azure-metrics-exporter Docker 镜像下载 - 轩辕镜像
azure-metrics-exporter 镜像详细信息和使用指南
azure-metrics-exporter 镜像标签列表和版本信息
azure-metrics-exporter 镜像拉取命令和加速下载
azure-metrics-exporter 镜像使用说明和配置指南
Docker 镜像加速服务 - 轩辕镜像平台
国内开发者首选的 Docker 镜像加速平台
极速拉取 Docker 镜像服务
相关 Docker 镜像推荐
热门 Docker 镜像下载
azure-metrics-exporter 镜像详细信息
azure-metrics-exporter 镜像标签列表
azure-metrics-exporter 镜像使用说明
azure-metrics-exporter 镜像拉取命令
Docker 镜像加速服务
轩辕镜像平台优势
镜像下载指南
相关 Docker 镜像推荐
azure-metrics-exporter 镜像详细说明
azure-metrics-exporter 使用指南
azure-metrics-exporter 配置说明
azure-metrics-exporter 官方文档
Azure Insights metrics exporter 中文技术文档
1. 镜像概述
Azure Insights metrics exporter 是一款 Prometheus 导出器,用于按需抓取 Azure Insights 指标。支持通过单次抓取从所有资源获取指标(自动服务发现),并支持指标维度,配置完全通过 Prometheus 完成,无需单独的配置文件。
2. 核心功能与特性
- 自动服务发现:支持从 Azure 订阅中自动发现资源并抓取指标
- 维度支持:支持 Azure 指标的维度标签,可通过参数筛选和聚合
- 灵活的探测端点:提供多种 HTTP 端点,支持单资源、资源列表、基于标签的资源配置及 LogAnalytics 查询
- 缓存机制:支持内部缓存,提升指标抓取效率
- 并发控制:可配置订阅和资源级别的并发请求数,优化抓取性能
- Prometheus 原生集成:指标格式符合 Prometheus 规范,支持通过 Prometheus 配置自定义抓取参数
3. 使用场景与适用范围
适用场景
- 将 Azure 云资源指标(如 Redis、虚拟网络网关、虚拟机等)集成到 Prometheus 监控体系
- 按需抓取 Azure LogAnalytics 查询结果并转换为 Prometheus 指标
- 对 Azure 资源指标进行多维度分析和告警
适用范围
- 支持所有提供 Azure Insights 指标的 Azure 资源类型(如
Microsoft.Cache/Redis、Microsoft.Network/virtualNetworkGateways等) - 支持 Azure 公有云及其他 Azure 环境(通过环境变量配置)
4. 配置说明
4.1 命令行参数与环境变量
| 参数名称 | 命令行选项 | 默认值 | 环境变量 | 描述 |
|---|---|---|---|---|
| 调试模式 | --debug | 禁用 | DEBUG | 启用调试模式 |
| 详细模式 | -v, --verbose | 禁用 | VERBOSE | 启用详细日志输出 |
| JSON 日志格式 | --log.json | 禁用 | LOG_JSON | 将日志输出切换为 JSON 格式 |
| Azure 环境名称 | --azure-environment | AZUREPUBLICCLOUD | AZURE_ENVIRONMENT | Azure 环境名称(如 Azure 中国云为 AZURECHINACLOUD) |
| 订阅并发数 | --concurrency.subscription | 5 | CONCURRENCY_SUBSCRIPTION | 并发订阅抓取数 |
| 资源并发数 | --concurrency.subscription.resource | 10 | CONCURRENCY_SUBSCRIPTION_RESOURCE | 每个订阅内的并发资源请求数 |
| 启用缓存 | --enable-caching | 禁用 | ENABLE_CACHING | 启用内部指标缓存 |
| 服务绑定地址 | --bind | :8080 | SERVER_BIND | 导出器服务绑定地址(格式:IP:端口) |
4.2 Azure API 认证
通过环境变量配置 Azure API 认证,支持 Azure SDK for Go 提供的所有认证方式,详情参考 Azure SDK for Go 认证文档。常用认证环境变量:
AZURE_CLIENT_ID:服务主体客户端 IDAZURE_CLIENT_SECRET:服务主体客户端密钥AZURE_TENANT_ID:Azure 租户 IDAZURE_SUBSCRIPTION_ID:目标 Azure 订阅 ID
5. 指标说明
| 指标名称 | 描述 |
|---|---|
azurerm_stats_metric_collecttime | 导出器通用统计信息(如抓取耗时) |
azurerm_stats_metric_requests | 资源指标请求计数器(包含结果标签:error/success) |
azurerm_resource_metric | 探测端点导出的资源指标(可通过 name 参数自定义指标名称) |
azurerm_loganalytics_query_result | LogAnalytics 查询结果导出的指标(按行计数) |
6. HTTP 端点
| 端点路径 | 描述 |
|---|---|
/metrics | 默认 Prometheus Go 运行时指标(如内存、CPU 使用率) |
/probe/metrics/resource | 单资源指标探测端点(对应 azurerm_resource_metric) |
/probe/metrics/list | 资源列表指标探测端点(对应 azurerm_resource_metric) |
/probe/metrics/scrape | 基于资源标签配置的指标探测端点(对应 azurerm_resource_metric) |
/probe/loganalytics/query | LogAnalytics 查询结果探测端点(对应 azurerm_loganalytics_query_result) |
6.1 /probe/metrics/resource 参数
| GET 参数 | 默认值 | 是否必填 | 支持多值 | 描述 |
|---|---|---|---|---|
subscription | - | 是 | 是 | Azure 订阅 ID |
target | - | 是 | 是 | Azure 资源 URI(如 /subscriptions/{sub}/resourceGroups/{rg}/providers/Microsoft.Cache/Redis/{name}) |
timespan | PT1M | 否 | 否 | 指标时间范围(如 PT5M 表示过去 5 分钟) |
interval | - | 否 | 否 | 指标采样间隔 |
metric | - | 否 | 是 | 指标名称(可指定多个,用逗号分隔或重复参数) |
aggregation | - | 否 | 是 | 指标聚合方式(支持 minimum/maximum/average/total/count,可指定多个) |
name | azurerm_resource_metric | 否 | 否 | Prometheus 指标名称 |
metricFilter | - | 否 | 否 | 指标维度筛选器(如 ConnectionName eq 'my-connection') |
metricTop | - | 否 | 否 | 维度结果数量限制(整数) |
metricOrderBy | - | 否 | 否 | 维度结果排序字段(如 avg(value) desc) |
cache | 与 timespan 相同 | 否 | 否 | 缓存有效期 |
6.2 /probe/metrics/list 参数
| GET 参数 | 默认值 | 是否必填 | 支持多值 | 描述 |
|---|---|---|---|---|
subscription | - | 是 | 是 | Azure 订阅 ID(可指定多个,用逗号分隔或重复参数) |
filter | - | 是 | 否 | Azure 资源筛选器(遵循 Azure 资源列表 API 筛选语法) |
timespan | PT1M | 否 | 否 | 指标时间范围 |
interval | - | 否 | 否 | 指标采样间隔 |
metric | - | 否 | 是 | 指标名称(可指定多个) |
aggregation | - | 否 | 是 | 指标聚合方式(支持多个) |
name | azurerm_resource_metric | 否 | 否 | Prometheus 指标名称 |
metricFilter | - | 否 | 否 | 指标维度筛选器 |
metricTop | - | 否 | 否 | 维度结果数量限制 |
metricOrderBy | - | 否 | 否 | 维度结果排序字段 |
cache | 与 timespan 相同 | 否 | 否 | 缓存有效期 |
6.3 /probe/metrics/scrape 参数
| GET 参数 | 默认值 | 是否必填 | 支持多值 | 描述 |
|---|---|---|---|---|
subscription | - | 是 | 是 | Azure 订阅 ID(可指定多个) |
filter | - | 是 | 否 | Azure 资源筛选器(遵循 Azure 资源列表 API 语法) |
metricTagName | - | 是 | 否 | 资源标签名称,用于从标签值获取指标列表 |
aggregationTagName | - | 是 | 否 | 资源标签名称,用于从标签值获取聚合方式列表 |
timespan | PT1M | 否 | 否 | 指标时间范围 |
interval | - | 否 | 否 | 指标采样间隔 |
metric | - | 否 | 是 | 指标名称(可指定多个) |
aggregation | - | 否 | 是 | 指标聚合方式(支持多个) |
name | azurerm_resource_metric | 否 | 否 | Prometheus 指标名称 |
metricFilter | - | 否 | 否 | 指标维度筛选器 |
metricTop | - | 否 | 否 | 维度结果数量限制(整数) |
metricOrderBy | - | 否 | 否 | 维度结果排序字段 |
cache | 与 timespan 相同 | 否 | 否 | 缓存有效期 |
6.4 /probe/loganalytics/query 参数
| GET 参数 | 默认值 | 是否必填 | 描述 |
|---|---|---|---|
workspace | - | 是 | Azure LogAnalytics 工作区 ID |
query | - | 是 | LogAnalytics 查询语句(如 `AzureMetrics |
timespan | - | 是 | 查询时间范围(如 PT1H 表示过去 1 小时) |
7. Docker 部署方案
7.1 docker run 命令示例
bashdocker run -d \ --name azure-metrics-exporter \ -p 8080:8080 \ -e AZURE_CLIENT_ID="your-client-id" \ -e AZURE_CLIENT_SECRET="your-client-secret" \ -e AZURE_TENANT_ID="your-tenant-id" \ -e SERVER_BIND=":8080" \ -e CONCURRENCY_SUBSCRIPTION="5" \ -e ENABLE_CACHING="true" \ webdevops/azure-metrics-exporter
7.2 Docker Compose 配置示例
yamlversion: '3' services: azure-metrics-exporter: image: webdevops/azure-metrics-exporter container_name: azure-metrics-exporter ports: - "8080:8080" environment: - AZURE_CLIENT_ID=your-client-id - AZURE_CLIENT_SECRET=your-client-secret - AZURE_TENANT_ID=your-tenant-id - AZURE_ENVIRONMENT=AZUREPUBLICCLOUD # 如使用中国云,改为 AZURECHINACLOUD - SERVER_BIND=:8080 - CONCURRENCY_SUBSCRIPTION=5 - CONCURRENCY_SUBSCRIPTION_RESOURCE=10 - ENABLE_CACHING=true - LOG_JSON=false # 如需 JSON 日志,设为 true restart: unless-stopped
8. Prometheus 配置示例
8.1 Azure Redis 指标
yaml- job_name: azure-metrics-redis scrape_interval: 1m metrics_path: /probe/metrics/list params: name: ["my_redis_metric"] # 自定义指标名称 subscription: - xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx # 替换为实际订阅 ID filter: ["resourceType eq 'Microsoft.Cache/Redis'"] # 筛选 Redis 资源 metric: - connectedclients # 连接客户端数 - totalcommandsprocessed # 总命令处理数 - cachehits # 缓存命中数 - cachemisses # 缓存未命中数 - usedmemory # 内存使用量 - usedmemorypercentage # 内存使用率 interval: ["PT1M"] # 采样间隔:1 分钟 timespan: ["PT1M"] # 时间范围:过去 1 分钟 aggregation: - average # 平均值 - total # 总和 static_configs: - targets: ["azure-metrics-exporter:8080"] # 导出器服务地址
8.2 虚拟网络网关指标
yaml- job_name: azure-metrics-virtualNetworkGateways scrape_interval: 1m metrics_path: /probe/metrics/list params: name: ["my_vng_metric"] # 自定义指标名称 subscription: - xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx # 替换为实际订阅 ID filter: ["resourceType eq 'Microsoft.Network/virtualNetworkGateways'"] # 筛选虚拟网络网关 metric: - AverageBandwidth # 平均带宽 - P2SBandwidth # P2S 带宽 - P2SConnectionCount # P2S 连接数 - TunnelAverageBandwidth # 隧道平均带宽 - TunnelEgressBytes # 隧道出口字节数 - TunnelIngressBytes # 隧道入口字节数 interval: ["PT5M"] # 采样间隔:5 分钟 timespan: ["PT5M"] # 时间范围:过去 5 分钟 aggregation: - average # 平均值 - total # 总和 static_configs: - targets: ["azure-metrics-exporter:8080"] # 导出器服务地址
8.3 虚拟网络网关连接指标(维度支持)
yaml- job_name: azure-metrics-virtualNetworkGateways-connections scrape_interval:1m metrics_path: /probe/metrics/list params: name: ["my_vng_connection_metric"] # 自定义指标名称 subscription: - xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx # 替换为实际订阅 ID filter: ["resourceType eq 'Microsoft.Network/virtualNetworkGateways'"] # 筛选虚拟网络网关 metric: - TunnelAverageBandwidth # 隧道平均带宽 - TunnelEgressBytes # 隧道出口字节数 - TunnelIngressBytes # 隧道入口字节数 interval: ["PT5M"] # 采样间隔:5 分钟 timespan: ["PT5M"] # 时间范围:过去 5 分钟 aggregation: - average # 平均值 - total # 总和 metricFilter: ["ConnectionName eq '*'"] # 筛选所有连接 metricTop: ["10"] # 最多返回 10 个连接的维度结果 static_configs: - targets: ["azure-metrics-exporter:8080"] # 导出器服务地址
注:所有示例中的订阅 ID、资源筛选器、指标名称等需根据实际 Azure 环境替换。支持的 Azure 指标列表可参考 Azure 指标支持文档。
用户好评
来自真实用户的反馈,见证轩辕镜像的优质服务
常见问题
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
轩辕镜像下载加速使用手册
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
登录仓库拉取
通过 Docker 登录认证访问私有仓库
Linux
在 Linux 系统配置镜像加速服务
Windows/Mac
在 Docker Desktop 配置镜像加速
Docker Compose
Docker Compose 项目配置加速
K8s Containerd
Kubernetes 集群配置 Containerd
宝塔面板
在宝塔面板一键配置镜像加速
群晖
Synology 群晖 NAS 配置加速
飞牛
飞牛 fnOS 系统配置镜像加速
极空间
极空间 NAS 系统配置加速服务
爱快路由
爱快 iKuai 路由系统配置加速
绿联
绿联 NAS 系统配置镜像加速
威联通
QNAP 威联通 NAS 配置加速
Podman
Podman 容器引擎配置加速
Singularity/Apptainer
HPC 科学计算容器配置加速
其他仓库配置
ghcr、Quay、nvcr 等镜像仓库
专属域名拉取
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429