简单的 Docker Filebeat Elasticsearch 组合不会注销 Docker 日志

问题描述 投票:0回答:1

我出于教育目的创建了一个 docker compose 来探索 Filebeat 日志记录功能,但我没有让 Filebeat 将日志记录到特定容器。

我创建了一个具有证书安全性的弹性流程,然后在其之上创建了一个 Kibana 容器。我使用 Filebeat 容器配置 Kibana/Elastic 设置,然后我期望 Kibana 中的“发现”选项卡中显示日志,但没有任何可见内容,没有日志。

这是我的 docker-compose:

services:
  elastic-setup:
    image: docker.elastic.co/elasticsearch/elasticsearch:8.12.1
    user: "0"
    volumes:
      - ./elasticsearch/certs:/usr/share/elasticsearch/config/certs
    command: >
      bash -c '
        if [ ! -f config/certs/ca.zip ]; then
          echo "Creating CA";
          bin/elasticsearch-certutil ca --silent --pem -out config/certs/ca.zip;
          unzip config/certs/ca.zip -d config/certs;
        fi;
        if [ ! -f config/certs/certs.zip ]; then
          echo "Creating certs";
          echo -ne \
          "instances:\n"\
          "  - name: search\n"\
          "    dns:\n"\
          "      - search\n"\
          "      - localhost\n"\
          "    ip:\n"\
          "      - 127.0.0.1\n"\
          > config/certs/instances.yml;
          bin/elasticsearch-certutil cert --silent --pem -out config/certs/certs.zip --in config/certs/instances.yml --ca-cert config/certs/ca/ca.crt --ca-key config/certs/ca/ca.key;
          unzip config/certs/certs.zip -d config/certs;
        fi;
        echo "Setting file permissions"
        chown -R root:root config/certs;
        find . -type d -exec chmod 750 \{\} \;;
        find . -type f -exec chmod 640 \{\} \;;
        echo "Waiting for Elasticsearch availability";
        until curl -s --cacert config/certs/ca/ca.crt https://search:9200 | grep -q "missing authentication credentials"; do sleep 30; done;
        echo "Setting kibana_system password";
        until curl -s -X POST --cacert config/certs/ca/ca.crt -u "elastic:elastic" -H "Content-Type: application/json" https://search:9200/_security/user/kibana_system/_password -d "{\"password\":\"kibana\"}" | grep -q "^{}"; do sleep 10; done;
        echo "All done!";
      '
    networks:
      - elasticnet
    healthcheck:
      test: ["CMD-SHELL", "[ -f config/certs/search/search.crt ]"]
      interval: 1s
      timeout: 5s
      retries: 120

  search:
    depends_on:
      elastic-setup:
        condition: service_healthy
    image: docker.elastic.co/elasticsearch/elasticsearch:8.12.1
    volumes:
      - ./elasticsearch/certs:/usr/share/elasticsearch/config/certs
    ports:
      - 9200:9200
    environment:
      - node.name=search
      - cluster.name=search-cluster
      - discovery.type=single-node
      - ELASTIC_PASSWORD=elastic
      - bootstrap.memory_lock=true
      - xpack.security.enabled=true
      - xpack.security.http.ssl.enabled=true
      - xpack.security.http.ssl.key=certs/search/search.key
      - xpack.security.http.ssl.certificate=certs/search/search.crt
      - xpack.security.http.ssl.certificate_authorities=certs/ca/ca.crt
      - xpack.security.http.ssl.verification_mode=certificate
      - xpack.security.transport.ssl.enabled=true
      - xpack.security.transport.ssl.key=certs/search/search.key
      - xpack.security.transport.ssl.certificate=certs/search/search.crt
      - xpack.security.transport.ssl.certificate_authorities=certs/ca/ca.crt
      - xpack.security.transport.ssl.verification_mode=certificate
      - xpack.license.self_generated.type=basic
    mem_limit: 1GB
    ulimits:
      memlock:
        soft: -1
        hard: -1
    networks:
      - elasticnet
    healthcheck:
      test:
        [
          "CMD-SHELL",
          "curl -s --cacert config/certs/ca/ca.crt https://localhost:9200 | grep -q 'missing authentication credentials'",
        ]
      interval: 10s
      timeout: 10s
      retries: 120

  kibana:
    image: docker.elastic.co/kibana/kibana:8.12.1
    volumes:
      - ./elasticsearch/certs:/usr/share/kibana/config/certs
    ports:
      - "5601:5601"
    environment:
      - SERVERNAME=kibana
      - ELASTICSEARCH_HOSTS=https://search:9200
      - ELASTICSEARCH_USERNAME=kibana_system
      - ELASTICSEARCH_PASSWORD=kibana
      - ELASTICSEARCH_SSL_CERTIFICATEAUTHORITIES=config/certs/ca/ca.crt
    networks:
      - elasticnet
    mem_limit: 1GB
    healthcheck:
      test:
        [
          "CMD-SHELL",
          "curl -s -I http://localhost:5601 | grep -q 'HTTP/1.1 302 Found'",
        ]
      interval: 10s
      timeout: 5s
      retries: 30
    depends_on:
      search:
        condition: service_healthy

  filebeat-setup:
    image: docker.elastic.co/beats/filebeat:8.12.1
    command: "--strict.perms=false setup"
    user: root
    networks:
      - elasticnet
    volumes:
      - ./filebeat/filebeat.yml:/usr/share/filebeat/filebeat.yml
      - ./elasticsearch/certs:/usr/share/filebeat/config/certs
    environment:
      - ELASTICSEARCH_HOST=https://search:9200
      - KIBANA_HOST=https://kibana:5601
      - ELASTICSEARCH_USERNAME=elastic
      - ELASTICSEARCH_PASSWORD=elastic
    depends_on:
      search:
        condition: service_healthy
      kibana:
        condition: service_healthy

  filebeat:
    image: docker.elastic.co/beats/filebeat:8.12.1
    command: "--strict.perms=false -e"
    user: root
    volumes:
      - ./filebeat/filebeat.yml:/usr/share/filebeat/filebeat.yml:ro
      - ./elasticsearch/certs:/usr/share/filebeat/config/certs
      - /var/lib/docker/containers:/var/lib/docker/containers:ro
      - /var/run/docker.sock:/var/run/docker.sock:ro
    environment:
      - ELASTICSEARCH_HOST=https://search:9200
      - KIBANA_HOST=https://kibana:5601
      - ELASTICSEARCH_USERNAME=elastic
      - ELASTICSEARCH_PASSWORD=elastic
    networks:
      - elasticnet
    depends_on:
      filebeat-setup:
        condition: service_completed_successfully

  logger:
    image: alpine:latest
    command: >
      sh -c '
        while true
        do
          echo "Log $(date)"
          sleep 1
        done
      '
    labels:
      co.elastic.logs/enabled: true
    networks:
      - elasticnet
    depends_on:
      filebeat-setup:
        condition: service_completed_successfully

networks:
  elasticnet:
    name: elasticnet

Filebeat 设置(我保存在 filebeat 子文件夹中,请参阅卷)非常简单:

filebeat.inputs:
  - type: filestream
    id: my-filestream-id
    enabled: false
# ============================== Filebeat modules ==============================

filebeat.config.modules:
  path: ${path.config}/modules.d/*.yml
  reload.enabled: false
  #reload.period: 10s

filebeat.autodiscover:
  providers:
    - type: docker
      hints.enabled: true
      hints.default_config.enabled: false

# ======================= Elasticsearch template setting =======================

setup.template.settings:
  index.number_of_shards: 1
setup.kibana:
  host: "kibana:5601"
  username: elastic
  password: elastic
output.elasticsearch:
  # Array of hosts to connect to.
  hosts: ["search:9200"]

  # Performance preset - one of "balanced", "throughput", "scale",
  # "latency", or "custom".
  preset: balanced

  # Protocol - either `http` (default) or `https`.
  protocol: "https"

  # Authentication credentials - either API key or username/password.
  #api_key: "id:api_key"
  username: "elastic"
  password: "elastic"

  ssl.certificate_authorities: ["/usr/share/filebeat/config/certs/ca/ca.crt"]
  ssl.certificate: "/usr/share/filebeat/config/certs/search/search.crt"
  ssl.key: "/usr/share/filebeat/config/certs/search/search.key"

# ================================= Processors =================================
processors:
  - add_host_metadata:
      when.not.contains.tags: forwarded
  - add_docker_metadata: ~

所有内容或多或少都是从 Elastic 文档中复制的,但是:

  1. 虽然我在 Kibana 中安装了一些仪表板,但在 Filebeat 初始化期间,我收到很多“kibana-1 | [2024-02-19T01:10:10.966+00:00][ERROR][http] 400 Bad Request”日志和
  2. 如前所述,Kibana Discover 选项卡中看不到来自我的测试“Logger”容器的日志
docker elasticsearch kibana filebeat
1个回答
0
投票

我认为你应该使用“container”filebeat输入type而不是filestream。

Filebeat 输入容器

© www.soinside.com 2019 - 2024. All rights reserved.