容器網絡(十一)Docker 如何支持多種日誌方案?【81】

(二)Docker 如何支持多種日誌方案?

​ 將[容器日誌發送到 STDOUT 和 STDERR]是 Docker 的默認日誌行爲。實際上,Docker 提供了多種日誌機制幫助用戶從運行的容器中提取日誌信息。這些機制被稱做 logging driver。docker

root@host1:~#  docker info |grep 'Logging Driver'
WARNING: No swap limit support
 Logging Driver: json-file
root@host1:~#

若是容器在啓動時沒有特別指明,就會使用這個默認的 logging driver。json

json-file 會將容器的日誌保存在 json 文件中,Docker 負責格式化其內容並輸出到 STDOUT 和 STDERR。日誌

咱們能夠在 Host 的容器目錄中找到這個文件,路徑爲 /var/lib/docker/containers/<contariner ID>/<contariner ID>-json.logcode

好比咱們能夠查看前面 httpd 容器 json 格式的日誌文件。blog

root@host1:/var/lib/docker/containers/fbf97b238f0c40cc397618ce19e4ed875b599fd26430382f9e73f3c275e9d7a1# pwd
/var/lib/docker/containers/fbf97b238f0c40cc397618ce19e4ed875b599fd26430382f9e73f3c275e9d7a1
root@host1:/var/lib/docker/containers/fbf97b238f0c40cc397618ce19e4ed875b599fd26430382f9e73f3c275e9dfbf97b238f0c40cc397618ce19e4ed875b599fd26430382f9e73f3c275e9d7a1-json.log

除了 json-file,Docker 還支持多種 logging driver。完整列表可訪問官方文檔 https://docs.docker.com/engine/admin/logging/overview/#supported-logging-drivers文檔

none 是 disable 容器日誌功能。get

syslogjournald 是 Linux 上的兩種日誌管理服務。it

awslogssplunkgcplogs 是第三方日誌託管服務。容器

gelffluentd 是兩種開源的日誌管理方案,咱們會在後面分別討論。file

容器啓動時能夠經過 --log-driver 指定使用的 logging driver。若是要設置 Docker 默認的 logging driver,須要修改 Docker daemon 的啓動腳本,指定 --log-driver 參數,好比:

ExecStart=/usr/bin/dockerd -H fd:// --log-driver=syslog --log-opt ......

每種 logging driver 都有本身的 --log-opt,使用時請參考官方文檔。

相關文章
相關標籤/搜索