今天小編給大家分享一下Docker容器日志實(shí)例代碼分析的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
為華池等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及華池網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、華池網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
查看容器日志
先使用 docker run -it --rm -d -p 80:80 nginx:1.15.8-alpine
命令啟動(dòng)一個(gè)nginx容器。如果沒有異常,會(huì)得到容器id如 d2408a7931c95a3a83ffeca2fba887763cf925a67890ef3be4d9ff838aa25b00 的長(zhǎng)串。再使用 curl -i 訪問服務(wù),確認(rèn)nginx容器正常啟動(dòng)運(yùn)行。最后使用 docker logs -f d24
查看容器的日志輸出,大概如下:
172.17.0.1 - - [24/mar/2019:03:51:21 +0000] "get / http/1.1" 200 612 "-" "curl/7.29.0" "-"
一般來說使用容器id的前3位即可
以上就是我們查看容器日志的日常方法了,非常簡(jiǎn)單實(shí)用。
容器日志文件存儲(chǔ)
容器的日志會(huì)以json文件方式存儲(chǔ)在本地磁盤,可以使用下面方式查看文件路徑 docker inspect d42 | grep log
可以找到:
"logpath": "/var/lib/docker/containers/d2408a7931c95a3a83ffeca2fba887763cf925a67890ef3be4d9ff838aa25b00/d2408a7931c95a3a83ffeca2fba887763cf925a67890ef3be4d9ff838aa25b00-json.log",
注意1:mac上沒有/var/lib/docker目錄 ,因?yàn)閐ocker for mac的運(yùn)作方式不一樣,最好使用linux系統(tǒng)練習(xí)。
注意2: 如果logpath內(nèi)容為空,大概是因?yàn)閐ocker engine版本,升級(jí)docker版本能到docker-ce 18.09.3
查看 d2408a7931c95a3a83ffeca2fba887763cf925a67890ef3be4d9ff838aa25b00-json.log 文件,可以看到:
{"log":"172.17.0.1 - - [24/mar/2019:03:51:21 +0000] \"get / http/1.1\" 200 612 \"-\" \"curl/7.29.0\" \"-\"\r\n","stream":"stdout","time":"2019-03-24t03:51:21.982476951z"}
這條信息的log字段內(nèi)容和之前通過 docker logs 命令查看的內(nèi)容一致。
容器日志會(huì)跟隨容器生命周期,容器銷毀后日志也會(huì)銷毀。使用 docker stop 24 關(guān)停測(cè)試的nginx服務(wù)。因?yàn)槿萜鲉?dòng)使用時(shí)候用了 --rm 參數(shù),關(guān)停后會(huì)自動(dòng)清理刪除,所以會(huì)發(fā)現(xiàn) /var/lib/docker/containers/d2408a7931c95a3a83ffeca2fba887763cf925a67890ef3be4d9ff838aa25b00 目錄不存在了,相應(yīng)的日志文件也就刪除了。
容器日志文件滾動(dòng)策略
docker容器日志默認(rèn)寫入json文件,在線上運(yùn)行時(shí)候會(huì)有磁盤寫滿的風(fēng)險(xiǎn)。可以調(diào)整策略,讓其進(jìn)行滾動(dòng)。修改/etc/docker/daemon.json(如果沒有就手工創(chuàng)建一個(gè)),增加下面內(nèi)容:
{ "log-opts": { "max-size": "1m", "max-file": "3" } }
修改完成后重啟docker服務(wù):
systemctl daemon-reload systemctl restart docker.service
測(cè)試一下新的日志策略,使用下面的命令創(chuàng)建一個(gè)容器:
docker run -d --rm alpine:3.6 sh -c "while true; do echo hello world; usleep 10; done"
這個(gè)alpine容器就是每隔10微秒輸出hello world,保持高頻度輸出,快速生產(chǎn)日志文件。
注:shell中的時(shí)間控制
1、sleep : 默認(rèn)為秒。
sleep 1s 表示延遲一秒
sleep 1m 表示延遲一分鐘
sleep 1h 表示延遲一小時(shí)
sleep 1d 表示延遲一天
2、usleep : 默認(rèn)以微秒。
1s = 1000ms = 1000000us
按照前文中查看日志文件的方法
# pwd /var/lib/docker/containers/aa3307f5b42770319129e126122be123cfd8e0ebe1c412371ad27e62faa007e3 # ls -lah total 2.6m drwx------ 4 root root 4.0k mar 24 16:22 . drwx------ 3 root root 4.0k mar 24 16:21 .. -rw-r----- 1 root root 647k mar 24 16:22 aa3307f5b42770319129e126122be123cfd8e0ebe1c412371ad27e62faa007e3-json.log -rw-r----- 1 root root 977k mar 24 16:22 aa3307f5b42770319129e126122be123cfd8e0ebe1c412371ad27e62faa007e3-json.log.1 -rw-r----- 1 root root 977k mar 24 16:21 aa3307f5b42770319129e126122be123cfd8e0ebe1c412371ad27e62faa007e3-json.log.2
很容易發(fā)現(xiàn),日志文件的策略就是維持3個(gè)1m大小文件存在,和我們?cè)O(shè)置保持一致。
測(cè)試完成后,記得使用docker stop aa3 清理測(cè)試現(xiàn)場(chǎng),max-size也可以按照真實(shí)需求調(diào)整大小。
nginx容器日志
了解docker容器的日志策略后,再看看常用的容器是如何處理的。先看看nginx容器。
首先 docker run -it --rm -d -p 80:80 nginx:1.15.8-alpine 創(chuàng)建一個(gè)nginx容器,然后 docker exec -it b6d sh 進(jìn)入容器,查看/etc/nginx/nginx.conf可以看到下面內(nèi)容:
error_log /var/log/nginx/error.log warn; access_log /var/log/nginx/access.log main;
也就是nginx會(huì)將錯(cuò)誤日志和訪問日志寫入對(duì)應(yīng)的日志文件。繼續(xù)查看/var/log/nginx目錄:
/var/log/nginx # ls -lah total 0 drwxr-xr-x 2 root root 39 mar 4 07:54 . drwxr-xr-x 3 root root 18 mar 4 07:54 .. lrwxrwxrwx 1 root root 11 jan 31 23:32 access.log -> /dev/stdout lrwxrwxrwx 1 root root 11 jan 31 23:32 error.log -> /dev/stderr
這就發(fā)現(xiàn)奧秘了,access.log文件會(huì)通過軟鏈接重定向到標(biāo)準(zhǔn)輸出,而錯(cuò)誤日志error.log則會(huì)重定向標(biāo)準(zhǔn)錯(cuò)誤。這樣使用docker log命令就可以看到nginx的訪問日志了。
為了進(jìn)一步驗(yàn)證,查看nginx dockerfile文件,其中有:
# forward request and error logs to docker log collector && ln -sf /dev/stdout /var/log/nginx/access.log \ && ln -sf /dev/stderr /var/log/nginx/error.log
可見nginx鏡像創(chuàng)建時(shí)候就定義好了日志文件的輸出。
同樣使用docker stop 524清理現(xiàn)場(chǎng),以后就不再介紹清理這一步驟了。
MySQL容器日志
啟動(dòng)一個(gè)mysql容器
docker run --rm -e mysql_root_password=123456 mysql:5.7
不難看到mysql容器日志輸出, 截取其中片段如下:
initializing database
2019-03-24t08:48:19.102726z 0 [warning] timestamp with implicit default value is deprecated. please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2019-03-24t08:48:20.241459z 0 [warning] innodb: new log files created, lsn=45790
2019-03-24t08:48:20.414933z 0 [warning] innodb: creating foreign key constraint system tables.
2019-03-24t08:48:20.509897z 0 [warning] no existing uuid has been found, so we assume that this is the first time that this server has been started. generating a new uuid: 935a6ee7-4e11-11e9-b135-0242ac110002.
2019-03-24t08:48:20.519148z 0 [warning] gtid table is not ready to be used. table 'mysql.gtid_executed' cannot be opened.
2019-03-24t08:48:20.519843z 1 [warning] is created with an empty password ! please consider switching off the --initialize-insecure option.
2019-03-24t08:48:24.066683z 1 [warning] 'user' entry ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066730z 1 [warning] 'user' entry ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066740z 1 [warning] 'user' entry ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066756z 1 [warning] 'db' entry 'performance_schema ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066761z 1 [warning] 'db' entry 'sys ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066772z 1 [warning] 'proxies_priv' entry '@ ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066814z 1 [warning] 'tables_priv' entry 'user ignored in --skip-name-resolve mode.
2019-03-24t08:48:24.066822z 1 [warning] 'tables_priv' entry 'sys_config ignored in --skip-name-resolve mode.
database initialized
initializing certificates
generating a rsa private key
查看mysql dockerfile 文件,可以知道m(xù)ysql鏡像啟動(dòng)入口在entrypoint.sh,從腳本中發(fā)現(xiàn):
echo 'initializing database' "$@" --initialize-insecure echo 'database initialized'
以上就是“Docker容器日志實(shí)例代碼分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。