How to write $upstream_trailer_{name} into access.log

Gena Makhomed gmm на csdoc.com
Сб Май 22 22:50:54 UTC 2021


On 23.05.2021 1:25, Andrey Kopeyko wrote:

> Добрый день, Геннадий!

Здравствуйте, Андрей!

>> Использую nginx/1.19.10 из официального репозитория nginx.org
>>
>> На бэкенде в секции http прописал такие директивы:
>>
>> add_trailer X-Response-Time $upstream_response_time always;
>> add_trailer X-Cache-Status $upstream_cache_status always;
>>
>> На фронтенде в секции http прописал proxy_http_version 1.1;
>> Также на фронтенде в директиву log_format добавил переменные:
>>
>> $upstream_trailer_x_response_time $upstream_trailer_x_cache_status
>>
>> Ожидается что в лог будут записаны полученные значения этих переменных,
>> но вместо них в лог пишутся символы - - обозначающие пустые значения.
>>
>> Почему так происходит?
> 
> Очевидно, потому что бэкенд _не_ возвращал вам заголовков 
> "trailer-x-response-time: " - вы их сами выдумали.

trailer fields at the end of the message - это не заголовки.

Бэкенд эти trailers возвращает, я проверял переменные

$sent_trailer_x_response_time $sent_trailer_x_cache_status

на бэкенде они имеют не пустые значения и пишутся в лог бэкенда.

Подробнее - см. в документации описание переменных

$sent_trailer_{name}
$upstream_trailer_{name}

http://nginx.org/en/docs/varindex.html
http://nginx.org/ru/docs/varindex.html

> А что вам мешает писать в лог значения $upstream_response_time и 
> $upstream_cache_status из которых вы свои кастомные заголовки строите?

В лог бэкенда я их так и пишу, напрямую, как
$upstream_response_time $upstream_cache_status

Но хотелось бы эти же самые значения видеть и в логе фронтенда.
(Это надо для более эффективной борьбы с DDoS-атаками на сайты)

Передать их с бэкенда на фронтенд удобнее всего будет с помощью
директивы add_trailer - она у меня больше нигде в конфиге
не используется, так что описать эти две директивы можно будет
всего один раз на уровне http и они будут работать для всех сайтов.

-- 
Best regards,
  Gena



Подробная информация о списке рассылки nginx-ru