
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Fluentd Kubernetes Gelf镜像专为Kubernetes环境设计,集成Fluentd日志收集工具与GELF(Graylog Extended Log Format)输出功能,提供容器化的日志收集解决方案。该镜像能够无缝对接Kubernetes集群,收集节点及Pod日志并转换为GELF格式,便于与Graylog等日志聚合系统集成,实现集群日志的集中收集、处理与分析。
bashdocker run -d --name fluentd-k8s-gelf \ --restart always \ -e GELF_HOST=graylog.example.com \ # GELF目标服务器地址(必填) -e GELF_PORT=12201 \ # GELF目标服务器端口(默认12201) -e KUBELET_URL=http://kubelet:10255 \ # Kubelet API地址(用于获取容器元数据) -e LOG_LEVEL=info \ # 日志级别(debug/info/warn/error,默认info) -v /var/log:/var/log:ro \ # 挂载节点日志目录(只读) -v /var/lib/docker/containers:/var/lib/docker/containers:ro \ # 挂载容器日志目录(只读) -v /etc/kubernetes/pki:/etc/kubernetes/pki:ro \ # 挂载Kubernetes证书(如需访问API Server) fluentd-kubernetes-gelf:latest
| 参数名 | 描述 | 默认值 | 是否必填 |
|---|---|---|---|
GELF_HOST | GELF目标服务器IP或域名 | - | 是 |
GELF_PORT | GELF目标服务器端口 | *** | 否 |
GELF_PROTOCOL | GELF传输协议(udp/tcp/http) | udp | 否 |
KUBELET_URL | Kubelet API地址(用于获取容器元数据) | http://localhost:*** | 否 |
KUBERNETES_API_URL | Kubernetes API Server地址 | [***] | 否 |
LOG_LEVEL | Fluentd日志级别 | info | 否 |
BUFFER_SIZE_LIMIT | 日志缓冲区大小限制 | 10MB | 否 |
TAIL_PATH | 日志文件路径模板 | /var/log/containers/*.log | 否 |
yamlapiVersion: apps/v1 kind: DaemonSet metadata: name: fluentd-k8s-gelf namespace: kube-system labels: app: fluentd-k8s-gelf spec: selector: matchLabels: app: fluentd-k8s-gelf template: metadata: labels: app: fluentd-k8s-gelf spec: tolerations: - key: node-role.kubernetes.io/master effect: NoSchedule containers: - name: fluentd-k8s-gelf image: fluentd-kubernetes-gelf:latest resources: limits: memory: 512Mi requests: cpu: 100m memory: 200Mi env: - name: GELF_HOST value: "graylog.internal" # 替换为实际GELF服务器地址 - name: GELF_PORT value: "12201" - name: LOG_LEVEL value: "info" volumeMounts: - name: varlog mountPath: /var/log readOnly: true - name: varlibdockercontainers mountPath: /var/lib/docker/containers readOnly: true - name: etckubernetes mountPath: /etc/kubernetes/pki readOnly: true - name: runlogjournal mountPath: /run/log/journal readOnly: true volumes: - name: varlog hostPath: path: /var/log - name: varlibdockercontainers hostPath: path: /var/lib/docker/containers - name: etckubernetes hostPath: path: /etc/kubernetes/pki - name: runlogjournal hostPath: path: /run/log/journal
通过挂载Fluentd配置文件(fluent.conf)可实现高级日志处理需求,示例配置片段:
xml# 从容器日志文件收集日志 <source> @type tail path "#{ENV['TAIL_PATH']}" pos_file /var/log/fluentd-containers.log.pos tag kube.* format json time_key time time_format %Y-%m-%dT%H:%M:%S.%NZ read_from_head true </source> # 过滤并增强Kubernetes元数据 <filter kube.**> @type kubernetes_metadata kube_url "#{ENV['KUBERNETES_API_URL']}" verify_ssl true ca_file /etc/kubernetes/pki/ca.crt </filter> # 输出至GELF目标 <match **> @type gelf host "#{ENV['GELF_HOST']}" port "#{ENV['GELF_PORT']}" protocol "#{ENV['GELF_PROTOCOL']}" include_tag_key true tag_key tag flush_interval 5s buffer_chunk_limit "#{ENV['BUFFER_SIZE_LIMIT']}" </match>
自定义配置文件可通过-v /path/to/custom/fluent.conf:/fluentd/etc/fluent.conf挂载至容器。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务