专属域名
文档搜索
提交工单
轩辕助手
Run助手
返回顶部
快速返回页面顶部
收起
收起工具栏

nginx/nginx-prometheus-exporter Docker 镜像 - 轩辕镜像

nginx-prometheus-exporter
nginx/nginx-prometheus-exporter
NGINX Prometheus Exporter用于收集并导出NGINX与NGINX Plus的监控指标,供Prometheus采集以实现对其运行状态的监控。
50 收藏0 次下载activenginx镜像
🚀专业版镜像服务,面向生产环境设计
版本下载
🚀专业版镜像服务,面向生产环境设计

![CI]([] ![FOSSA Status]([] ![Go Report Card]([] ![codecov]([] !GitHub all releases !GitHub release (latest by SemVer) ![GitHub release (latest SemVer)]([] !GitHub go.mod Go version ![Docker Pulls]([] !Docker Image Size (latest semver) ![Project Status: Active – The project has reached a stable, usable state and is being actively developed.]([***]

NGINX Prometheus Exporter

NGINX Prometheus exporter makes it possible to monitor NGINX or NGINX Plus using Prometheus.

Table of Contents

  • Overview
  • Getting Started
    • A Note about NGINX Ingress Controller
    • Prerequisites
    • Running the Exporter in a Docker Container
    • Running the Exporter Binary
  • Usage
    • Command-line Arguments
  • Exported Metrics
    • Common metrics
    • Metrics for NGINX OSS
      • Stub status metrics
    • Metrics for NGINX Plus
      • Connections
      • HTTP
      • SSL
      • HTTP Server Zones
      • Stream Server Zones
      • HTTP Upstreams
      • Stream Upstreams
      • Stream Zone Sync
      • Location Zones
      • Resolver
      • HTTP Requests Rate Limiting
      • HTTP Connections Limiting
      • Stream Connections Limiting
      • Cache
      • Worker
  • Troubleshooting
  • Releases
    • Docker images
    • Binaries
    • Homebrew
    • Scoop
    • Nix
  • Building the Exporter
    • Building the Docker Image
    • Building the Binary
  • Grafana Dashboard
  • SBOM (Software Bill of Materials)
    • Binaries
    • Docker Image
  • Provenance
  • Contacts
  • Contributing
  • Support
  • License

Overview

NGINX exposes a handful of metrics via the stub_status page. NGINX Plus provides a richer set of metrics via the API and the monitoring dashboard. NGINX Prometheus exporter fetches the metrics from a single NGINX or NGINX Plus, converts the metrics into appropriate Prometheus metrics types and finally exposes them via an HTTP server to be collected by Prometheus.

Getting Started

In this section, we show how to quickly run NGINX Prometheus Exporter for NGINX or NGINX Plus.

A Note about NGINX Ingress Controller

If you’d like to use the NGINX Prometheus Exporter with NGINX Ingress Controller for Kubernetes, see this doc for the installation instructions.

Prerequisites

We assume that you have already installed Prometheus and NGINX or NGINX Plus. Additionally, you need to:

  • Expose the built-in metrics in NGINX/NGINX Plus:
    • For NGINX, expose the stub_status page at /stub_status on port 8080.
    • For NGINX Plus, expose the API at /api on port 8080.
  • Configure Prometheus to scrape metrics from the server with the exporter. Note that the default scrape port of the exporter is 9113 and the default metrics path -- /metrics.
Running the Exporter in a Docker Container

To start the exporter we use the docker run command.

  • To export NGINX metrics, run:

    console
    docker run -p 9113:9113 nginx/nginx-prometheus-exporter:1.5.1 --nginx.scrape-uri=http://<nginx>:8080/stub_status
    

    where <nginx> is the IP address/DNS name, through which NGINX is available.

  • To export NGINX Plus metrics, run:

    console
    docker run -p 9113:9113 nginx/nginx-prometheus-exporter:1.5.1 --nginx.plus --nginx.scrape-uri=http://<nginx-plus>:8080/api
    

    where <nginx-plus> is the IP address/DNS name, through which NGINX Plus is available.

Running the Exporter Binary
  • To export NGINX metrics, run:

    console
    nginx-prometheus-exporter --nginx.scrape-uri=http://<nginx>:8080/stub_status
    

    where <nginx> is the IP address/DNS name, through which NGINX is available.

  • To export NGINX Plus metrics:

    console
    nginx-prometheus-exporter --nginx.plus --nginx.scrape-uri=http://<nginx-plus>:8080/api
    

    where <nginx-plus> is the IP address/DNS name, through which NGINX Plus is available.

  • To scrape NGINX metrics with unix domain sockets, run:

    console
    nginx-prometheus-exporter --nginx.scrape-uri=unix:<nginx>:/stub_status
    

    where <nginx> is the path to unix domain socket, through which NGINX stub status is available.

Note. The nginx-prometheus-exporter is not a daemon. To run the exporter as a system service (daemon), you can follow the example in examples/systemd. Alternatively, you can run the exporter in a Docker container.

Usage

Command-line Arguments
console
usage: nginx-prometheus-exporter [<flags>]


Flags:
  -h, --[no-]help                Show context-sensitive help (also try --help-long and --help-man).
      --[no-]web.systemd-socket  Use systemd socket activation listeners instead
                                 of port listeners (Linux only). ($SYSTEMD_SOCKET)
      --web.listen-address=:9113 ...
                                 Addresses on which to expose metrics and web interface. Repeatable for multiple addresses. ($LISTEN_ADDRESS)
      --web.config.file=""       Path to configuration file that can enable TLS or authentication. See: [***] ($CONFIG_FILE)
      --web.telemetry-path="/metrics"
                                 Path under which to expose metrics. ($TELEMETRY_PATH)
      --[no-]nginx.plus          Start the exporter for NGINX Plus. By default, the exporter is started for NGINX. ($NGINX_PLUS)
      --nginx.scrape-uri=[***] ...
                                 A URI or unix domain socket path for scraping NGINX or NGINX Plus metrics. For NGINX, the stub_status page must be available through the URI. For NGINX Plus -- the API. Repeatable for multiple URIs. ($SCRAPE_URI)
      --[no-]nginx.ssl-verify    Perform SSL certificate verification. ($SSL_VERIFY)
      --nginx.ssl-ca-cert=""     Path to the PEM encoded CA certificate file used to validate the servers SSL certificate. ($SSL_CA_CERT)
      --nginx.ssl-client-cert=""
                                 Path to the PEM encoded client certificate file to use when connecting to the server. ($SSL_CLIENT_CERT)
      --nginx.ssl-client-key=""  Path to the PEM encoded client certificate key file to use when connecting to the server. ($SSL_CLIENT_KEY)
      --[no-]nginx.proxy-protocol
                                 Pass proxy protocol payload to nginx listeners. ($PROXY_PROTOCOL)
      --nginx.timeout=5s         A timeout for scraping metrics from NGINX or NGINX Plus. ($TIMEOUT)
      --prometheus.const-label=PROMETHEUS.CONST-LABEL ...
                                 Label that will be used in every metric. Format is label=value. It can be repeated multiple times. ($CONST_LABELS)
      --log.level=info           Only log messages with the given severity or above. One of: [debug, info, warn, error]
      --log.format=logfmt        Output format of log messages. One of: [logfmt, json]
      --[no-]version             Show application version.

Exported Metrics

Common metrics
NameTypeDescriptionLabels
nginx_exporter_build_infoGaugeShows the exporter build information.branch, goarch, goos, goversion, revision, tags and version
promhttp_metric_handler_requests_totalCounterTotal number of scrapes by HTTP status code.code (the HTTP status code)
promhttp_metric_handler_requests_in_flightGaugeCurrent number of scrapes being served.[]
go_*MultipleGo runtime metrics.[]
Metrics for NGINX OSS
NameTypeDescriptionLabels
nginx_upGaugeShows the status of the last metric scrape: 1 for a successful scrape and 0 for a failed one[]
Stub status metrics
NameTypeDescriptionLabels
nginx_connections_acceptedCounterAccepted client connections.[]
nginx_connections_activeGaugeActive client connections.[]
nginx_connections_handledCounterHandled client connections.[]
nginx_connections_readingGaugeConnections where NGINX is reading the request header.[]
nginx_connections_waitingGaugeIdle client connections.[]
nginx_connections_writingGaugeConnections where NGINX is writing the response back to the client.[]
nginx_http_requests_totalCounterTotal http requests.[]
Metrics for NGINX Plus
NameTypeDescriptionLabels
nginxplus_upGaugeShows the status of the last metric scrape: 1 for a successful scrape and 0 for a failed one[]
Connections
NameTypeDescriptionLabels
nginxplus_connections_acceptedCounterAccepted client connections[]
nginxplus_connections_activeGaugeActive client connections[]
nginxplus_connections_droppedCounterDropped client connections dropped[]
nginxplus_connections_idleGaugeIdle client connections[]
HTTP
NameTypeDescriptionLabels
nginxplus_http_requests_totalCounterTotal http requests[]
nginxplus_http_requests_currentGaugeCurrent http requests[]
SSL
NameTypeDescriptionLabels
nginxplus_ssl_handshakesCounterSuccessful SSL handshakes[]
nginxplus_ssl_handshakes_failedCounterFailed SSL handshakes[]
nginxplus_ssl_session_reusesCounterSession reuses during SSL handshake[]
HTTP Server Zones
NameTypeDescriptionLabels
nginxplus_server_zone_processingGaugeClient requests that are currently being processedserver_zone
nginxplus_server_zone_requestsCounterTotal client requestsserver_zone
nginxplus_server_zone_responsesCounterTotal responses sent to clientscode (the response status code. The values are: 1xx, 2xx, 3xx, 4xx and 5xx), server_zone
nginxplus_server_zone_responses_codesCounterTotal responses sent to clients by codecode (the response status code. The possible values are available on the NGINX Wiki), server_zone
nginxplus_server_zone_discardedCounterRequests completed without sending a responseserver_zone
nginxplus_server_zone_receivedCounterBytes received from clientsserver_zone
nginxplus_server_zone_sentCounterBytes sent to clientsserver_zone
nginxplus_server_ssl_handshakesCounterSuccessful SSL handshakesserver_zone
nginxplus_server_ssl_handshakes_failedCounterFailed SSL handshakesserver_zone
nginxplus_server_ssl_session_reusesCounterSession reuses during SSL handshakeserver_zone
Stream Server Zones
NameTypeDescriptionLabels
nginxplus_stream_server_zone_processingGaugeClient connections that are currently being processedserver_zone
nginxplus_stream_server_zone_connectionsCounterTotal connectionsserver_zone
nginxplus_stream_server_zone_sessionsCounterTotal sessions completedcode (the response status code. The values are: 2xx, 4xx, and 5xx), server_zone
nginxplus_stream_server_zone_discardedCounterConnections completed without creating a sessionserver_zone
nginxplus_stream_server_zone_receivedCounterBytes received from clientsserver_zone
nginxplus_stream_server_zone_sentCounterBytes sent to clientsserver_zone
nginxplus_stream_server_ssl_handshakesCounterSuccessful SSL handshakesserver_zone
nginxplus_stream_server_ssl_handshakes_failedCounterFailed SSL handshakesserver_zone
nginxplus_stream_server_ssl_session_reusesCounterSession reuses during SSL handshakeserver_zone
HTTP Upstreams

Note: for the state metric, the string values are converted to float64 using the following rule: "up" -> 1.0, "draining" -> 2.0, "down" -> 3.0, "unavail" –> 4.0, "checking" –> 5.0, "unhealthy" -> 6.0.

NameTypeDescriptionLabels
nginxplus_upstream_server_stateGaugeCurrent stateserver, upstream
nginxplus_upstream_server_activeGaugeActive connectionsserver, upstream
nginxplus_upstream_server_limitGaugeLimit for connections which corresponds to the max_conns parameter of the upstream server. Zero value means there is no limitserver, upstream
nginxplus_upstream_server_requestsCounterTotal client requestsserver, upstream
nginxplus_upstream_server_responsesCounterTotal responses sent to clientscode (the response status code. The values are: 1xx, 2xx, 3xx, 4xx and 5xx), server, upstream
nginxplus_upstream_server_responses_codesCounterTotal responses sent to clients by codecode (the response status code. The possible values are available on the NGINX Wiki), server, upstream
nginxplus_upstream_server_sentCounterBytes sent to this serverserver, upstream
nginxplus_upstream_server_receivedCounterBytes received to this serverserver, upstream
nginxplus_upstream_server_failsCounterNumber of unsuccessful attempts to communicate with the serverserver, upstream
nginxplus_upstream_server_unavail
查看更多 nginx-prometheus-exporter 相关镜像 →
ubuntu/nginx-prometheus-exporter logo
ubuntu/nginx-prometheus-exporter
by Canonical
认证
用于从NGINX实例导出Prometheus指标的Rock镜像,基于Ubuntu,由Canonical提供,接收安全更新,支持长期维护,可免费使用且无每用户速率限制。
6.8K pulls
上次更新:6 天前
nginx/nginx-ingress logo
nginx/nginx-ingress
by NGINX Inc.
认证
NGINX和NGINX Plus入口控制器是专为Kubernetes设计的流量管理工具,主要用于管理外部HTTP/HTTPS流量进入Kubernetes集群,支持请求路由、负载均衡、SSL终止、流量控制等功能,适用于容器化应用和微服务架构,其中NGINX Plus还提供商业支持、高级监控和增强的负载均衡能力,帮助提升集群流量管理的效率与安全性。
1111B+ pulls
上次更新:4 天前
nginxinc/nginx-unprivileged logo
nginxinc/nginx-unprivileged
by NGINX Inc.
认证
非特权NGINX Docker构建文件是指用于构建以非root用户身份在Docker容器中运行NGINX的配置文件,通过预设用户权限、环境变量及安全参数,确保NGINX在低权限模式下仍能正常处理HTTP请求、反向代理及负载均衡等功能,有效降低因容器漏洞引发的权限提升风险,适用于对安全性要求较高的生产环境部署场景。
1791B+ pulls
上次更新:5 天前
nginx/nginx-ingress-operator logo
nginx/nginx-ingress-operator
by NGINX Inc.
认证
用于NGINX和NGINX Plus入口控制器的NGINX入口操作器,基于Helm图表构建。
31M+ pulls
上次更新:4 天前
nginxinc/nginx-s3-gateway logo
nginxinc/nginx-s3-gateway
by NGINX Inc.
认证
基于NGINX的认证和缓存网关,用于S3 API后端服务。
65M+ pulls
上次更新:5 天前

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

oldzhang的头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
nginx/nginx-prometheus-exporter
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
提交工单
免费获取在线技术支持请 提交工单,官方QQ群:13763429 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
免费获取在线技术支持请提交工单,官方QQ群: 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.
轩辕镜像 官方专业版 Logo
轩辕镜像轩辕镜像官方专业版
首页个人中心搜索镜像
交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 13763429