Astronomer Log Collection Daemon 是 Astronomer 平台的核心组件之一,作为轻量级日志收集守护进程,专门用于在 Astronomer 平台环境中实现日志数据的集中化采集、处理与传输。该镜像旨在简化平台日志管理流程,确保日志数据从产生到存储的全链路可靠性,为平台监控、故障排查及审计分析提供基础数据支持。
基本运行命令
bashdocker run -d \ --name astronomer-log-daemon \ --restart always \ -v /var/log/astronomer:/var/log/astronomer:ro \ # 挂载平台日志目录(只读) -v /var/run/docker.sock:/var/run/docker.sock:ro \ # 访问 Docker 容器日志(可选) -e LOG_OUTPUT_DESTINATION="elasticsearch" \ # 日志输出目标类型 -e ELASTICSEARCH_URL="http://elasticsearch:9200" \ # Elasticsearch 服务地址 -e LOG_LEVEL="info" \ # 守护进程自身日志级别 astronomer/log-collection-daemon:latest
yamlversion: '3.8' services: log-daemon: image: astronomer/log-collection-daemon:latest container_name: astronomer-log-daemon restart: always volumes: - /var/log/astronomer:/var/log/astronomer:ro - /var/run/docker.sock:/var/run/docker.sock:ro environment: - LOG_OUTPUT_DESTINATION=elasticsearch - ELASTICSEARCH_URL=http://elasticsearch:9200 - ELASTICSEARCH_INDEX="astronomer-logs-{{ .Timestamp.Format \"2006-01-02\" }}" - LOG_SOURCE_PATHS="/var/log/astronomer/*.log,/var/log/astronomer/workers/*.log" # 多日志源路径 - LOG_FILTER_INCLUDE="level:info,level:warn,level:error" # 包含指定级别的日志 - CACHE_DIR="/tmp/log-cache" # 本地日志缓存目录 networks: - astronomer-platform-network # 加入平台网络,确保与其他组件通信 networks: astronomer-platform-network: external: true
yamlapiVersion: apps/v1 kind: DaemonSet metadata: name: astronomer-log-daemon namespace: astronomer spec: selector: matchLabels: app: astronomer-log-daemon template: metadata: labels: app: astronomer-log-daemon spec: containers: - name: log-daemon image: astronomer/log-collection-daemon:latest volumeMounts: - name: var-log-astronomer mountPath: /var/log/astronomer readOnly: true - name: docker-sock mountPath: /var/run/docker.sock readOnly: true - name: log-cache mountPath: /tmp/log-cache env: - name: LOG_OUTPUT_DESTINATION value: "elasticsearch" - name: ELASTICSEARCH_URL valueFrom: configMapKeyRef: name: astronomer-config key: elasticsearch.url - name: LOG_LEVEL value: "info" volumes: - name: var-log-astronomer hostPath: path: /var/log/astronomer - name: docker-sock hostPath: path: /var/run/docker.sock - name: log-cache emptyDir: {}
| 环境变量名 | 描述 | 可选值 | 默认值 |
|---|---|---|---|
LOG_OUTPUT_DESTINATION | 日志输出目标类型 | elasticsearch, s3, kafka | elasticsearch |
LOG_LEVEL | 守护进程自身日志级别 | debug, info, warn, error | info |
LOG_SOURCE_PATHS | 日志源文件路径,多个路径用逗号分隔 | 合法文件路径表达式 | /var/log/astronomer/*.log |
LOG_FILTER_INCLUDE | 日志包含过滤规则,格式"key:value,..." | 键值对表达式 | 无(默认采集所有日志) |
LOG_FILTER_EXCLUDE | 日志排除过滤规则,格式"key:value,..." | 键值对表达式 | 无(默认不排除日志) |
ELASTICSEARCH_URL | Elasticsearch 服务地址(当目标为 ES 时) | 合法 URL | http://elasticsearch:9200 |
ELASTICSEARCH_INDEX | Elasticsearch 索引名模板 | 字符串,支持时间格式化 | astronomer-logs-{{ .Timestamp.Format "2006-01-02" }} |
S3_BUCKET | S3 存储桶名称(当目标为 S3 时) | 合法 S3 桶名 | 无(必填) |
S3_REGION | S3 区域(当目标为 S3 时) | AWS 区域代码 | us-east-1 |
KAFKA_BROKERS | Kafka brokers 地址(当目标为 Kafka 时) | 逗号分隔的 broker 列表 | 无(必填) |
KAFKA_TOPIC | Kafka 主题名(当目标为 Kafka 时) | 合法主题名 | astronomer-logs |
CACHE_DIR | 本地日志缓存目录 | 合法目录路径 | /tmp/log-cache |
CACHE_MAX_SIZE | 缓存目录最大容量(MB) | 正整数 | 1024(1GB) |
默认采集的日志数据包含以下字段(结构化 JSON 格式):
json{ "timestamp": "2023-10-01T12:34:56.789Z", # 日志产生时间(UTC) "source": "/var/log/astronomer/airflow-scheduler.log", # 日志源路径 "level": "info", # 日志级别 "message": "Scheduler started successfully", # 日志内容 "hostname": "astronomer-scheduler-5f78d2", # 主机/容器名 "component": "airflow-scheduler", # 平台组件名 "cluster_id": "astronomer-prod-01" # 集群标识(如有) }
常见问题及解决方法
日志采集不完整
LOG_SOURCE_PATHS 配置是否包含目标日志路径docker logs astronomer-log-daemon日志无法传输到目标服务
docker exec -it astronomer-log-daemon curl http://elasticsearch:9200docker exec -it astronomer-log-daemon du -sh /tmp/log-cache容器启动失败
ls -ld /var/log/astronomerastronomer/log-collection-daemon:latest您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。



探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务