共計 1061 個字符,預(yù)計需要花費 3 分鐘才能閱讀完成。
本篇文章給大家分享的是有關(guān) Docker 如何支持多種日志方案,丸趣 TV 小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著丸趣 TV 小編一起來看看吧。
將容器日志發(fā)送到 STDOUT 和 STDERR 是 Docker 的默認(rèn)日志行為。實際上,Docker 提供了多種日志機制幫助用戶從運行的容器中提取日志信息。這些機制被稱作 logging driver。
Docker 的默認(rèn) logging driver 是 json-file。
# docker info |grep Logging Driver
Logging Driver: json-file
如果容器在啟動時沒有特別指明,就會使用這個默認(rèn)的 logging driver。
json-file 會將容器的日志保存在 json 文件中,Docker 負(fù)責(zé)格式化其內(nèi)容并輸出到 STDOUT 和 STDERR。
我們可以在 Host 的容器目錄中找到這個文件,器路徑為 /var/lib/docker/containers/ contariner ID / contariner ID -json.log
比如我們可以查看前面 httpd 容器 json 格式的日志文件。
可以看到 5 條日志記錄。
除了 json-file,Docker 還支持多種 logging driver。檔 https://docs.docker.com/engine/admin/logging/overview/#supported-logging-drivers
none 是 disable 容器日志功能。
syslog 和 journald 是 Linux 上的兩種日志管理服務(wù)。
awslogs、splunk 和 gcplogs 是第三方日志托管服務(wù)。
gelf 和 fluentd 是兩種開源的日志管理方案,我們會在后面分別討論。
容器啟動時可以通過 –log-driver 指定使用的 logging driver。如果要設(shè)置 Docker 默認(rèn)的 logging driver,需要修改 Docker daemon 的啟動腳本,指定 –log-driver 參數(shù),比如:
ExecStart=/usr/bin/dockerd -H fd:// --log-driver=syslog --log-opt ......
每種 logging driver 都有自己的 –log-opt。
以上就是 Docker 如何支持多種日志方案,丸趣 TV 小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注丸趣 TV 行業(yè)資訊頻道。