{{tag>software sysadmin docker loki log troubleshooting}}
====== Docker: Aucune journalisation produite par le driver loki ======
Les services docker-compose sont paramétrés pour communiquer avec le service loki mais aucun log n'est intégré dans la base Loki, elle reste vide.
Visionner les journaux système à la recherche des traces produites par le daemon docker et loki:
sudo journalctl -u docker.service | grep loki
Ci-dessous un extrait retourné:
août 23 08:54:48 phobos dockerd[2378]: time="2021-08-23T08:54:48Z" level=info msg="level=error ts=2021-08-23T08:54:48.248210233Z caller=client.go:355 container_id=5815df036ed5d2a480b3058587a7643757da8c32bc043844f6ec5db621236517 component=client host=loki:3100 msg=\"final error sending batch\" status=-1 error=\"Post \\\"http://loki:3100/loki/api/v1/push\\\": dial tcp: lookup loki on 91.224.149.254:53: no such host\"" plugin=d8c20ad5025304cb7b7b1768e1439d004a9ce704159b4acba37ec4636192572c
Le message indique une erreur de communication avec l’hôte de destination. Il faut noter que ce n'est pas directement le service qui communique avec Loki mais le daemon Docker. Pour que la communication puisse se faire on modifie la configuration du service docker-compose loki afin qu'il écoute sur la boucle locale uniquement ainsi seules les applications locales y auront accès
version: "3.3"
loki:
image: grafana/loki:2.3.0
restart: unless-stopped
ports:
- "127.0.0.1:3100:3100/tcp"
command: -config.file=/mnt/loki-config.yaml
...
Relancer le service docker-compose loki et vérifier que le mapping du port est correct:
docker-compose ps
Name Command State Ports
--------------------------------------------------------------------------------------------------
monitoring_cadvisor_1 /usr/bin/cadvisor -logtostderr Up (healthy) 8080/tcp
monitoring_grafana_1 /run.sh Up 3000/tcp
monitoring_loki_1 /usr/bin/loki -config.file ... Up 127.0.0.1:3100->3100/tcp
Modifier le fichier ''/etc/hosts'' du serveur exécutant le daemon Docker
127.0.0.1 localhost loki.local loki
# The following lines are desirable for IPv6 capable hosts
::1 ip6-localhost ip6-loopback
fe00::0 ip6-localnet
Enfin pour chaque service souhaitant transmettre les logs vers loki, spécifier le driver loki:
version: "3.3"
...
dokuwiki:
image: bitnami/dokuwiki:latest
depends_on:
- traefik
restart: unless-stopped
logging:
driver: loki
options:
loki-url: "http://loki.local:3100/loki/api/v1/push"
loki-batch-size: "10"
loki-retries: "5"
...
===== Références =====
* https://stackoverflow.com/questions/65994928/docker-containers-not-logging-to-loki-using-loki-log-driver
* https://github.com/grafana/loki/issues/1368