【监控】grafana+loki做nginx_log服务
0、环境
centos7
grafana8.0
loki2.2.1
curl -O -L "https://github.com/grafana/loki/releases/download/v2.2.1/loki-linux-amd64.zip"
promtail 2.2.1
1、安装grafana
cat >> /etc/yum.repos.d/grafana.repo << EOF
[grafana]
name=grafana
baseurl=https://packages.grafana.com/enterprise/rpm
repo_gpgcheck=1
enabled=1
gpgcheck=1
gpgkey=https://packages.grafana.com/gpg.key
sslverify=1
sslcacert=/etc/pki/tls/certs/ca-bundle.crtwe
[grafana]
name=grafana
baseurl=https://packages.grafana.com/oss/rpm
repo_gpgcheck=1
enabled=1
gpgcheck=1
gpgkey=https://packages.grafana.com/gpg.key
sslverify=1
sslcacert=/etc/pki/tls/certs/ca-bundle.crt
EOF
yum install grafana
grafana-cli plugins install grafana-worldmap-panel
systemctl restart grafana
import 模板 12559
2、安装loki2.0.2
unzip loki-linux-amd64.zip
mkdir -p /usr/local/loki/{chunks,index}
vim loki.yml
auth_enabled: false
server:
http_listen_port: 3100
ingester:
lifecycler:
address: 192.168.34.3
ring:
kvstore:
store: inmemory
replication_factor: 1
final_sleep: 0s
chunk_idle_period: 5m
chunk_retain_period: 30s
schema_config:
configs:
- from: 2020-07-21
store: boltdb
object_store: filesystem
schema: v11
index:
prefix: index_
period: 168h
#每张表的时间范围6天
storage_config:
boltdb:
directory: /data/loki/index
#索引文件存储地址
filesystem:
directory: /data/loki/chunks
#块存储地址
limits_config:
enforce_metric_name: false
reject_old_samples: true
reject_old_samples_max_age: 168h
chunk_store_config:
# 最大可查询历史日期 90天
max_look_back_period: 2160h
# 表的保留期90天
table_manager:
retention_deletes_enabled: true
retention_period: 672h
./loki-linux-amd64 -config.file=/usr/local/loki/loki.yml
3、安装配置promtail
unzip promtail-linux-amd64.zip
mkdir -p /usr/local/promtail
cat > /usr/local/promtail/promtail.yaml << EOF
server:
http_listen_port: 0
grpc_listen_port: 0
positions:
filename: /tmp/positions.yaml
clients:
- url: http://45.117.160.27:3100/loki/api/v1/push
scrape_configs:
- job_name: nginx
static_configs:
- targets:
- 103.153.254.31
labels:
job: nginx_access_log
host: proxy-4-vn
agent: promtail
__path__: /www/wwwlogs/*.json.log
EOF
nohup ./promtail-linux-amd64 -config.file=/usr/local/promtail/promtail.yaml &
4、安装配置nginx
cat > /etc/yum.repos.d/nginx.repo << EOF
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
EOF
yum search nginx-module
yum install nginx-module-* rh-nginx
vim /etc/nginx/nginx.conf
# 添加
geoip_country /usr/local/GeoIP/GeoIP.dat;
geoip_city /usr/local/GeoIP/GeoCity.dat
# http {} 中
log_format json_analytics escape=json '{'
'"msec": "$msec", ' # request unixtime in seconds with a milliseconds resolution
'"connection": "$connection", ' # connection serial number
'"connection_requests": "$connection_requests", ' # number of requests made in connection
'"pid": "$pid", ' # process pid
'"request_id": "$request_id", ' # the unique request id
'"request_length": "$request_length", ' # request length (including headers and body)
'"remote_addr": "$remote_addr", ' # client IP
'"remote_user": "$remote_user", ' # client HTTP username
'"remote_port": "$remote_port", ' # client port
'"time_local": "$time_local", '
'"time_iso8601": "$time_iso8601", ' # local time in the ISO 8601 standard format
'"request": "$request", ' # full path no arguments if the request
'"request_uri": "$request_uri", ' # full path and arguments if the request
'"args": "$args", ' # args
'"status": "$status", ' # response status code
'"body_bytes_sent": "$body_bytes_sent", ' # the number of body bytes exclude headers sent to a client
'"bytes_sent": "$bytes_sent", ' # the number of bytes sent to a client
'"http_referer": "$http_referer", ' # HTTP referer
'"http_user_agent": "$http_user_agent", ' # user agent
'"http_x_forwarded_for": "$http_x_forwarded_for", ' # http_x_forwarded_for
'"http_host": "$http_host", ' # the request Host: header
'"server_name": "$server_name", ' # the name of the vhost serving the request
'"request_time": "$request_time", ' # request processing time in seconds with msec resolution
'"upstream": "$upstream_addr", ' # upstream backend server for proxied requests
'"upstream_connect_time": "$upstream_connect_time", ' # upstream handshake time incl. TLS
'"upstream_header_time": "$upstream_header_time", ' # time spent receiving upstream headers
'"upstream_response_time": "$upstream_response_time", ' # time spend receiving upstream body
'"upstream_response_length": "$upstream_response_length", ' # upstream response length
'"upstream_cache_status": "$upstream_cache_status", ' # cache HIT/MISS where applicable
'"ssl_protocol": "$ssl_protocol", ' # TLS protocol
'"ssl_cipher": "$ssl_cipher", ' # TLS cipher
'"scheme": "$scheme", ' # http or https
'"request_method": "$request_method", ' # request method
'"server_protocol": "$server_protocol", ' # request protocol, like HTTP/1.1 or HTTP/2.0
'"pipe": "$pipe", ' # "p" if request was pipelined, "." otherwise
'"gzip_ratio": "$gzip_ratio", '
'"http_cf_ray": "$http_cf_ray",'
'"geoip_country_code": "$geoip_country_code"'
'}';
# access log 添加
access_log /www/wwwlogs/web.yostat.xyz.json.log json_analytics;
/usr/local/nginx/sbin/nginx -s reload
5、自定义模板
{ "annotations": { "list": [ { "builtIn": 1, "datasource": "-- Grafana --", "enable": true, "hide": true, "iconColor": "rgba(0, 211, 255, 1)", "name": "Annotations & Alerts", "type": "dashboard" } ] }, "description": "Loki v2+ showcase using JSON NGINX access logs.", "editable": true, "gnetId": 12559, "graphTooltip": 0, "id": 3, "iteration": 1624354604449, "links": [], "panels": [ { "collapsed": false, "datasource": null, "gridPos": { "h": 1, "w": 24, "x": 0, "y": 0 }, "id": 36, "panels": [], "title": "Request statistics over time real", "type": "row" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "palette-classic" }, "custom": { "axisLabel": "", "axisPlacement": "auto", "barAlignment": 0, "drawStyle": "line", "fillOpacity": 100, "gradientMode": "hue", "hideFrom": { "legend": false, "tooltip": false, "viz": false }, "lineInterpolation": "smooth", "lineWidth": 1, "pointSize": 5, "scaleDistribution": { "log": 2, "type": "log" }, "showPoints": "never", "spanNulls": false, "stacking": { "group": "A", "mode": "none" }, "thresholdsStyle": { "mode": "area" } }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "#EAB839", "value": 0.2 }, { "color": "red", "value": 0.3 } ] }, "unit": "s" }, "overrides": [ { "matcher": { "id": "byName", "options": "95th percentile" }, "properties": [ { "id": "color", "value": { "fixedColor": "blue", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "max latency" }, "properties": [ { "id": "color", "value": { "fixedColor": "super-light-blue", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "max latency" }, "properties": [ { "id": "custom.fillOpacity", "value": 30 } ] } ] }, "gridPos": { "h": 9, "w": 8, "x": 0, "y": 1 }, "id": 16, "interval": null, "maxDataPoints": 50, "options": { "legend": { "calcs": [], "displayMode": "list", "placement": "bottom" }, "tooltip": { "mode": "single" } }, "pluginVersion": "8.0.0-beta3", "targets": [ { "expr": "quantile_over_time(0.95,{$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | unwrap request_time | __error__=\"\" [$__interval]) by (host)", "legendFormat": "95th percentile", "refId": "C" }, { "expr": "max by (host) (max_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | unwrap request_time | __error__=\"\" [$__interval]))", "legendFormat": "max latency", "refId": "D" } ], "timeFrom": null, "timeShift": null, "title": "95th percentile of Request Time", "type": "timeseries" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "palette-classic" }, "custom": { "axisLabel": "", "axisPlacement": "auto", "barAlignment": 0, "drawStyle": "line", "fillOpacity": 39, "gradientMode": "hue", "hideFrom": { "legend": false, "tooltip": false, "viz": false }, "lineInterpolation": "smooth", "lineWidth": 1, "pointSize": 5, "scaleDistribution": { "log": 2, "type": "log" }, "showPoints": "never", "spanNulls": true, "stacking": { "group": "A", "mode": "none" }, "thresholdsStyle": { "mode": "off" } }, "decimals": 0, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] }, "unit": "short" }, "overrides": [ { "matcher": { "id": "byName", "options": "HTTP Status 500" }, "properties": [ { "id": "color", "value": { "fixedColor": "dark-orange", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "{statuscode=\"200\"} 200" }, "properties": [ { "id": "color", "value": { "fixedColor": "green", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "{statuscode=\"404\"} 404" }, "properties": [ { "id": "color", "value": { "fixedColor": "semi-dark-purple", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "{statuscode=\"500\"} 500" }, "properties": [ { "id": "color", "value": { "fixedColor": "dark-red", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "HTTP Status 404" }, "properties": [ { "id": "color", "value": { "fixedColor": "light-orange", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "HTTP Status 301" }, "properties": [ { "id": "color", "value": { "fixedColor": "light-blue", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "HTTP Status 200" }, "properties": [ { "id": "color", "value": { "fixedColor": "semi-dark-blue", "mode": "fixed" } } ] } ] }, "gridPos": { "h": 9, "w": 8, "x": 8, "y": 1 }, "id": 2, "interval": null, "maxDataPoints": 50, "options": { "legend": { "calcs": [], "displayMode": "list", "placement": "bottom" }, "tooltip": { "mode": "single" } }, "pluginVersion": "8.0.0-beta3", "targets": [ { "expr": "sum by (status) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\" [$__interval]))", "legendFormat": "HTTP Status {{status}}", "refId": "A" } ], "timeFrom": null, "timeShift": null, "title": "HTTP status codes over time", "transformations": [ { "id": "filterFieldsByName", "options": { "include": { "names": [ "Time", "HTTP Status 200", "HTTP Status 301", "HTTP Status 304", "HTTP Status 404", "HTTP Status 406", "HTTP Status 500" ] } } } ], "type": "timeseries" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "palette-classic" }, "custom": { "axisLabel": "", "axisPlacement": "auto", "barAlignment": 0, "drawStyle": "line", "fillOpacity": 100, "gradientMode": "hue", "hideFrom": { "legend": false, "tooltip": false, "viz": false }, "lineInterpolation": "smooth", "lineWidth": 1, "pointSize": 5, "scaleDistribution": { "type": "linear" }, "showPoints": "never", "spanNulls": false, "stacking": { "group": "A", "mode": "none" }, "thresholdsStyle": { "mode": "off" } }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] }, "unit": "decbytes" }, "overrides": [ { "matcher": { "id": "byName", "options": "Bytes sent" }, "properties": [ { "id": "color", "value": { "fixedColor": "light-blue", "mode": "fixed" } } ] }, { "matcher": { "id": "byName", "options": "appfelstrudel" }, "properties": [ { "id": "color", "value": { "fixedColor": "yellow", "mode": "fixed" } } ] } ] }, "gridPos": { "h": 9, "w": 8, "x": 16, "y": 1 }, "id": 9, "interval": null, "maxDataPoints": 50, "options": { "legend": { "calcs": [], "displayMode": "list", "placement": "bottom" }, "tooltip": { "mode": "single" } }, "pluginVersion": "8.0.0-beta3", "targets": [ { "expr": "sum by (host) (sum_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | status=200 | unwrap body_bytes_sent | __error__=\"\" [$__interval]))", "legendFormat": "Bytes sent", "refId": "A" } ], "timeFrom": null, "timeShift": null, "title": "Bytes Sent", "transformations": [], "type": "timeseries" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": null, "displayMode": "auto", "filterable": false }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlPu" } } ] }, { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.width", "value": 300 } ] } ] }, "gridPos": { "h": 6, "w": 9, "x": 0, "y": 10 }, "id": 6, "interval": null, "maxDataPoints": 1, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Requests" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (http_referer) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | http_referer != \"\" and http_referer !~ \".*?$host.*?\" and http_referer !~ \".*?\\\\*\\\\*\\\\*.*?\" | __error__=\"\" [15m])))", "instant": true, "legendFormat": "{{http_referer}}", "range": false, "refId": "A" } ], "timeFrom": "15m", "timeShift": null, "title": "Top 10 HTTP Referers", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Time": true }, "indexByName": {}, "renameByName": { "Field": "Referer", "Total": "Requests", "Value #A": "Requests", "http_referer": "HTTP Referrer" } } } ], "type": "table" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": null, "displayMode": "auto", "filterable": false }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.width", "value": 300 }, { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlPu" } } ] }, { "matcher": { "id": "byName", "options": "User agent" }, "properties": [ { "id": "custom.width", "value": null } ] } ] }, "gridPos": { "h": 6, "w": 15, "x": 9, "y": 10 }, "id": 7, "interval": null, "maxDataPoints": 1, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Requests" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (http_user_agent) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\" [15m])))", "instant": true, "legendFormat": "{{http_user_agent}}", "range": false, "refId": "A" } ], "timeFrom": "15m", "timeShift": null, "title": "Top 10 User Agents", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Field": false, "Time": true }, "indexByName": {}, "renameByName": { "Field": "Agent", "Total": "Requests", "Value #A": "Requests", "http_user_agent": "User agent" } } } ], "type": "table" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": null, "displayMode": "auto", "filterable": false }, "mappings": [ { "options": { "NL": { "index": 1, "text": "🇳🇱" }, "US": { "index": 0, "text": "🇺🇸" } }, "type": "value" } ], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.width", "value": 300 }, { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlPu" } } ] }, { "matcher": { "id": "byName", "options": "Country" }, "properties": [ { "id": "custom.width", "value": 74 } ] } ] }, "gridPos": { "h": 8, "w": 9, "x": 0, "y": 16 }, "id": 3, "interval": null, "maxDataPoints": 1, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Requests" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (remote_addr, geoip_country_code) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\" [15m])))", "instant": true, "legendFormat": "{{remote_addr}}", "range": false, "refId": "A" } ], "timeFrom": "15m", "timeShift": null, "title": "Top 10 visitor IPs", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Field": false, "Time": true }, "indexByName": { "Time": 0, "Value #A": 3, "geoip_country_code": 2, "remote_addr": 1 }, "renameByName": { "Field": "IP Address", "Total": "Requests", "Value #A": "Requests", "geoip_country_code": "Country", "remote_addr": "IP Address " } } } ], "type": "table" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": null, "displayMode": "auto", "filterable": false }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.width", "value": 300 }, { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlPu" } } ] } ] }, "gridPos": { "h": 8, "w": 15, "x": 9, "y": 16 }, "id": 12, "interval": null, "maxDataPoints": 1, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Requests" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (request_uri) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} !~ `\\.ico|\\.svg|\\.css|\\.png|\\.txt|\\.js|\\.xml` | json | status = 200 and request_uri != \"/\" | __error__=\"\" [15m])))", "instant": true, "legendFormat": "{{request_uri}}", "range": false, "refId": "A" } ], "timeFrom": "15m", "timeShift": null, "title": "Top 10 Requested Pages", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Time": true }, "indexByName": {}, "renameByName": { "Field": "Page", "Time": "", "Total": "", "Value #A": "Requests", "request_uri": "Path" } } } ], "type": "table" }, { "datasource": null, "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": "auto", "displayMode": "auto" }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Rquests Time(s)" }, "properties": [ { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlPu" } }, { "id": "custom.width", "value": 302 } ] }, { "matcher": { "id": "byName", "options": "Rquests Time(s)" }, "properties": [ { "id": "custom.width", "value": 300 } ] } ] }, "gridPos": { "h": 7, "w": 9, "x": 0, "y": 24 }, "id": 38, "libraryPanel": { "description": "", "meta": { "connectedDashboards": 1, "created": "2021-06-22T14:25:09+07:00", "createdBy": { "avatarUrl": "/avatar/46d229b033af06a191ff2267bca9ae56", "id": 1, "name": "admin" }, "folderName": "General", "folderUid": "", "updated": "2021-06-22T14:40:01+07:00", "updatedBy": { "avatarUrl": "/avatar/46d229b033af06a191ff2267bca9ae56", "id": 1, "name": "admin" } }, "name": "Top10 Request Slow Time", "type": "table", "uid": "1a96zrRnz", "version": 3 }, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Rquests Time(s)" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (http_referer) (max_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | unwrap request_time | http_referer != \"\" and http_referer !~ \".*?$host.*?\" and http_referer !~ \".*?\\\\*\\\\*\\\\*.*?\" | __error__=\"\" [15m])))", "instant": true, "legendFormat": "{{ http_referer }}", "range": false, "refId": "A" } ], "title": "Top10 Request Slow Time", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Time": true }, "indexByName": {}, "renameByName": { "Value #A": "Rquests Time(s)", "http_referer": "HTTP Referrer" } } } ], "type": "table" }, { "datasource": null, "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": "auto", "displayMode": "auto" }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "green", "value": null }, { "color": "red", "value": 80 } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Request Time(s)" }, "properties": [ { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-BlYlRd" } } ] }, { "matcher": { "id": "byName", "options": "Request Time(s)" }, "properties": [ { "id": "custom.width", "value": 300 } ] } ] }, "gridPos": { "h": 7, "w": 15, "x": 9, "y": 24 }, "id": 40, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Request Time(s)" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum by (request) (max_over_time({filename=~\"/www/wwwlogs/api\\\\.yostat\\\\.xyz\\\\.json\\\\.log\", job=~\"nginx_access_log\", instance=~\"\"} | json | unwrap request_time | request != \"\" and request !~ \".*version.*\" | __error__=\"\" [15m]))", "instant": true, "legendFormat": "{{ request }}", "range": false, "refId": "A" } ], "title": "Requests Slow Go Http", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Time": true }, "indexByName": {}, "renameByName": { "Value #A": "Request Time(s)", "request": "Request" } } } ], "type": "table" }, { "collapsed": false, "datasource": "$datasource", "gridPos": { "h": 1, "w": 24, "x": 0, "y": 31 }, "id": 24, "panels": [], "title": "KPI's", "type": "row" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "purple", "value": null } ] }, "unit": "short" }, "overrides": [] }, "gridPos": { "h": 4, "w": 5, "x": 0, "y": 32 }, "hideTimeOverride": false, "id": 4, "interval": null, "maxDataPoints": 300, "options": { "colorMode": "background", "graphMode": "area", "justifyMode": "center", "orientation": "auto", "reduceOptions": { "calcs": [ "sum" ], "fields": "", "values": false }, "text": {}, "textMode": "value" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum by(host) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"}[$__interval])) ", "legendFormat": "", "refId": "A" } ], "timeFrom": "24h", "timeShift": null, "title": "Total requests ", "transformations": [], "type": "stat" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "mappings": [], "thresholds": { "mode": "percentage", "steps": [ { "color": "rgba(110, 157, 228, 0.76)", "value": null }, { "color": "rgba(73, 124, 202, 1)", "value": 20 } ] }, "unit": "short" }, "overrides": [] }, "gridPos": { "h": 8, "w": 13, "x": 5, "y": 32 }, "id": 5, "interval": null, "maxDataPoints": 20, "options": { "colorMode": "background", "graphMode": "area", "justifyMode": "auto", "orientation": "auto", "reduceOptions": { "calcs": [ "sum" ], "fields": "", "values": false }, "text": {}, "textMode": "auto" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum by (status) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\" [$__interval]))", "instant": false, "legendFormat": "HTTP Status: {{status}}", "range": true, "refId": "A" } ], "timeFrom": null, "timeShift": null, "title": "Requests per status code", "transformations": [], "type": "stat" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "purple", "value": null } ] }, "unit": "decbytes" }, "overrides": [] }, "gridPos": { "h": 4, "w": 3, "x": 18, "y": 32 }, "id": 8, "interval": null, "maxDataPoints": 1, "options": { "colorMode": "background", "graphMode": "none", "justifyMode": "center", "orientation": "auto", "reduceOptions": { "calcs": [ "sum" ], "fields": "", "values": false }, "text": {}, "textMode": "value" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum by (host) (sum_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | unwrap body_bytes_sent | __error__=\"\" [$__interval]))", "instant": true, "legendFormat": "Bytes sent", "range": false, "refId": "A" } ], "timeFrom": null, "timeShift": null, "title": "Total Bytes Sent", "transformations": [], "type": "stat" }, { "cacheTimeout": null, "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "mappings": [], "max": 100, "min": 0, "thresholds": { "mode": "absolute", "steps": [ { "color": "purple", "value": null } ] }, "unit": "percent" }, "overrides": [] }, "gridPos": { "h": 4, "w": 2, "x": 21, "y": 32 }, "hideTimeOverride": true, "id": 18, "interval": "10m", "links": [], "maxDataPoints": 1, "options": { "colorMode": "background", "graphMode": "none", "justifyMode": "auto", "orientation": "auto", "reduceOptions": { "calcs": [ "last" ], "fields": "", "values": false }, "text": {}, "textMode": "value" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum(count_over_time(({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} |= \"Googlebot\")[$__interval])) / (sum(count_over_time(({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} != \"Googlebot\")[$__interval])) / 100)", "instant": true, "legendFormat": "", "range": false, "refId": "A" } ], "timeFrom": "1h", "timeShift": null, "title": "% of requests by Googlebot", "type": "stat" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "mappings": [], "thresholds": { "mode": "absolute", "steps": [ { "color": "purple", "value": null } ] } }, "overrides": [] }, "gridPos": { "h": 4, "w": 5, "x": 0, "y": 36 }, "id": 22, "interval": "5m", "options": { "colorMode": "background", "graphMode": "none", "justifyMode": "auto", "orientation": "auto", "reduceOptions": { "calcs": [ "mean" ], "fields": "", "values": false }, "text": {}, "textMode": "value" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "count(sum by (remote_addr) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\" [$__interval])))", "instant": true, "legendFormat": "", "range": false, "refId": "A" } ], "timeFrom": "5m", "timeShift": null, "title": "Realtime visitors ", "transformations": [], "type": "stat" }, { "cacheTimeout": null, "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "decimals": 1, "mappings": [], "max": 100, "min": 0, "thresholds": { "mode": "absolute", "steps": [ { "color": "purple", "value": null }, { "color": "red", "value": 80 } ] }, "unit": "percent" }, "overrides": [] }, "gridPos": { "h": 4, "w": 5, "x": 18, "y": 36 }, "hideTimeOverride": true, "id": 19, "interval": null, "links": [], "maxDataPoints": 1, "options": { "colorMode": "background", "graphMode": "none", "justifyMode": "center", "orientation": "auto", "reduceOptions": { "calcs": [ "max" ], "fields": "", "values": false }, "text": {}, "textMode": "value" }, "pluginVersion": "8.0.3", "targets": [ { "expr": "sum(count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | status >= 500 |__error__=\"\"[$__interval])) / (sum(count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | __error__=\"\"[$__interval]))/ 100)", "instant": false, "legendFormat": "", "range": true, "refId": "A" } ], "timeFrom": "1h", "timeShift": null, "title": "% of 5xx requests ", "type": "stat" }, { "circleMaxSize": "50", "circleMinSize": "15", "colors": [ "#96D98D", "#73BF69", "#56A64B" ], "datasource": "$datasource", "decimals": null, "description": "", "esMetric": "Count", "gridPos": { "h": 13, "w": 19, "x": 0, "y": 40 }, "hideEmpty": false, "hideZero": false, "id": 14, "initialZoom": "2", "interval": null, "locationData": "countries", "mapCenter": "(0°, 0°)", "mapCenterLatitude": 0, "mapCenterLongitude": 0, "maxDataPoints": 1, "mouseWheelZoom": false, "pluginVersion": "7.4.0", "showLegend": true, "stickyLabels": true, "tableQueryOptions": { "geohashField": "geohash", "latitudeField": "latitude", "longitudeField": "longitude", "metricField": "metric", "queryType": "geohash" }, "targets": [ { "expr": "sum by (geoip_country_code) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | geoip_country_code != \"\" | __error__=\"\" [$__interval]))", "instant": false, "legendFormat": "{{geoip_country_code}}", "range": true, "refId": "A" } ], "thresholds": "5,10", "timeFrom": null, "timeShift": null, "title": "Requests per Country", "transformations": [], "type": "grafana-worldmap-panel", "unitPlural": "", "unitSingle": "", "valueName": "total" }, { "datasource": "$datasource", "description": "", "fieldConfig": { "defaults": { "color": { "mode": "thresholds" }, "custom": { "align": "center", "displayMode": "auto", "filterable": false }, "mappings": [ { "options": { "CN": { "color": "transparent", "index": 4, "text": "🇨🇳CN" }, "DE": { "color": "transparent", "index": 2, "text": "🇩🇪DE" }, "FR": { "color": "transparent", "index": 3, "text": "🇫🇷FR" }, "GB": { "color": "transparent", "index": 7, "text": "🇬🇧GB" }, "IN": { "color": "transparent", "index": 5, "text": "🇮🇳IN" }, "IT": { "color": "transparent", "index": 6, "text": "🇮🇹IT" }, "NL": { "color": "transparent", "index": 1, "text": "🇳🇱NL" }, "US": { "color": "transparent", "index": 0, "text": "🇺🇸 US" } }, "type": "value" } ], "thresholds": { "mode": "percentage", "steps": [ { "color": "transparent", "value": null } ] } }, "overrides": [ { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.displayMode", "value": "gradient-gauge" }, { "id": "color", "value": { "mode": "continuous-GrYlRd" } } ] }, { "matcher": { "id": "byName", "options": "Country" }, "properties": [ { "id": "custom.width", "value": 100 } ] }, { "matcher": { "id": "byName", "options": "Requests" }, "properties": [ { "id": "custom.width", "value": 200 } ] } ] }, "gridPos": { "h": 13, "w": 4, "x": 19, "y": 40 }, "hideTimeOverride": true, "id": 32, "interval": null, "maxDataPoints": 1, "options": { "showHeader": true, "sortBy": [ { "desc": true, "displayName": "Requests" } ] }, "pluginVersion": "8.0.3", "targets": [ { "expr": "topk(10, sum by (geoip_country_code) (count_over_time({$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | geoip_country_code != \"\" and __error__=\"\" [$__interval])))", "instant": true, "legendFormat": "{{remote_addr}}", "maxLines": null, "range": false, "refId": "A" } ], "timeFrom": "15m", "timeShift": null, "title": "Top Countries", "transformations": [ { "id": "organize", "options": { "excludeByName": { "Field": false, "Time": true, "Value #A": false }, "indexByName": { "Time": 0, "Value #A": 3, "geoip_country_code": 2, "remote_addr": 1 }, "renameByName": { "Field": "IP Address", "Total": "Requests", "Value #A": "Requests", "geoip_country_code": "Country", "remote_addr": "IP Address " } } } ], "type": "table" }, { "datasource": "$datasource", "description": "", "gridPos": { "h": 5, "w": 23, "x": 0, "y": 53 }, "id": 11, "options": { "dedupStrategy": "signature", "enableLogDetails": false, "showLabels": false, "showTime": false, "sortOrder": "Descending", "wrapLogMessage": false }, "targets": [ { "expr": "{$label_name=~\"$label_value\", job=~\"$job\", instance=~\"$instance\"} | json | line_format \"➡️ {{.request_method}} {{.request_uri}} with HTTP status: {{.status}} \"", "legendFormat": "", "refId": "A" } ], "timeFrom": null, "timeShift": null, "title": "Recent requests", "transformations": [], "type": "logs" } ], "refresh": "", "schemaVersion": 30, "style": "dark", "tags": [], "templating": { "list": [ { "current": { "selected": false, "text": "Loki", "value": "Loki" }, "description": null, "error": null, "hide": 0, "includeAll": false, "label": "Datasource", "multi": false, "name": "datasource", "options": [], "query": "loki", "queryValue": "", "refresh": 1, "regex": "", "skipUrlSync": false, "type": "datasource" }, { "allValue": null, "current": { "selected": false, "text": "filename", "value": "filename" }, "datasource": "$datasource", "definition": "label_names()", "description": null, "error": null, "hide": 0, "includeAll": false, "label": "Label Name", "multi": false, "name": "label_name", "options": [], "query": "label_names()", "refresh": 1, "regex": "", "skipUrlSync": false, "sort": 1, "tagValuesQuery": "", "tagsQuery": "", "type": "query", "useTags": false }, { "allValue": null, "current": { "selected": true, "text": [ "All" ], "value": [ "$__all" ] }, "datasource": "$datasource", "definition": "label_values($label_name)", "description": null, "error": null, "hide": 0, "includeAll": true, "label": "Label Value", "multi": true, "name": "label_value", "options": [], "query": "label_values($label_name)", "refresh": 1, "regex": "", "skipUrlSync": false, "sort": 1, "tagValuesQuery": "", "tagsQuery": "", "type": "query", "useTags": false }, { "allValue": null, "current": { "selected": true, "text": [ "All" ], "value": [ "$__all" ] }, "datasource": "$datasource", "definition": "label_values({$label_name=~\"$label_value\"}, job)", "description": null, "error": null, "hide": 0, "includeAll": true, "label": "Job", "multi": true, "name": "job", "options": [], "query": "label_values({$label_name=~\"$label_value\"}, job)", "refresh": 1, "regex": "", "skipUrlSync": false, "sort": 0, "tagValuesQuery": "", "tagsQuery": "", "type": "query", "useTags": false }, { "allValue": null, "current": { "selected": true, "text": [ "All" ], "value": [ "$__all" ] }, "datasource": "$datasource", "definition": "label_values({$label_name=~\"$label_value\"}, instance)", "description": null, "error": null, "hide": 0, "includeAll": true, "label": "Instance", "multi": true, "name": "instance", "options": [], "query": "label_values({$label_name=~\"$label_value\"}, instance)", "refresh": 1, "regex": "", "skipUrlSync": false, "sort": 0, "tagValuesQuery": "", "tagsQuery": "", "type": "query", "useTags": false }, { "datasource": "$datasource", "description": null, "error": null, "filters": [], "hide": 0, "label": null, "name": "Filters", "skipUrlSync": false, "type": "adhoc" } ] }, "time": { "from": "now-6h", "to": "now" }, "timepicker": { "refresh_intervals": [ "10s", "30s", "1m", "5m", "15m", "30m", "1h", "2h", "1d" ] }, "timezone": "Asia/Bangkok", "title": "Grafana Loki Dashboard for NGINX Service Mesh", "uid": "EqSs2wR7z", "version": 22 }