172 похожих чатов

Ребят, пытаюсь сделать конфиг мап для ингресса apiVersion: v1 kind: ConfigMap metadata:

name: nginx-configuration
namespace: test
labels:
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: ingress-nginx
data:
http-snippet: |
lua_shared_dict prometheus_metrics 10M;

init_by_lua_block {
local prometheus = require("prometheus")
prometheus.init("prometheus_metrics")
local metric_requests = prometheus:counter("nginx_http_requests_total", "Number of HTTP requests", {"host", "status"})
local metric_latency = prometheus:histogram("nginx_http_request_duration_seconds", "HTTP request latency", {"host"})
local metric_connections = prometheus:gauge("nginx_http_connections", "Number of HTTP connections", {"state"})
}

log_by_lua_block {
metric_requests:inc(1, {ngx.var.server_name, ngx.var.status})
metric_latency:observe(tonumber(ngx.var.request_time), {ngx.var.server_name})
}
server-snippet: |
location /metrics {
content_by_lua_block {
metric_connections:set(ngx.var.connections_reading, {"reading"})
metric_connections:set(ngx.var.connections_waiting, {"waiting"})
metric_connections:set(ngx.var.connections_writing, {"writing"})
prometheus:collect()
}
}

чтобы получить "vts-подобные" метрики.. (модуль vts выпилен из ингресса в последних версиях).. ругается на блок init_by_lua_block

2019/08/14 14:13:47 [emerg] 87#87: "init_by_lua" directive is duplicate in /tmp/nginx-cfg200575486:259
nginx: [emerg] "init_by_lua" directive is duplicate in /tmp/nginx-cfg200575486:259
nginx: configuration file /tmp/nginx-cfg200575486 test failed

кто-то делал такое? как лечили?

пробовал другие блоки типа access/content - nginx встает без проблем и даже правильно конфигурит конфиг, но метрики отдает не те, что должны быть, да и блоки эти для других целей

1 ответов

10 просмотров
Evgeny-Koshelev Автор вопроса

https://github.com/knyar/nginx-lua-prometheus

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта