Filebeat 无法作为 docker 容器启动

dex*_*305 2 ubuntu docker docker-compose filebeat

以下是使用的 docker-compose。

version: '3.5'
services:
  filebeat: 
    image: docker.elastic.co/beats/filebeat:6.4.2
    volumes:
      - ${PWD}/filebeat.yml:/usr/share/filebeat/filebeat.yml:ro
      - ${PWD}/test/input:/tmp/input:rw
Run Code Online (Sandbox Code Playgroud)

filebeat.yml 中的 Filebeat 配置是

filebeat.inputs:
- type: container
  paths: 
    - '/var/lib/docker/containers/*/*.log'

processors:
- add_docker_metadata:
    host: "unix:///var/run/docker.sock"

- decode_json_fields:
    fields: ["message"]
    target: "json"
    overwrite_keys: true

output.elasticsearch:
  hosts: ["elasticsearch:9200"]
  indices:
    - index: "filebeat-%{[agent.version]}-%{+yyyy.MM.dd}"

logging.json: true
logging.metrics.enabled: false
Run Code Online (Sandbox Code Playgroud)

之后docker-compose up,容器启动失败,并报告下面提到的错误。

退出:加载配置文件时出错:配置文件(“filebeat.yml”)必须由用户标识符(uid = 0)或root拥有

这里有什么问题?我在运行 ubuntu 的笔记本电脑上运行此示例。

dav*_*xxx 7

加载配置文件时出错:配置文件(“filebeat.yml”)必须由用户标识符(uid = 0)或root拥有

一般来说,我们以root身份启动filebeat(以确保系统的所有文件都可以被它访问)。
您可以尝试以 root 身份启动您的 compose 的 filebeat 服务:

version: '3.5'
services:
  filebeat: 
    user: root #change here
    image: docker.elastic.co/beats/filebeat:6.4.2
    volumes:
      - ${PWD}/filebeat.yml:/usr/share/filebeat/filebeat.yml:ro
      - ${PWD}/test/input:/tmp/input:rw
Run Code Online (Sandbox Code Playgroud)

如果这还不够,您可以 -strict.perms=false使用禁用权限检查的参数来运行容器,例如:

version: '3.5'
services:
  filebeat: 
    user: root #change here
    image: docker.elastic.co/beats/filebeat:6.4.2
    command:
      - "-e"
      - "--strict.perms=false"
     ...
Run Code Online (Sandbox Code Playgroud)

PS:该-e标志禁用 syslog/file 输出并重定向 std 错误中的所有输出(与您的观点无关,但通常需要在容器中从容器日志中读取 filebeat 日志)。

更多信息请参见官方网站