newrelic/k8s-metadata-injectionnewrelic/k8s-metadata-injection 镜像文档newrelic/k8s-metadata-injection 是 New Relic 提供的 Kubernetes 元数据注入工具镜像,用于在 Kubernetes 环境中自动将 Pod、节点、命名空间等基础设施元数据注入到应用容器中,实现 New Relic APM (Application Performance Monitoring) 数据与 Kubernetes 基础设施数据的关联。通过该工具,应用性能指标(如响应时间、错误率)可与对应的 Kubernetes 资源上下文(如 Pod 名称、节点标签)绑定,帮助用户在 New Relic 平台中构建从应用到基础设施的完整监控链路。
newrelic.yml),适用于需要自定义配置格式的场景。该镜像通常在 Kubernetes 集群中通过 Mutating Webhook 或 Sidecar 容器 部署。以下为两种部署方式的基本说明:
作为 Kubernetes Mutating Admission Webhook 运行,自动拦截 Pod 创建请求并注入元数据。需配合 Kubernetes 准入控制机制,通常通过 Helm Chart 或 YAML 清单部署(具体部署步骤见 官方 GitHub 文档)。
作为 Sidecar 与应用容器共部署于同一 Pod,通过共享卷或环境变量注入元数据。示例 Pod 清单片段:
yamlapiVersion: v1 kind: Pod metadata: name: example-app namespace: default spec: containers: - name: app image: your-app-image:latest env: - name: NEW_RELIC_METADATA_POD_NAME valueFrom: fieldRef: fieldPath: metadata.name # 其他应用环境变量... - name: metadata-injector image: newrelic/k8s-metadata-injection:latest # 注入器配置...
如需本地测试镜像功能,可通过以下命令运行容器(实际生产环境建议在 Kubernetes 中部署):
bashdocker run -d \ --name k8s-metadata-injection \ -e LOG_LEVEL=info \ -e KUBERNETES_SERVICE_HOST=your-k8s-api-server \ -e KUBERNETES_SERVICE_PORT=6443 \ newrelic/k8s-metadata-injection:latest
镜像支持通过 环境变量 或 命令行参数 配置,以下为核心配置项:
| 参数名 | 类型 | 描述 | 默认值 |
|---|---|---|---|
LOG_LEVEL | 字符串 | 日志级别(debug/info/warn/error) | info |
INJECTION_MODE | 字符串 | 元数据注入方式(env=环境变量注入,config=配置文件注入) | env |
KUBERNETES_SERVICE_HOST | 字符串 | Kubernetes API Server 地址(容器内运行时自动获取,外部测试需手动指定) | 自动获取 |
KUBERNETES_SERVICE_PORT | 整数 | Kubernetes API Server 端口 | 6443 |
NEW_RELIC_LICENSE_KEY | 字符串 | New Relic 许可证密钥(用于与 APM 服务通信,部分场景需配置) | 无 |
部署后,可通过检查应用容器的环境变量或日志确认元数据是否注入成功。例如,在应用容器内执行:
bashenv | grep NEW_RELIC_METADATA_
预期输出包含类似以下元数据:
NEW_RELIC_METADATA_POD_NAME=example-app NEW_RELIC_METADATA_NAMESPACE=default NEW_RELIC_METADATA_NODE_NAME=node-1.example.com


manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务