Получение метрик хоста контейнера при запуске Telegraf внутри Docker

#telegraf

Вопрос:

У меня есть служба docker compose с кучей контейнеров, и я пытаюсь собрать как метрики контейнера docker из этих контейнеров, так и метрики хоста контейнера с сервера Ubuntu, на котором запущены контейнеры. Я получаю статистику контейнера docker, но я не получаю метрики хоста контейнера Ubuntu. Статистика из плагинов ввода, не основанных на docker (inputs.diskio, inputs.mem и т. Д.), взята из контейнера telegraf.

Я нашел это и открыл тома, но по-прежнему ничего: https://community.influxdata.com/t/how-can-we-collect-host-machine-metrics-while-telegraf-is-running-in-docker-container/12005

Вот мой файл для создания:

 version: "3" 
services:
  telegraf:
    image: telegraf:1.20.3
    volumes:
     - ./telegraf.conf:/etc/telegraf/telegraf.conf:ro
     - /var/run/docker.sock:/var/run/docker.sock:ro
     - /sys:/rootfs/sys:ro
     - /proc:/rootfs/proc:ro
     - /etc:/rootfs/etc:ro
    environment:
      HOST_PROC: /rootfs/proc
      HOST_SYS: /rootfs/sys
      HOST_ETC: /rootfs/etc

  vote:
    build: ./vote
    # use python rather than gunicorn for local dev
    command: python app.py
    depends_on:
      - redis
    volumes:
     - ./vote:/app
    ports:
      - "5000:80"
    networks:
      - front-tier
      - back-tier
  
  result:
    build: ./result
    # use nodemon rather than node for local dev
    command: nodemon server.js
    depends_on:
      - db
    volumes:
      - ./result:/app
    ports:
      - "5001:80"
      - "5858:5858"
    networks:
      - front-tier
      - back-tier

  worker:
    build:
      context: ./worker
    depends_on:
      - redis
      - db
    networks:
      - back-tier

  redis:
    image: redis:5.0-alpine3.10
    volumes:
      - "./healthchecks:/healthchecks"
    healthcheck:
      test: /healthchecks/redis.sh
      interval: "5s"
    ports: ["6379"]
    networks:
      - back-tier

  db:
    image: postgres:9.4
    environment:
      POSTGRES_USER: "postgres"
      POSTGRES_PASSWORD: "postgres"
    volumes:
      - "db-data:/var/lib/postgresql/data"
      - "./healthchecks:/healthchecks"
    healthcheck:
      test: /healthchecks/postgres.sh
      interval: "5s"
    networks:
      - back-tier

volumes:
    db-data:

networks:
    front-tier:
    back-tier:
 

Вот конфигурация агента:

 [agent]
  interval = "10s"

[[inputs.mem]]

[[inputs.disk]]
  ## Ignore mount points by filesystem type.
  ignore_fs = ["tmpfs", "devtmpfs", "devfs", "iso9660", "overlay", "aufs", "squashfs"]

[[inputs.diskio]]

[[inputs.kernel]]

[[inputs.ethtool]]

[[inputs.procstat]]
  pattern = ".*"

[[inputs.docker]]
  endpoint = "unix:///var/run/docker.sock"
  gather_services = false
  container_names = []
  source_tag = true
  container_name_include = []
  container_name_exclude = []
  timeout = "5s"
  perdevice = true
  docker_label_include = []
  docker_label_exclude = []

  
[[inputs.cpu]]
  percpu = true
  totalcpu = true
  collect_cpu_time = true
  report_active = true
 

How do I get the container host metrics??