詳解如何查看 docker 容器使用的資源
在容器的使用過(guò)程中,如果能及時(shí)的掌握容器使用的系統(tǒng)資源,無(wú)論對(duì)開發(fā)還是運(yùn)維工作都是非常有益的。幸運(yùn)的是 docker 自己就提供了這樣的命令:docker stats。
默認(rèn)輸出
docker stats 命令用來(lái)顯示容器使用的系統(tǒng)資源。不帶任何選項(xiàng)執(zhí)行 docker stats 命令:
$ docker stats

默認(rèn)情況下,stats 命令會(huì)每隔 1 秒鐘刷新一次輸出的內(nèi)容直到你按下 ctrl + c。下面是輸出的主要內(nèi)容:
[CONTAINER]:以短格式顯示容器的 ID。
[CPU %]:CPU 的使用情況。
[MEM USAGE / LIMIT]:當(dāng)前使用的內(nèi)存和最大可以使用的內(nèi)存。
[MEM %]:以百分比的形式顯示內(nèi)存使用情況。
[NET I/O]:網(wǎng)絡(luò) I/O 數(shù)據(jù)。
[BLOCK I/O]:磁盤 I/O 數(shù)據(jù)。
[PIDS]:PID 號(hào)。
只返回當(dāng)前的狀態(tài)
如果不想持續(xù)的監(jiān)控容器使用資源的情況,可以通過(guò) --no-stream 選項(xiàng)只輸出當(dāng)前的狀態(tài):
$ docker stats --no-stream

這樣輸出的結(jié)果就不會(huì)變化了,看起來(lái)省勁不少。
只輸出指定的容器
如果我們只想查看個(gè)別容器的資源使用情況,可以為 docker stats 命令顯式的指定目標(biāo)容器的名稱或者是 ID:
$ docker stats --no-stream registry 1493

當(dāng)有很多的容器在運(yùn)行時(shí),這樣的結(jié)果看起來(lái)會(huì)清爽一些。這里的 registry 和 1493 分別是容器的名稱和容器的 ID。注意,多個(gè)容器的名稱或者是 ID 之間需要用空格進(jìn)行分割。
細(xì)心的同學(xué)可能已經(jīng)發(fā)現(xiàn)了,第一列不再顯示默認(rèn)的容器 ID,而是顯示了我們傳入的容器名稱和 ID。基于此,我們可以通過(guò)簡(jiǎn)單的方式使用容器的名稱替代默認(rèn)輸出中的容器 ID:
$ docker stats $(docker ps --format={{.Names}})

用容器的名稱替代 ID 后輸出的結(jié)果是不是友好一些?
格式化輸出的結(jié)果
我們?cè)谇懊娓懔它c(diǎn)小手段把輸出中的容器 ID 替換成了名稱。其實(shí) docker stats 命令支持我們通過(guò) --format 選項(xiàng)自定義輸出的內(nèi)容和格式:
$ docker stats --format "table {{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}"

上面的命令中我們只輸出了 Name, CPUPerc 和 Memusage 三列。下面是自定義的格式中可以使用的所有占位符:
.Container 根據(jù)用戶指定的名稱顯示容器的名稱或 ID。
.Name 容器名稱。
.ID 容器 ID。
.CPUPerc CPU 使用率。
.MemUsage 內(nèi)存使用量。
.NetIO 網(wǎng)絡(luò) I/O。
.BlockIO 磁盤 I/O。
.MemPerc 內(nèi)存使用率。
.PIDs PID 號(hào)。
有了這些信息我們就可以完全按照自己的需求或者是偏好來(lái)控制 docker stats 命令輸出的內(nèi)容了。
除了以 table 格式輸出結(jié)果,還可以通過(guò) format 選項(xiàng)輸出 json 格式的結(jié)果:
$ docker stats --no-stream --format \
"{\"container\":\"{{ .Container }}\",\"memory\":{\"raw\":\"{{ .MemUsage }}\",\"percent\":\"{{ .MemPerc }}\"},\"cpu\":\"{{ .CPUPerc }}\"}"

總結(jié)
通過(guò) docker stats 命令我們可以看到容器使用系統(tǒng)資源的情況。這為我們進(jìn)一步的約束容器可用資源或者是調(diào)查與資源相關(guān)的問(wèn)題提供了依據(jù)。除了 docker 自帶的命令,像 glances 等工具也已經(jīng)支持查看容器使用的資源情況了,有興趣的朋友可以去了解一下。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Docker方式實(shí)現(xiàn)MySql 主從復(fù)制(實(shí)踐篇)
本篇文章主要介紹了詳解Docker方式實(shí)現(xiàn)MySql 主從復(fù)制(實(shí)踐篇),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
ubuntu如何在docker容器中安裝strongswan
這篇文章主要介紹了ubuntu如何在docker容器中安裝strongswan,起動(dòng)一個(gè)ubuntu容器,我是用的docker compose啟動(dòng)的,compose的配置文件為ipsec-strongswan.yml,感興趣的朋友跟隨小編一起看看吧2024-04-04
詳解Docker創(chuàng)建Mysql容器并通過(guò)命令行連接到容器
本篇文章主要介紹了Docker創(chuàng)建Mysql容器并通過(guò)命令行連接到容器,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
docker和docker compose版本太低問(wèn)題的解決方案
本文主要介紹了Docker和docker-compose版本過(guò)低導(dǎo)致的KeyError: 'ContainerConfig'錯(cuò)誤的解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03
Docker 容器文件系統(tǒng)詳細(xì)介紹(圖文)
這篇文章主要介紹了Docker 容器文件系統(tǒng)詳細(xì)介紹(圖文)的相關(guān)資料,這里對(duì)Docker 容器文件系統(tǒng)進(jìn)行了具體的分析詳解,需要的朋友可以參考下2016-12-12
完美解決Windows10下無(wú)法對(duì)docker容器進(jìn)行端口訪問(wèn)的操作
這篇文章主要介紹了完美解決Windows10下無(wú)法對(duì)docker容器進(jìn)行端口訪問(wèn)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11

