Сохранение журналов контейнеров docker с именами контейнеров вместо идентификаторов контейнеров

#docker #logrotate

#docker #logrotate

Вопрос:

Есть ли способ регистрировать журналы rotate docker container с именами контейнеров вместо идентификаторов контейнеров с помощью драйвера ведения журнала json-файлов по умолчанию?

Идентификаторы контейнеров в имени файла журнала выглядят не очень удобочитаемыми, поэтому я подумал о сохранении журналов с именами контейнеров вместо этого?

Ответ №1:

Можно настроить механизм с параметрами журнала для включения меток в журналы:

 # cat /etc/docker/daemon.json 
{
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "10m",
    "max-file": "3",
    "labels": "com.docker.stack.namespace,com.docker.swarm.service.name,environment"
  }
}

# docker run --label environment=dev busybox echo hello logs
hello logs
root@vm-11:/etc/docker# docker ps -l
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                     PORTS               NAMES
9615c898c2d2        busybox             "echo hello logs"   8 seconds ago       Exited (0) 7 seconds ago                       eloquent_germain

# docker logs --details 961
environment=dev hello logs

# more /var/lib/docker/containers/9615c898c2d2aa7439581e08c2e685f154e4bf2bb9fd5ded0c384da3242c6c9e/9615c898c2d2aa7439581e08c2e685f154e4bf2bb9fd5ded0c384da3242c6c9e-json.log
{"log":"hello logsn","stream":"stdout","attrs":{"environment":"dev"},"time":"2020-09-22T11:12:41.279155826Z"}
  

Вам необходимо перезагрузить механизм docker после внесения изменений в daemon.json, и изменения применяются только к вновь созданным контейнерам. Для systemd перезагрузка выполняется с systemctl reload docker помощью .

Чтобы конкретно передать имя контейнера, которое не является меткой, вы можете передать параметр «tag»:

 # docker run --name test-log-opts --log-opt tag="{{.Name}}/{{.ID}}" busybox echo hello log opts
hello log opts

# docker ps -l
CONTAINER ID        IMAGE               COMMAND                 CREATED             STATUS                     PORTS               NAMES
c201d0a2504a        busybox             "echo hello log opts"   6 seconds ago       Exited (0) 5 seconds ago                       test-log-opts

# docker logs --details c20
tag=test-log-opts/c201d0a2504a hello log opts

# more /var/lib/docker/containers/c201d0a2504addedb2b6785850a83e8931052d0d9778438e9dcc27391f45fec2/c201d0a2504addedb2b6785850a83e8931052d0d9778438e9dcc27391f45fec2-json.log
{"log":"hello log optsn","stream":"stdout","attrs":{"tag":"test-log-opts/c201d0a2504a"},"time":"2020-09-22T11:15:26.998956544Z"}
  

Для получения более подробной информации:

Комментарии:

1. Спасибо @bmitch за подробное объяснение.