
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
PostgreSQL Prometheus Exporter OCI镜像是一个遵循OCI(开放容器倡议)标准的容器化工具,旨在从PostgreSQL数据库实例中采集关键指标(如连接数、查询性能、锁状态、资源使用率等),并将其转换为Prometheus监控系统可识别的格式,通过HTTP端点暴露供Prometheus抓取。该镜像轻量、易配置,可无缝集成到基于Prometheus的监控体系中,适用于各类PostgreSQL部署环境(包括物理机、虚拟机及容器化环境)。
/metrics HTTP端点,返回符合Prometheus文本格式的指标数据,支持Prometheus自动发现和抓取。postgresql://user:password@host:port/dbname)配置,兼容多种认证方式(密码、SSL等)。通过docker run命令快速启动 exporter,核心配置通过环境变量传递:
bashdocker run -d \ --name postgres-exporter \ -p 9187:9187 \ # 默认监听端口9187 -e DATA_SOURCE_NAME="postgresql://user:password@postgres-host:5432/dbname?sslmode=disable" \ # PostgreSQL连接串 -e LISTEN_PORT=9187 \ # 监听端口(可选,默认9187) -e LISTEN_ADDRESS="0.0.0.0" \ # 监听地址(可选,默认0.0.0.0) prometheuscommunity/postgres-exporter:latest
关键环境变量说明
| 环境变量名 | 描述 | 默认值 |
|---|---|---|
DATA_SOURCE_NAME | PostgreSQL连接串,格式:postgresql://user:password@host:port/dbname?option=value | 无(必填) |
LISTEN_ADDRESS | 服务监听地址 | 0.0.0.0 |
LISTEN_PORT | 服务监听端口 | 9187 |
PG_EXPORTER_CONFIG_FILE | 自定义配置文件路径(若使用文件配置,需挂载配置文件至容器内路径) | 无 |
LOG_LEVEL | 日志级别(debug/info/warn/error) | info |
在容器化应用中,可通过docker-compose.yml集成 exporter 与 PostgreSQL:
yamlversion: '3.8' services: postgres: image: docker.xuanyuan.run/postgres:14 environment: POSTGRES_USER: dbuser POSTGRES_PASSWORD: dbpass POSTGRES_DB: appdb ports: - "5432:5432" postgres-exporter: image: docker.xuanyuan.run/prometheuscommunity/postgres-exporter:latest ports: - "9187:9187" environment: DATA_SOURCE_NAME: "postgresql://dbuser:dbpass@postgres:5432/appdb?sslmode=disable" depends_on: - postgres
对于复杂指标采集需求(如自定义指标、过滤特定指标等),可通过配置文件定义采集规则。配置文件为YAML格式,示例:
yaml# postgres_exporter.yml refresh_interval: 5s # 指标采集间隔 metrics: - name: pg_custom_query_seconds help: "Duration of custom query execution" type: gauge query: "SELECT EXTRACT(EPOCH FROM NOW() - query_start) AS duration FROM pg_stat_activity WHERE state = 'active'" columns: - name: duration usage: "value"
启动容器时挂载配置文件:
bashdocker run -d \ --name postgres-exporter \ -p 9187:9187 \ -e DATA_SOURCE_NAME="postgresql://user:password@postgres-host:5432/dbname?sslmode=disable" \ -e PG_EXPORTER_CONFIG_FILE="/etc/postgres-exporter/postgres_exporter.yml" \ -v ./postgres_exporter.yml:/etc/postgres-exporter/postgres_exporter.yml \ docker.xuanyuan.run/prometheuscommunity/postgres-exporter:latest
启动后,通过访问 http://<exporter-ip>:9187/metrics 验证指标是否正常暴露,响应应包含以 pg_ 为前缀的Prometheus指标(如 pg_stat_database_numbackends、pg_locks_count 等)。
pg_monitor角色),以访问pg_stat_*等系统视图。sslmode=require),避免明文传输凭据。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务