vts: Модуль статуса трафика виртуального хоста NGINX
Установка на Debian/Ubuntu
Эти документы относятся к пакету APT nginx-module-vts, предоставляемому репозиторием GetPageSpeed Extras.
- Настройте репозиторий APT, как описано в настройке репозитория APT.
- Установите модуль:
sudo apt-get update
sudo apt-get install nginx-module-vts
Показать дистрибутивы и архитектуры
| Дистрибутив | Версия | Компонент | Архитектуры |
|-------------|------------------|-------------|------------------|
| debian | bookworm | main | amd64, arm64 |
| debian | bookworm-mainline| main | amd64, arm64 |
| debian | trixie | main | amd64, arm64 |
| debian | trixie-mainline | main | amd64, arm64 |
| ubuntu | focal | main | amd64, arm64 |
| ubuntu | focal-mainline | main | amd64, arm64 |
| ubuntu | jammy | main | amd64, arm64 |
| ubuntu | jammy-mainline | main | amd64, arm64 |
| ubuntu | noble | main | amd64, arm64 |
| ubuntu | noble-mainline | main | amd64, arm64 |
Модуль состояния трафика виртуального хоста Nginx
Тест
Запустите sudo prove -r t после установки этого модуля. sudo требуется, потому что
тесту необходимо, чтобы Nginx слушал на порту 80.
Скриншоты


Синопсис
http {
vhost_traffic_status_zone;
...
server {
...
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
Описание
Это модуль Nginx, который предоставляет доступ к информации о состоянии виртуального хоста. Он содержит текущее состояние, такое как сервера, верхние уровни, кэши. Это похоже на мониторинг активности в реальном времени Nginx Plus. Встроенный HTML также взят с демонстрационной страницы старой версии.
Прежде всего, требуется директива vhost_traffic_status_zone,
а затем, если директива vhost_traffic_status_display установлена, доступ к ней можно получить следующим образом:
- /status/format/json
- Если вы запрашиваете
/status/format/json, ответ будет в виде документа JSON, содержащего текущие данные активности для использования в панелях мониторинга в реальном времени и сторонних инструментах мониторинга. - /status/format/html
- Если вы запрашиваете
/status/format/html, ответ будет в виде встроенной панели мониторинга в HTML, которая внутренне запрашивает/status/format/json. - /status/format/jsonp
- Если вы запрашиваете
/status/format/jsonp, ответ будет в виде функции обратного вызова JSONP, содержащей текущие данные активности для использования в панелях мониторинга в реальном времени и сторонних инструментах мониторинга. - /status/format/prometheus
- Если вы запрашиваете
/status/format/prometheus, ответ будет в виде документа prometheus, содержащего текущие данные активности. - /status/control
- Если вы запрашиваете
/status/control, ответ будет в виде документа JSON после сброса или удаления зон через строку запроса. См. Управление.
Документ JSON содержит следующее:
{
"hostName": ...,
"moduleVersion": ...,
"nginxVersion": ...,
"loadMsec": ...,
"nowMsec": ...,
"connections": {
"active":...,
"reading":...,
"writing":...,
"waiting":...,
"accepted":...,
"handled":...,
"requests":...
},
"sharedZones": {
"name":...,
"maxSize":...,
"usedSize":...,
"usedNode":...
},
"serverZones": {
"...":{
"requestCounter":...,
"inBytes":...,
"outBytes":...,
"responses":{
"1xx":...,
"2xx":...,
"3xx":...,
"4xx":...,
"5xx":...,
"miss":...,
"bypass":...,
"expired":...,
"stale":...,
"updating":...,
"revalidated":...,
"hit":...,
"scarce":...
},
"requestMsecCounter":...,
"requestMsec":...,
"requestMsecs":{
"times":[...],
"msecs":[...]
},
"requestBuckets":{
"msecs":[...],
"counters":[...]
},
}
...
},
"filterZones": {
"...":{
"...":{
"requestCounter":...,
"inBytes":...,
"outBytes":...,
"responses":{
"1xx":...,
"2xx":...,
"3xx":...,
"4xx":...,
"5xx":...,
"miss":...,
"bypass":...,
"expired":...,
"stale":...,
"updating":...,
"revalidated":...,
"hit":...,
"scarce":...
},
"requestMsecCounter":...,
"requestMsec":...,
"requestMsecs":{
"times":[...],
"msecs":[...]
},
"requestBuckets":{
"msecs":[...],
"counters":[...]
},
},
...
},
...
},
"upstreamZones": {
"...":[
{
"server":...,
"requestCounter":...,
"inBytes":...,
"outBytes":...,
"responses":{
"1xx":...,
"2xx":...,
"3xx":...,
"4xx":...,
"5xx":...
},
"requestMsecCounter":...,
"requestMsec":...,
"requestMsecs":{
"times":[...],
"msecs":[...]
},
"requestBuckets":{
"msecs":[...],
"counters":[...]
},
"responseMsecCounter":...,
"responseMsec":...,
"responseMsecs":{
"times":[...],
"msecs":[...]
},
"responseBuckets":{
"msecs":[...],
"counters":[...]
},
"weight":...,
"maxFails":...,
"failTimeout":...,
"backup":...,
"down":...
}
...
],
...
}
"cacheZones": {
"...":{
"maxSize":...,
"usedSize":...,
"inBytes":...,
"outBytes":...,
"responses":{
"miss":...,
"bypass":...,
"expired":...,
"stale":...,
"updating":...,
"revalidated":...,
"hit":...,
"scarce":...
}
},
...
}
}
- main
- Базовая версия, время работы((nowMsec - loadMsec)/1000)
- nowMsec, loadMsec в миллисекундах.
- connections
- Общее количество соединений и запросов (то же самое, что и stub_status_module в NGINX)
- sharedZones
- Информация о разделяемой памяти, используемой в nginx-module-vts.
- serverZones
- Трафик (входящий/исходящий) и количество запросов и ответов, а также коэффициент попадания в кэш для каждой зоны сервера
- Общий трафик (входящий/исходящий) и количество запросов и ответов (имя зоны -
*) и коэффициент попадания - filterZones
- Трафик (входящий/исходящий) и количество запросов и ответов, а также коэффициент попадания в кэш для каждой зоны сервера, отфильтрованной через директиву
vhost_traffic_status_filter_by_set_key - Общий трафик (входящий/исходящий) и количество запросов и ответов (имя зоны -
*) и коэффициент попадания, отфильтрованный через директивуvhost_traffic_status_filter_by_set_key - upstreamZones
- Трафик (входящий/исходящий) и количество запросов и ответов для серверов в каждой группе upstream
- Текущие параметры (вес, maxfails, failtimeout...) в nginx.conf
- cacheZones
- Трафик (входящий/исходящий) и размер (вместимость/используемый) и коэффициент попадания для каждой зоны кэша при использовании директивы proxy_cache.
Объекты overCounts в документе JSON в основном предназначены для 32-битных систем и будут увеличиваться на 1, если их значение переполнено.
Директива vhost_traffic_status_display_format устанавливает формат по умолчанию, который является одним из json, jsonp, html, prometheus. (По умолчанию: json)
Расчет трафика выполняется следующим образом:
- ServerZones
- in += requested_bytes
- out += sent_bytes
- FilterZones
- in += requested_bytes через фильтр
- out += sent_bytes через фильтр
- UpstreamZones
- in += requested_bytes через ServerZones
- out += sent_bytes через ServerZones
- cacheZones
- in += requested_bytes через ServerZones
- out += sent_bytes через ServerZones
Все вычисления происходят на этапе обработки логов Nginx. Внутренние перенаправления (X-Accel-Redirect или error_page) не учитываются в UpstreamZones.
Предостережения: этот модуль зависит от системы логирования nginx (NGX_HTTP_LOG_PHASE: последний этап http nginx), поэтому трафик может быть
в определенных обстоятельствах отличен от реального трафика по полосе пропускания.
Websocket, отмененные загрузки могут быть причиной неточностей.
Работа модуля не зависит от того, включена ли директива access_log "включена" или "выключена".
Еще раз, этот модуль работает хорошо при "access_log off".
При использовании нескольких доменов он устанавливается как первый домен (слева) директивы server_name.
Если вы этого не хотите, смотрите директивы vhost_traffic_status_filter_by_host, vhost_traffic_status_filter_by_set_key.
Смотрите следующие модули для статистики трафика stream:
* nginx-module-sts
* nginx-module-stream-sts
Вычисления и Интервалы
Средние значения
Все средние значения в настоящее время рассчитываются как AMM(арифметическое среднее) за последние 64 значения.
Управление
Он способен сбросить или удалить зоны трафика через строку запроса. Запрос отвечает документом JSON.
- Синтаксис URI
- /
{status_uri}/control?cmd={command}&group={group}&zone={name}
http {
geoip_country /usr/share/GeoIP/GeoIP.dat;
vhost_traffic_status_zone;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::*;
...
server {
server_name example.org;
...
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
Если он установлен, как указано выше, то контрольный uri выглядит как example.org/status/control.
Доступные параметры запроса следующие:
* cmd=\<status|reset|delete>
* status
* Возвращает статус зон трафика в формате json, как status/format/json.
* reset
* Сбрасывает зоны трафика, не удаляя узлы в общей памяти. (= инициализация в 0)
* delete
* Удаляет зоны трафика из общей памяти. При повторном запросе создаются заново.
* group=\<server|filter|upstream@alone|upstream@group|cache|*>
* server
* filter
* upstream@alone
* upstream@group
* cache
* *
* zone=name
* server
* name
* filter
* filter_group@name
* upstream@group
* upstream_group@name
* upstream@alone
* @name
* cache
* name
Получение статуса зон трафика на лету
Это похоже на status/format/json, за исключением того, что можно получить каждую зону.
Для получения всех зон
- Это точно так же, как
status/format/json. - /status/control?cmd=status&group=*
Для получения групповых зон
- mainZones
- /status/control?cmd=status&group=server&zone=::main
- serverZones
- /status/control?cmd=status&group=server&zone=*
- filterZones
- /status/control?cmd=status&group=filter&zone=*
- upstreamZones
- /status/control?cmd=status&group=upstream@group&zone=*
- upstreamZones::nogroups
- /status/control?cmd=status&group=upstream@alone&zone=*
- cacheZones
- /status/control?cmd=status&group=cache&zone=*
Значения mainZones — это значения статуса по умолчанию, включая hostName, moduleVersion, nginxVersion, loadMsec, nowMsec, connections.
Для получения каждой зоны
- единственная зона в serverZones
- /status/control?cmd=status&group=server&zone=
name - единственная зона в filterZones
- /status/control?cmd=status&group=filter&zone=
filter_group@name - единственная зона в upstreamZones
- /status/control?cmd=status&group=upstream@group&zone=
upstream_group@name - единственная зона в upstreamZones::nogroups
- /status/control?cmd=status&group=upstream@alone&zone=
name - единственная зона в cacheZones
- /status/control?cmd=status&group=cache&zone=
name
Сброс зон трафика на лету
Он сбрасывает значения указанных зон в 0.
Для сброса всех зон
- /status/control?cmd=reset&group=*
Для сброса групповых зон
- serverZones
- /status/control?cmd=reset&group=server&zone=*
- filterZones
- /status/control?cmd=reset&group=filter&zone=*
- upstreamZones
- /status/control?cmd=reset&group=upstream@group&zone=*
- upstreamZones::nogroups
- /status/control?cmd=reset&group=upstream@alone&zone=*
- cacheZones
- /status/control?cmd=reset&group=cache&zone=*
Для сброса каждой зоны
- единственная зона в serverZones
- /status/control?cmd=reset&group=server&zone=
name - единственная зона в filterZones
- /status/control?cmd=reset&group=filter&zone=
filter_group@name - единственная зона в upstreamZones
- /status/control?cmd=reset&group=upstream@group&zone=
upstream_group@name - единственная зона в upstreamZones::nogroups
- /status/control?cmd=reset&group=upstream@alone&zone=
name - единственная зона в cacheZones
- /status/control?cmd=reset&group=cache&zone=
name
Удаление зон трафика на лету
Он удаляет указанные зоны из общей памяти.
Для удаления всех зон
- /status/control?cmd=delete&group=*
Для удаления групповых зон
- serverZones
- /status/control?cmd=delete&group=server&zone=*
- filterZones
- /status/control?cmd=delete&group=filter&zone=*
- upstreamZones
- /status/control?cmd=delete&group=upstream@group&zone=*
- upstreamZones::nogroups
- /status/control?cmd=delete&group=upstream@alone&zone=*
- cacheZones
- /status/control?cmd=delete&group=cache&zone=*
Для удаления каждой зоны
- единственная зона в serverZones
- /status/control?cmd=delete&group=server&zone=
name - единственная зона в filterZones
- /status/control?cmd=delete&group=filter&zone=
filter_group@name - единственная зона в upstreamZones
- /status/control?cmd=delete&group=upstream@group&zone=
upstream_group@name - единственная зона в upstreamZones::nogroups
- /status/control?cmd=delete&group=upstream@alone&zone=
name - единственная зона в cacheZones
- /status/control?cmd=delete&group=cache&zone=
name
Set
С помощью директивы vhost_traffic_status_set_by_filter можно отдельно получить значения статусов в конфигурации nginx. Она может получить почти все значения статусов, и полученное значение сохраняется в переменной, определяемой пользователем, которая является первым аргументом.
- Синтаксис директивы
- vhost_traffic_status_set_by_filter $variable group/zone/name
http {
geoip_country /usr/share/GeoIP/GeoIP.dat;
vhost_traffic_status_zone;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::*;
...
upstream backend {
10.10.10.11:80;
10.10.10.12:80;
}
server {
server_name example.org;
...
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
vhost_traffic_status_set_by_filter $requestCounter server/example.org/requestCounter;
vhost_traffic_status_set_by_filter $requestCounterKR filter/country::example.org@KR/requestCounter;
location /backend {
vhost_traffic_status_set_by_filter $requestCounterB1 upstream@group/backend@10.10.10.11:80/requestCounter;
proxy_pass http://backend;
}
}
}
Вышеуказанные настройки выглядят следующим образом:
- $requestCounter
- serverZones -> example.org -> requestCounter
- $requestCounterKR
- filterZones -> country::example.org -> KR -> requestCounter
- $requestCounterB1
- upstreamZones -> backend -> 10.0.10.11:80 -> requestCounter
Пожалуйста, обратитесь к директиве vhost_traffic_status_set_by_filter для получения подробной информации о использовании.
JSON
Следующая информация о состоянии предоставляется в формате JSON:
Json используемый для состояния
/{status_uri}/format/json
/{status_uri}/control?cmd=status&...
- hostName
- Имя хоста.
- moduleVersion
- Версия модуля в формате
{version}(|.dev.{commit}). - nginxVersion
- Версия предоставленного.
- loadMsec
- Время загрузки процесса в миллисекундах.
- nowMsec
- Текущее время в миллисекундах.
- connections
- active
- Текущее количество активных клиентских соединений.
- reading
- Общее количество читателей клиентских соединений.
- writing
- Общее количество писателей клиентских соединений.
- waiting
- Общее количество ожидающих клиентских соединений.
- accepted
- Общее количество принятых клиентских соединений.
- handled
- Общее количество обработанных клиентских соединений.
- requests
- Общее количество запрошенных клиентских соединений.
- sharedZones
- name
- Имя общей памяти, указанное в конфигурации. (по умолчанию:
vhost_traffic_status)
- Имя общей памяти, указанное в конфигурации. (по умолчанию:
- maxSize
- Ограничение на максимальный размер общей памяти, указанное в конфигурации.
- usedSize
- Текущий размер общей памяти.
- usedNode
- Текущее количество узлов, использующих общую память. Приблизительный размер одного узла можно получить по следующей формуле: (usedSize / usedNode)
- serverZones
- requestCounter
- Общее количество клиентских запросов, полученных от клиентов.
- inBytes
- Общее количество байт, полученных от клиентов.
- outBytes
- Общее количество байт, отправленных клиентам.
- responses
- 1xx, 2xx, 3xx, 4xx, 5xx
- Количество ответов с кодами состояния 1xx, 2xx, 3xx, 4xx и 5xx.
- miss
- Количество промахов кэша.
- bypass
- Количество обходов кэша.
- expired
- Количество истекших кэшей.
- stale
- Количество устаревших кэшей.
- updating
- Количество обновляющихся кэшей.
- revalidated
- Количество переутвержденных кэшей.
- hit
- Количество попаданий в кэш.
- scarce
- Количество недостатков кэша.
- requestMsecCounter
- Число накопленного времени обработки запросов в миллисекундах.
- requestMsec
- Среднее время обработки запросов в миллисекундах.
- requestMsecs
- times
- Время в миллисекундах на время обработки запросов.
- msecs
- Время обработки запросов в миллисекундах.
- requestBuckets
- msecs
- Значения ведер гистограммы, установленные директивой
vhost_traffic_status_histogram_buckets. - counters
- Кумулятивные значения, для которых каждое значение ведра больше или равно времени обработки запроса.
- filterZones
- Обеспечивает те же поля, что и
serverZones, за исключением того, что включены имена групп. - upstreamZones
- server
- Адрес сервера.
- requestCounter
- Общее количество клиентских соединений, перенаправленных на этот сервер.
- inBytes
- Общее количество байт, полученных от этого сервера.
- outBytes
- Общее количество байт, отправленных на этот сервер.
- responses
- 1xx, 2xx, 3xx, 4xx, 5xx
- Количество ответов с кодами состояния 1xx, 2xx, 3xx, 4xx и 5xx.
- requestMsecCounter
- Количество накопленного времени обработки запросов, включая upstream, в миллисекундах.
- requestMsec
- Среднее время обработки запросов, включая upstream, в миллисекундах.
- requestMsecs
- times
- Время в миллисекундах на время обработки запросов.
- msecs
- Время обработки запросов, включая upstream, в миллисекундах.
- requestBuckets
- msecs
- Значения ведер гистограммы, установленные директивой
vhost_traffic_status_histogram_buckets. - counters
- Кумулятивные значения, для которых каждое значение ведра больше или равно времени обработки запроса, включая upstream.
- responseMsecCounter
- Количество накопленного времени обработки только upstream ответов в миллисекундах.
- responseMsec
- Среднее время обработки только upstream ответов в миллисекундах.
- responseMsecs
- times
- Время в миллисекундах на время обработки ответов.
- msecs
- Время обработки только upstream ответов в миллисекундах.
- responseBuckets
- msecs
- Значения ведер гистограммы, установленные директивой
vhost_traffic_status_histogram_buckets. - counters
- Кумулятивные значения, для которых каждое значение ведра больше или равно времени обработки только upstream ответов.
- weight
- Текущая настройка
weightдля сервера.
- Текущая настройка
- maxFails
- Текущая настройка
max_failsдля сервера.
- Текущая настройка
- failTimeout
- Текущая настройка
fail_timeoutдля сервера.
- Текущая настройка
- backup
- Текущая настройка
backupдля сервера.
- Текущая настройка
- down
- Текущая настройка
downдля сервера. В основном, это просто отметка о том, что сервер из ngx_http_upstream_module отключен (например,server backend3.example.com down), а не фактическое состояние upstream сервера. Это изменится на фактическое состояние, если вы включите директиву upstream zone.
- Текущая настройка
- cacheZones
- maxSize
- Ограничение на максимальный размер кэша, указанное в конфигурации. Если
max_sizeв директивеproxy_cache_pathне указано, по умолчанию используется значение, зависящее от системы,NGX_MAX_OFF_T_VALUE. Другими словами, это значение из nginx, а не то, что я указал.
- Ограничение на максимальный размер кэша, указанное в конфигурации. Если
- usedSize
- Текущий размер кэша. Это значение берется из nginx, как и вышеуказанное значение
maxSize.
- Текущий размер кэша. Это значение берется из nginx, как и вышеуказанное значение
- inBytes
- Общее количество байт, полученных из кэша.
- outBytes
- Общее количество байт, отправленных из кэша.
- responses
- miss
- Количество промахов кэша.
- bypass
- Количество обходов кэша.
- expired
- Количество истекших кэшей.
- stale
- Количество устаревших кэшей.
- updating
- Количество обновляющихся кэшей.
- revalidated
- Количество переутвержденных кэшей.
- hit
- Количество попаданий в кэш.
- scarce
- Количество недостатков кэша.
Json используемый для управления
/{status_uri}/control?cmd=reset&...
/{status_uri}/control?cmd=delete&...
- processingReturn
- Результат true или false.
- processingCommandString
- Запрошенная строка команды.
- processingGroupString
- Запрошенная строка группы.
- processingZoneString
- Запрошенная строка зоны.
- processingCounts
- Фактическое количество обработки.
Переменные
Следующие встроенные переменные доступны:
- $vts_request_counter
- Общее количество клиентских запросов, полученных от клиентов.
- $vts_in_bytes
- Общее количество байт, полученных от клиентов.
- $vts_out_bytes
- Общее количество байт, отправленных клиентам.
- $vts_1xx_counter
- Количество ответов со статус-кодами 1xx.
- $vts_2xx_counter
- Количество ответов со статус-кодами 2xx.
- $vts_3xx_counter
- Количество ответов со статус-кодами 3xx.
- $vts_4xx_counter
- Количество ответов со статус-кодами 4xx.
- $vts_5xx_counter
- Количество ответов со статус-кодами 5xx.
- $vts_cache_miss_counter
- Количество промахов кэша.
- $vts_cache_bypass_counter
- Количество обходов кэша.
- $vts_cache_expired_counter
- Количество истекших значений кэша.
- $vts_cache_stale_counter
- Количество устаревших значений кэша.
- $vts_cache_updating_counter
- Количество обновлений кэша.
- $vts_cache_revalidated_counter
- Количество повторно подтвержденных значений кэша.
- $vts_cache_hit_counter
- Количество попаданий в кэш.
- $vts_cache_scarce_counter
- Количество дефицита кэша.
- $vts_request_time_counter
- Общее количество времени обработки запросов.
- $vts_request_time
- Среднее время обработки запросов.
Ограничение
Он способен ограничивать общий трафик для каждого хоста с помощью директивы
vhost_traffic_status_limit_traffic.
Он также может ограничивать весь трафик с помощью директивы
vhost_traffic_status_limit_traffic_by_set_key.
Когда лимит превышен, сервер вернет ошибку 503
(Служба временно недоступна) в ответ на запрос.
Код возврата может быть изменен.
Ограничить трафик для сервера
http {
vhost_traffic_status_zone;
...
server {
server_name *.example.org;
vhost_traffic_status_limit_traffic in:64G;
vhost_traffic_status_limit_traffic out:1024G;
...
}
}
- Ограничить входящий/исходящий общий трафик на
*.example.orgдо 64G и 1024G соответственно. Это работает индивидуально для каждого домена, если включена директиваvhost_traffic_status_filter_by_host.
Ограничить трафик для фильтра
http {
geoip_country /usr/share/GeoIP/GeoIP.dat;
vhost_traffic_status_zone;
...
server {
server_name example.org;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
vhost_traffic_status_limit_traffic_by_set_key FG@country::$server_name@US out:1024G;
vhost_traffic_status_limit_traffic_by_set_key FG@country::$server_name@CN out:2048G;
...
}
}
- Ограничить общий трафик, поступающий в США и КНР на
example.org, до 1024G и 2048G соответственно.
Ограничить трафик для upstream
http {
vhost_traffic_status_zone;
...
upstream backend {
server 10.10.10.17:80;
server 10.10.10.18:80;
}
server {
server_name example.org;
location /backend {
vhost_traffic_status_limit_traffic_by_set_key UG@backend@10.10.10.17:80 in:512G;
vhost_traffic_status_limit_traffic_by_set_key UG@backend@10.10.10.18:80 in:1024G;
proxy_pass http://backend;
}
...
}
}
- Ограничить общий трафик, поступающий в upstream backend на
example.org, до 512G и 1024G для каждого пира.
Предостережения: Трафик - это накопленный объем передачи или счетчик, а не скорость передачи данных.
Сценарии использования
Он способен вычислять определенные пользователем индивидуальные статистические данные, используя директиву vhost_traffic_status_filter_by_set_key.
Для вычисления трафика для отдельной страны с использованием GeoIP
http {
geoip_country /usr/share/GeoIP/GeoIP.dat;
vhost_traffic_status_zone;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::*;
...
server {
...
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
- Вычисление трафика для отдельной страны среди всех серверных групп.
- Вычисление трафика для отдельной страны для каждой из серверных групп.
В основном, изображения флагов стран встроены в HTML.
Изображение флага страны включается, если строка country присутствует в названии группы, который является вторым аргументом директивы vhost_traffic_status_filter_by_set_key.
Для вычисления трафика для отдельного дискового объема
http {
vhost_traffic_status_zone;
...
server {
...
location ~ ^/storage/(.+)/.*$ {
set $volume $1;
vhost_traffic_status_filter_by_set_key $volume storage::$server_name;
}
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
- Вычисление трафика для отдельного дискового объема, совпадающего с регулярным выражением директивы location.
Для вычисления трафика для отдельного пользовательского агента
http {
vhost_traffic_status_zone;
map $http_user_agent $filter_user_agent {
default 'unknown';
~iPhone ios;
~Android android;
~(MSIE|Mozilla) windows;
}
vhost_traffic_status_filter_by_set_key $filter_user_agent agent::*;
...
server {
...
vhost_traffic_status_filter_by_set_key $filter_user_agent agent::$server_name;
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
- Вычисление трафика для отдельного
http_user_agent
Для вычисления трафика по детальному коду http статуса
http {
vhost_traffic_status_zone;
server {
...
vhost_traffic_status_filter_by_set_key $status $server_name;
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
- Вычисление трафика по детальному
http статус коду
Предостережения: Переменная $status доступна в nginx-(1.3.2, 1.2.2).
Для вычисления трафика для динамического dns
Если домен имеет несколько DNS A записей, вы можете вычислить трафик для отдельных IP-адресов для домена, используя функцию фильтрации или переменную в proxy_pass.
http {
vhost_traffic_status_zone;
upstream backend {
elb.example.org:80;
}
...
server {
...
location /backend {
vhost_traffic_status_filter_by_set_key $upstream_addr upstream::backend;
proxy_pass backend;
}
}
}
- Вычисление трафика для отдельных IP-адресов для домена
elb.example.org. Если уelb.example.orgесть несколько DNS A записей, будут отображены все IP-адреса вfilterZones. В вышеуказанных настройках, когда NGINX запускается или обновляет свою конфигурацию, он запрашивает DNS сервер для разрешения домена, и DNS A записи кешируются в памяти. Поэтому DNS A записи не изменяются в памяти, даже если DNS A записи изменяются администратором DNS, если только NGINX не перезапускается или не перезагружается.
http {
vhost_traffic_status_zone;
resolver 10.10.10.53 valid=10s
...
server {
...
location /backend {
set $backend_server elb.example.org;
proxy_pass http://$backend_server;
}
}
}
- Вычисление трафика для отдельных IP-адресов для домена
elb.example.org. Если A запись DNSelb.example.orgизменяется, будет отображен как старый, так и новый IP в::nogroups. В отличие от первой настройки группы upstream, вторая настройка работает хорошо, даже если A записи DNS изменяются администратором DNS.
Предостережения: Пожалуйста, ознакомьтесь с дополнительной информацией о DNS NGINX
в статье dns-service-discovery-nginx-plus.
Для вычисления трафика, за исключением страницы состояния
http {
vhost_traffic_status_zone;
...
server {
...
location /status {
vhost_traffic_status_bypass_limit on;
vhost_traffic_status_bypass_stats on;
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
- URI
/statusисключается из расчета трафика состояния и функции ограничения. Смотрите следующие директивы: - vhost_traffic_status_bypass_limit
- vhost_traffic_status_bypass_stats
Для постоянного хранения статистических данных
http {
vhost_traffic_status_zone;
vhost_traffic_status_dump /var/log/nginx/vts.db;
...
server {
...
}
}
- Директива
vhost_traffic_status_dumpобеспечивает постоянное хранение статистических данных, даже если система была перезагружена или nginx был перезапущен. Пожалуйста, смотрите директиву vhost_traffic_status_dump для подробного использования.
Настройка
Настройка после установки модуля
-
Вам нужно изменить строку
{{uri}}на ваш статусный URI в status.template.html следующим образом:shell> vi share/status.template.htmlvar vtsStatusURI = "yourStatusUri/format/json", vtsUpdateInterval = 1000; -
Затем настройте и скопируйте status.template.html в корневую директорию сервера следующим образом:
shell> cp share/status.template.html /usr/share/nginx/html/status.html -
Настройте
nginx.confserver { server_name example.org; root /usr/share/nginx/html; # Перенаправить запросы с / на /status.html location = / { return 301 /status.html; } location = /status.html {} # Всё, что начинается с /status (кроме /status.html) обрабатывается # обработчиком статуса location /status { vhost_traffic_status_display; vhost_traffic_status_display_format json; } } -
Доступ к вашему html.
http://example.org/status.html
Настройка до установки модуля
-
Измените
share/status.template.html(не меняйте строку{{uri}}) -
Восстановите файл
ngx_http_vhost_traffic_status_module_html.hследующим образом:shell> cd util shell> ./tplToDefine.sh ../share/status.template.html > ../src/ngx_http_vhost_traffic_status_module_html.h -
Добавьте модуль в конфигурацию сборки, добавив
--add-module=/path/to/nginx-module-vts -
Соберите двоичный файл nginx.
-
Установите двоичный файл nginx.
Директивы

vhost_traffic_status
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status \<on|off> |
| По умолчанию | off |
| Контекст | http, server, location |
Описание: Включает или отключает работу модуля. Если вы установите директиву vhost_traffic_status_zone, она автоматически включится.
vhost_traffic_status_zone
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_zone [shared:name:size] |
| По умолчанию | shared:vhost_traffic_status:1m |
| Контекст | http |
Описание: Устанавливает параметры для зоны общей памяти, которая будет хранить состояния для различных ключей. Кэш разделяется между всеми рабочими процессами. В большинстве случаев размер общей памяти, используемой модулем nginx-module-vts, значительно не увеличивается. Размер общей памяти увеличивается довольно сильно при использовании директивы vhost_traffic_status_filter_by_set_key, но если ключи фильтра фиксированы (например, общее количество кодов стран составляет около 240), он не увеличивается постоянно.
Если вы используете директиву vhost_traffic_status_filter_by_set_key, установите ее следующим образом:
- Установите больше 32M по умолчанию.
(
vhost_traffic_status_zone shared:vhost_traffic_status:32m) - Если в error_log выводится сообщение (
"ngx_slab_alloc() failed: no memory in vhost_traffic_status_zone"), увеличьте значение более чем на (usedSize * 2).
vhost_traffic_status_dump
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_dump path [period] |
| По умолчанию | - |
| Контекст | http |
Описание: Включает дамп статистических данных и восстановление. Путь path - это местоположение для дампа статистических данных (например, /var/log/nginx/vts.db). Период period - это время цикла резервного копирования (по умолчанию: 60s). Он будет забэкаплен немедленно независимо от цикла резервного копирования, если nginx завершится по сигналу (SIGKILL).
vhost_traffic_status_display
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_display |
| По умолчанию | - |
| Контекст | http, server, location |
Описание: Включает или отключает дисплейный обработчик модуля.
vhost_traffic_status_display_format
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_display_format \<json|html|jsonp|prometheus> |
| По умолчанию | json |
| Контекст | http, server, location |
Описание: Устанавливает формат вывода обработчика отображения. Если вы установите json, будет дан ответ в виде документа JSON. Если вы установите html, будет дан ответ с встроенной живой панелью в формате HTML. Если вы установите jsonp, будет дан ответ с функцией обратного вызова JSONP (по умолчанию: ngx_http_vhost_traffic_status_jsonp_callback). Если вы установите prometheus, будет дан ответ с документом prometheus.
vhost_traffic_status_display_jsonp
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_display_jsonp callback |
| По умолчанию | ngx_http_vhost_traffic_status_jsonp_callback |
| Контекст | http, server, location |
Описание: Устанавливает имя обратного вызова для JSONP.
vhost_traffic_status_display_sum_key
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_display_sum_key name |
| По умолчанию | * |
| Контекст | http, server, location |
Описание: Устанавливает строку суммы ключа в поле JSON serverZones. Строка суммы по умолчанию - это "*".
vhost_traffic_status_filter
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_filter \<on|off> |
| По умолчанию | on |
| Контекст | http, server, location |
Описание: Включает или отключает функции фильтрации.
vhost_traffic_status_filter_by_host
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_filter_by_host \<on|off> |
| По умолчанию | off |
| Контекст | http, server, location |
Описание: Включает или отключает ключи по полю заголовка Host. Если вы установите on, и директива server_name nginx установлена на несколько или с подстановочным знаком, начинающимся с символа , например, “.example.org”, и будет запрашиваться сервер с именем хоста, таким как (a|b|c).example.org или *.example.org, тогда JSON serverZones будет распечатан следующим образом:
server {
server_name *.example.org;
vhost_traffic_status_filter_by_host on;
...
}
...
"serverZones": {
"a.example.org": {
...
},
"b.example.org": {
...
},
"c.example.org": {
...
}
...
},
...
Это обеспечивает ту же функциональность, что и установка vhost_traffic_status_filter_by_set_key $host.
vhost_traffic_status_filter_by_set_key
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_filter_by_set_key key [name] |
| По умолчанию | - |
| Контекст | http, server, location |
Описание: Включает ключи по пользовательской переменной. Ключ key - это строка ключа для расчета трафика. name - это строка группы для расчета трафика. key и name могут содержать переменные, такие как $host, $server_name. Группа name принадлежит filterZones, если указана. Группа key принадлежит serverZones, если не указаны вторичный аргумент name. Пример с модулем geoip представлен ниже:
server {
server_name example.org;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
...
}
...
"serverZones": {
...
},
"filterZones": {
"country::example.org": {
"KR": {
"requestCounter":...,
"inBytes":...,
"outBytes":...,
"responses":{
"1xx":...,
"2xx":...,
"3xx":...,
"4xx":...,
"5xx":...,
"miss":...,
"bypass":...,
"expired":...,
"stale":...,
"updating":...,
"revalidated":...,
"hit":...,
"scarce":...
},
"requestMsecCounter":...,
"requestMsec":...,
"requestMsecs":{
"times":[...],
"msecs":[...]
},
},
"US": {
...
},
...
},
...
},
...
vhost_traffic_status_filter_check_duplicate
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_filter_check_duplicate \<on|off> |
| По умолчанию | on |
| Контекст | http, server, location |
Описание: Включает или отключает дедупликацию vhost_traffic_status_filter_by_set_key. Обрабатывается только одно из дублирующих значений (key + name) в каждой директиве (http, server, location), если эта опция включена.
vhost_traffic_status_filter_max_node
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_filter_max_node number [string ...] |
| По умолчанию | 0 |
| Контекст | http |
Описание: Включает ограничение на размер фильтра с использованием указанных значений number и string. Если number превышено, существующие узлы удаляются по алгоритму LRU. Аргумент number - это размер узла, который будет ограничен. Значение по умолчанию 0 не ограничивает фильтры. Один узел - это объект в filterZones в JSON документе. Аргументы string - это значения строк, которые соответствуют строковым значениям группы, установленным директивой vhost_traffic_status_filter_by_set_key. Даже если совпадает только первая часть, соответствие успешно, как в регулярном выражении /^string.*/. По умолчанию, если вы не задаете аргументы string, они применяются для всех фильтров.
Примеры:
$ vi nginx.conf
http {
geoip_country /usr/share/GeoIP/GeoIP.dat;
vhost_traffic_status_zone;
# Все фильтры ограничены в общей сложности 16 узлов.
# vhost_traffic_status_filter_max_node 16
# Шаблоны групповых строк `/^uris.*/` и `/^client::ports.*/` ограничены в общей сложности 64 узла.
vhost_traffic_status_filter_max_node 16 uris client::ports;
...
server {
server_name example.org;
...
vhost_traffic_status_filter_by_set_key $uri uris::$server_name;
vhost_traffic_status_filter_by_set_key $remote_port client::ports::$server_name;
vhost_traffic_status_filter_by_set_key $geoip_country_code country::$server_name;
}
}
$ for i in {0..1000}; do curl -H 'Host: example.org' -i "http://localhost:80/test$i"; done

В приведенном выше примере шаблоны групповых строк /^uris.*/ и /^client::ports.*/ ограничены в общей сложности 16 узлов. Остальные фильтры, такие как country::.*, не ограничены.
vhost_traffic_status_limit
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_limit \<on|off> |
| По умолчанию | on |
| Контекст | http, server, location |
Описание: Включает или отключает функции ограничения.
vhost_traffic_status_limit_traffic
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_limit_traffic member:size [code] |
| По умолчанию | - |
| Контекст | http, server, location |
Описание: Включает ограничение трафика для указанного member. member - это строка члена для ограничения трафика. size - это размер (k/m/g) для ограничения трафика. code - это код, который вернуть в ответ на отклоненные запросы (по умолчанию: 503).
Доступные строки member следующие:
* request
* Общее количество клиентских запросов, полученных от клиентов.
* in
* Общее количество байт, полученных от клиентов.
* out
* Общее количество байт, отправленных клиентам.
* 1xx
* Количество ответов со статус-кодами 1xx.
* 2xx
* Количество ответов со статус-кодами 2xx.
* 3xx
* Количество ответов со статус-кодами 3xx.
* 4xx
* Количество ответов со статус-кодами 4xx.
* 5xx
* Количество ответов со статус-кодами 5xx.
* cache_miss
* Количество пропусков кэша.
* cache_bypass
* Количество обхождений кэша.
* cache_expired
* Количество истекших кэшей.
* cache_stale
* Количество устаревших кэшей.
* cache_updating
* Количество обновлений кэша.
* cache_revalidated
* Количество повторных проверок кэша.
* cache_hit
* Количество попаданий в кэш.
* cache_scarce
* Количество дефицита кэша.
vhost_traffic_status_limit_traffic_by_set_key
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_limit_traffic_by_set_key key member:size [code] |
| По умолчанию | - |
| Контекст | http, server, location |
Описание: Включает ограничение трафика для указанного key и member. key - это строка ключа для ограничения трафика. member - это строка члена для ограничения трафика. size - это размер (k/m/g) для ограничения трафика. code - это код, который вернуть в ответ на отклоненные запросы (по умолчанию: 503).
Синтаксис key следующий:
* group@[subgroup@]name
Доступные строки group следующие:
* NO
* Группа сервера.
* UA
* Группа уникального upstream.
* UG
* Группа upstream (используйте subgroup).
* CC
* Группа кэша.
* FG
* Группа фильтров (используйте subgroup).
Доступные строки member следующие:
* request
* Общее количество клиентских запросов, полученных от клиентов.
* in
* Общее количество байт, полученных от клиентов.
* out
* Общее количество байт, отправленных клиентам.
* 1xx
* Количество ответов со статус-кодами 1xx.
* 2xx
* Количество ответов со статус-кодами 2xx.
* 3xx
* Количество ответов со статус-кодами 3xx.
* 4xx
* Количество ответов со статус-кодами 4xx.
* 5xx
* Количество ответов со статус-кодами 5xx.
* cache_miss
* Количество пропусков кэша.
* cache_bypass
* Количество обхождений кэша.
* cache_expired
* Количество истекших кэшей.
* cache_stale
* Количество устаревших кэшей.
* cache_updating
* Количество обновлений кэша.
* cache_revalidated
* Количество повторных проверок кэша.
* cache_hit
* Количество попаданий в кэш.
* cache_scarce
* Количество дефицита кэша.
member аналогично директиве vhost_traffic_status_limit_traffic.
vhost_traffic_status_limit_check_duplicate
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_limit_check_duplicate \<on|off> |
| По умолчанию | on |
| Контекст | http, server, location |
Описание: Включает или отключает дедупликацию vhost_traffic_status_limit_by_set_key. Обрабатывается только одно из дублирующих значений (member | key + member) в каждой директиве (http, server, location), если эта опция включена.
vhost_traffic_status_set_by_filter
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_set_by_filter $variable group/zone/name |
| По умолчанию | - |
| Контекст | http, server, location, if |
Описание: Получает указанное значение состояния, хранящееся в общей памяти. Он может получить почти все значения состояния, а полученное значение хранится в $variable, который является первым аргументом.
- group
- server
- filter
- upstream@alone
- upstream@group
- cache
- zone
- server
- name
- filter
- filter_group@name
- upstream@group
- upstream_group@name
- upstream@alone
- @name
- cache
- name
- name
- requestCounter
- Общее количество клиентских запросов, полученных от клиентов.
- requestMsecCounter
- Количество накопленного времени обработки запросов в миллисекундах.
- requestMsec
- Среднее время обработки запросов в миллисекундах.
- responseMsecCounter
- Количество накопленного времени обработки только ответов upstream в миллисекундах.
- responseMsec
- Среднее время обработки только ответов upstream в миллисекундах.
- inBytes
- Общее количество байт, полученных от клиентов.
- outBytes
- Общее количество байт, отправленных клиентам.
- 1xx, 2xx, 3xx, 4xx, 5xx
- Количество ответов со статус-кодами 1xx, 2xx, 3xx, 4xx и 5xx.
- cacheMaxSize
- Ограничение на максимальный размер кэша, указанное в конфигурации.
- cacheUsedSize
- Текущий размер кэша.
- cacheMiss
- Количество пропусков кэша.
- cacheBypass
- Количество обхождений кэша.
- cacheExpired
- Количество истекших кэшей.
- cacheStale
- Количество устаревших кэшей.
- cacheUpdating
- Количество обновлений кэша.
- cacheRevalidated
- Количество повторных проверок кэша.
- cacheHit
- Количество попаданий в кэш.
- cacheScarce
- Количество дефицита кэша.
- weight
- Текущая настройка веса сервера.
- maxFails
- Текущая настройка max_fails сервера.
- failTimeout
- Текущая настройка fail_timeout сервера.
- backup
- Текущая настройка резервирования сервера (0|1).
- down
- Текущая настройка состояния сервера (0|1).
Предостережения: name чувствителен к регистру. Все возвращаемые значения имеют целочисленный тип.
Примеры:
* requestCounter в serverZones
* vhost_traffic_status_set_by_filter $requestCounter server/example.org/requestCounter
* requestCounter в фильтровых зонах
* vhost_traffic_status_set_by_filter $requestCounter filter/country::example.org@KR/requestCounter
* requestCounter в upstreamZones
* vhost_traffic_status_set_by_filter $requestCounter upstream@group/backend@10.10.10.11:80/requestCounter
* requestCounter в upstreamZones::nogroups
* vhost_traffic_status_set_by_filter $requestCounter upstream@alone/10.10.10.11:80/requestCounter
* cacheHit в cacheZones
* vhost_traffic_status_set_by_filter $cacheHit cache/my_cache_name/cacheHit
vhost_traffic_status_average_method
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_average_method \<AMM|WMA> [period] |
| По умолчанию | AMM 60s |
| Контекст | http, server, location |
Описание: Устанавливает метод, который является формулой для расчета среднего времени обработки ответов. Период period - это эффективное время значений, используемых для расчета среднего (по умолчанию: 60s). Если period установлено на 0, эффективное время игнорируется. В этом случае отображается последнее среднее значение, даже если запросов не было, и после истечения времени. Соответствующие значения - это requestMsec и responseMsec в JSON.
- AMM
- AMM - это арифметическое среднее.
- WMA
- WMA - это взвешенное скользящее среднее.
vhost_traffic_status_histogram_buckets
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_histogram_buckets second ... |
| По умолчанию | - |
| Контекст | http, server, location |
Описание: Устанавливает ведра для наблюдения, используемые в гистограммах. По умолчанию, если вы не установите эту директиву, она не будет работать. second может быть указано в десятичных дробях с минимальным значением 0.001 (1ms). Максимальный размер ведер - 32. Если этого значения недостаточно для вас, измените NGX_HTTP_VHOST_TRAFFIC_STATUS_DEFAULT_BUCKET_LEN в src/ngx_http_vhost_traffic_status_node.h.
Примеры:
* vhost_traffic_status_histogram_buckets 0.005 0.01 0.05 0.1 0.5 1 5 10
* Ведра наблюдения: [5ms 10ms 50ms 100ms 500ms 1s 5s 10s].
* vhost_traffic_status_histogram_buckets 0.005 0.01 0.05 0.1
* Ведра наблюдения: [5ms 10ms 50ms 100ms].
Предостережения: По умолчанию, если вы не установите эту директиву, статистика гистограммы не работает. Восстановленные гистограммы директивой vhost_traffic_status_dump не подлежат влиянию изменений ведер в директиве vhost_traffic_status_histogram_buckets. Поэтому вы должны сначала удалить зону или файл дампа перед изменением ведер в директиве vhost_traffic_status_histogram_buckets. Аналогично, удалите файл дампа при первом использовании гистограммы.
vhost_traffic_status_bypass_limit
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_bypass_limit \<on|off> |
| По умолчанию | off |
| Контекст | http, server, location |
Описание: Включает или отключает обход директив vhost_traffic_status_limit. Функции ограничения обходятся, если эта опция включена. Это в основном полезно, если вы хотите подключиться к веб-странице состояния, такой как /status, независимо от директив vhost_traffic_status_limit, как показано ниже:
http {
vhost_traffic_status_zone;
...
server {
...
location /status {
vhost_traffic_status_bypass_limit on;
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
vhost_traffic_status_bypass_stats
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_bypass_stats \<on|off> |
| По умолчанию | off |
| Контекст | http, server, location |
Описание: Включает или отключает обход vhost_traffic_status. Функции статистики трафика обходятся, если эта опция включена. Другими словами, это исключено из статистики трафика. Это в основном полезно, если вы хотите игнорировать свой запрос на веб-странице состояния, такой как /status, как показано ниже:
http {
vhost_traffic_status_zone;
...
server {
...
location /status {
vhost_traffic_status_bypass_stats on;
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
}
}
vhost_traffic_status_stats_by_upstream
| - | - |
|---|---|
| Синтаксис | vhost_traffic_status_stats_by_upstream \<on|off> |
| По умолчанию | on |
| Контекст | http |
Описание: Включает или отключает статистику upstreamZone. upstreamZone в функциях статистики трафика обходится, если эта опция отключена. Другими словами, это исключено из статистики трафика. Это в основном полезно, если вы хотите отключить сбор статистики для upstream серверов, чтобы снизить нагрузку на процессор.
http {
vhost_traffic_status_zone;
vhost_traffic_status_stats_by_upstream off;
proxy_cache_path /var/cache/nginx keys_zone=zone1:1m max_size=1g inactive=24h;
upstream backend {
...
}
...
server {
...
location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;
}
location /backend {
proxy_cache zone1;
proxy_pass http://backend;
}
}
}
Выпуски
Чтобы подготовить выпуск, создайте PR для записи в журнал изменений с помощью git-chglog
version="v0.2.0"
git checkout -b "cut-${version}"
git-chglog -o CHANGELOG.md --next-tag "${version}"
git add CHANGELOG.md
sed -i "s/NGX_HTTP_VTS_MODULE_VERSION \".*/NGX_HTTP_VTS_MODULE_VERSION \"${version}\"/" src/ngx_http_vhost_traffic_status_module.h
git add src/ngx_http_vhost_traffic_status_module.h
git-chglog -t .chglog/RELNOTES.tmpl --next-tag "${version}" "${version}" | git commit -F-
После слияния PR создайте новый тег и выпуск на GitHub Releases.
См. также
- Статус трафика потока
- nginx-module-sts
-
Prometheus
-
Защита системы
- nginx-module-sysguard