0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Docker占用資源過高,如何快速清理Docker?

阿銘linux ? 來源:電子發(fā)燒友網(wǎng) ? 作者:工程師譚軍 ? 2018-07-06 10:05 ? 次閱讀

docker 減肥記

如果經(jīng)常使用 docker,你會發(fā)現(xiàn) docker 占用的資源膨脹很快,其中最明顯也最容易被察覺的應(yīng)該是對磁盤空間的占用。

如何快速的清理 docker 占用的系統(tǒng)資源,具體點(diǎn)說就是刪除那些無用的鏡像、容器、網(wǎng)絡(luò)和數(shù)據(jù)卷…

1

查看 docker 占用的資源

在進(jìn)行資源清理之前我們有必要搞清楚 docker 都占用了哪些系統(tǒng)的資源。

這需要綜合使用不同的命令來完成。

docker container ls:默認(rèn)只列出正在運(yùn)行的容器,-a 選項(xiàng)會列出包括停止的所有容器。

docker image ls:列出鏡像信息,-a 選項(xiàng)會列出 intermediate 鏡像(就是其它鏡像依賴的層)。

docker volume ls:列出數(shù)據(jù)卷。

docker network ls:列出 network。

docker info:顯示系統(tǒng)級別的信息,比如容器和鏡像的數(shù)量等。

通過這些命令查看 docker 使用的資源情況后,

相信你已經(jīng)決定要清理 docker 占用的一些資源了!

2

讓我們先從那些未被使用的資源開始。

只刪除那些未被使用的資源

Docker 提供了方便的 docker system prune 命令來刪除那些已停止的容器、dangling 鏡像、未被容器引用的 network 和構(gòu)建過程中的 cache:

$ docker system prune

安全起見,這個命令默認(rèn)不會刪除那些未被任何容器引用的數(shù)據(jù)卷,如果需要同時刪除這些數(shù)據(jù)卷,你需要顯式的指定 --volumns 參數(shù)。比如你可能想要執(zhí)行下面的命令:

$ docker system prune --all --force --volumns

這次不僅會刪除數(shù)據(jù)卷,而且連確認(rèn)的過程都沒有了!

注意使用 --all 參數(shù)后會刪除所有未被引用的鏡像而不僅僅是 dangling 鏡像。

這里有必要解釋一下何為 dangling images,其實(shí)可以簡單的理解為未被任何鏡像引用的鏡像。比如在你重新構(gòu)建了鏡像后,那些之前構(gòu)建的且不再被引用的鏡像層就變成了 dangling images:

Docker占用資源過高,如何快速清理Docker?

在本地的鏡像更新之后,就會出現(xiàn)類似圖中紅框內(nèi)的 鏡像。這表示舊的鏡像已經(jīng)不再被引用了,此時它們就變成了 dangling images。如果使用 -a 參數(shù),你還會發(fā)現(xiàn)另外一種類型的 鏡像,它們的 repository 和 tag 列都表現(xiàn)為

Docker占用資源過高,如何快速清理Docker?

這些鏡像被稱為 intermediate 鏡像(就是其它鏡像依賴的層)。

我們還可在不同在子命令下執(zhí)行 prune,這樣刪除的就是某類資源:

docker container prune #刪除所有退出狀態(tài)的容器

docker volume prune #刪除未被使用的數(shù)據(jù)卷

docker image prune #刪除 dangling 或所有未被使用的鏡像

3

讓 docker 回到安裝時的狀態(tài)

這里的 "安裝時的狀態(tài)" 指資源占用情況而不是 docker 的相關(guān)配置。這也是一種比較常見的用例,比如就需要在一個干凈的 docker 環(huán)境中自動化的還原出某天的一個生產(chǎn)環(huán)境(使用生產(chǎn)環(huán)境的備份數(shù)據(jù))用于 bug 調(diào)查。

讓我們一起來看看都需要做些什么?

回想我們前面介紹的 docker system prune --all --force --volumns 命令,如果在執(zhí)行這個命令前系統(tǒng)中所有的容器都已停止,那么這個命令就會移除所有的資源!好,現(xiàn)在讓我們想辦法停掉系統(tǒng)中的所有容器。

docker container stop 命令可以停止一個或多個容器,我們只需要把系統(tǒng)中所有在運(yùn)行的容器羅列出來就可以了。

由于 docker 并不介意我們再次停止一個已經(jīng)停止了的容器,干脆簡單粗暴點(diǎn),直接列出所有的容器(包括已經(jīng)停止的)!

$ docker container ls -a -q

Docker占用資源過高,如何快速清理Docker?

-a 顯示所有的容器,-q 只顯示數(shù)字形式的容器 ID。

然后把這里命令執(zhí)行的結(jié)果作為 docker container stop 命令的參數(shù):

$ docker container stop $(docker container ls -a -q)

完整的恢復(fù) docker 環(huán)境的命令如下:

$ docker container stop $(docker container ls -a -q) && docker system prune --all --force --volumns

和前面的 prune 命令類似,也可以完全刪除某一類資源:

刪除容器:docker container rm $(docker container ls -a -q)

刪除鏡像:docker image rm $(docker image ls -a -q)

刪除數(shù)據(jù)卷:docker volume rm $(docker volume ls -q)

刪除 network:docker network rm $(docker network ls -q)

4

創(chuàng)建 shell 別名

上面的命令可以完成任務(wù)但是卻很繁瑣,我們可以通過 shell 的別名功能來簡化這些命令的執(zhí)行。

alias docker-clean-unused='docker system prune --all --force --volumes'

alias docker-clean-all='docker stop $(docker container ls -a -q) && docker system prune --all --force --volumes'

把上面的命令寫入到用戶的 ~/.bashrc 文件中就可以了!

Docker占用資源過高,如何快速清理Docker?

執(zhí)行一次清理任務(wù):

5

總結(jié)

經(jīng)常清理系統(tǒng)資源不僅能夠讓系統(tǒng)運(yùn)行的更流暢,也利于我們把精力集中在相關(guān)的重點(diǎn)資源上面。

所以建議大家能夠使用相關(guān)的資源清理命令,讓 docker 保持清爽和高效。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Docker
    +關(guān)注

    關(guān)注

    0

    文章

    458

    瀏覽量

    11856
  • 資源占用
    +關(guān)注

    關(guān)注

    0

    文章

    1

    瀏覽量

    1225

原文標(biāo)題:Docker減肥小記

文章出處:【微信號:aming_linux,微信公眾號:阿銘linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    在 Huawei Cloud EulerOS 系統(tǒng)中安裝 Docker 的詳細(xì)步驟與常見問題解決

    前言 ? 1. 安裝Docker ? 1.1 系統(tǒng)更新與依賴安裝 ? 1.2 添加華為云Docker倉庫 ? 2. 解決倉庫配置錯誤 ? 2.1 手動修改倉庫配置文件 ? 2.2 安裝Docker
    的頭像 發(fā)表于 12-26 18:12 ?146次閱讀
    在 Huawei Cloud EulerOS 系統(tǒng)中安裝 <b class='flag-5'>Docker</b> 的詳細(xì)步驟與常見問題解決

    docker-compose配置文件內(nèi)容詳解以及常用命令介紹

    一、Docker Compose 簡介 Docker Compose是一種用于定義和運(yùn)行多容器Docker應(yīng)用程序的工具。通過一個? docker-compose.yml ?文件,您可
    的頭像 發(fā)表于 12-02 09:29 ?380次閱讀
    <b class='flag-5'>docker</b>-compose配置文件內(nèi)容詳解以及常用命令介紹

    三分鐘學(xué)會Docker基本操作,快速入門容器技術(shù)!

    機(jī)上一切正?!钡幕貞?yīng),留下您滿心的無奈與困惑? …… 那么,是時候?qū)W習(xí)并使用 Docker技術(shù) 了。通過快速掌握Docker,您將能夠輕松實(shí)現(xiàn)在不同平臺間上的無縫構(gòu)建、測試與部署應(yīng)用程序。Do
    的頭像 發(fā)表于 11-11 17:22 ?164次閱讀
    三分鐘學(xué)會<b class='flag-5'>Docker</b>基本操作,<b class='flag-5'>快速</b>入門容器技術(shù)!

    docker和k8s部署在云平臺性能要求盤點(diǎn)

    Docker和Kubernetes在云平臺部署時有各自的性能要求。Docker需要足夠的CPU、內(nèi)存和存儲資源,以及快速的網(wǎng)絡(luò)帶寬和優(yōu)化的鏡像大小。而Kubernetes則強(qiáng)調(diào)集群管理
    的頭像 發(fā)表于 11-05 10:47 ?188次閱讀

    Docker運(yùn)行環(huán)境安裝

    作者:京東科技 林中 Docker是一個開放的平臺,用于開發(fā)、發(fā)布和運(yùn)行應(yīng)用程序。Docker分離了應(yīng)用程序和運(yùn)行應(yīng)用的基礎(chǔ)設(shè)施,從而實(shí)現(xiàn)了軟件的快速交付。利用docker提供的一系列
    的頭像 發(fā)表于 10-29 11:28 ?217次閱讀

    如何通過Docker使用香山

    資源包在通過Docker形式提供了運(yùn)行香山必須的Linux操作系統(tǒng)、香山開發(fā)環(huán)境、香山和仿真相關(guān)工具的代碼,會大大降低自己部署環(huán)境和工具的難度,理論上比自己部署要方便。如果想自己配置,可以參看本地使用香山的文檔自行安裝。
    的頭像 發(fā)表于 10-29 09:38 ?210次閱讀
    如何通過<b class='flag-5'>Docker</b>使用香山

    手動構(gòu)建Docker鏡像的方法

    不推薦使用docker commit命令,而應(yīng)該使用更靈活、更強(qiáng)大的dockerfile來構(gòu)建docker鏡像。
    的頭像 發(fā)表于 08-05 15:30 ?524次閱讀
    手動構(gòu)建<b class='flag-5'>Docker</b>鏡像的方法

    ARM平臺實(shí)現(xiàn)Docker容器技術(shù)

    。通過利用Docker快速發(fā)布、測試和部署代碼的方法,可顯著減少產(chǎn)品開發(fā)時間。Docker使用客戶端——服務(wù)器(C/S)體系結(jié)構(gòu)。Docker客戶端與
    發(fā)表于 07-25 14:36

    ARM平臺實(shí)現(xiàn)Docker容器技術(shù)

    。通過利用Docker快速發(fā)布、測試和部署代碼的方法,可顯著減少產(chǎn)品開發(fā)時間。Docker使用客戶端——服務(wù)器(C/S)體系結(jié)構(gòu)。Docker客戶端與
    發(fā)表于 07-17 11:05

    Jtti:Docker會替代調(diào)虛機(jī)嗎

    Docker是計算虛擬化的一種方式,和使用虛擬機(jī)進(jìn)行虛擬化是類似的。由于近幾年Docker技術(shù)的流行和發(fā)展。所以單獨(dú)介紹一下Docker。首先先回答下面一個問題。 1.Docker會替
    的頭像 發(fā)表于 07-12 14:38 ?323次閱讀
    Jtti:<b class='flag-5'>Docker</b>會替代調(diào)虛機(jī)嗎

    關(guān)于Docker清理命令集錦

    這篇文章主要介紹了Docker 清理命令集錦,需要的朋友可以參考下 復(fù)制代碼代碼如下: docker kill $(docker ps -a -q) ?刪除所有已經(jīng)停止的容器 復(fù)制代碼
    的頭像 發(fā)表于 06-13 15:56 ?384次閱讀

    鴻蒙OpenHarmony技術(shù):【Docker編譯環(huán)境】

    OpenHarmony為開發(fā)者提供了兩種Docker環(huán)境,以幫助開發(fā)者快速完成復(fù)雜的開發(fā)環(huán)境準(zhǔn)備工作。
    的頭像 發(fā)表于 05-11 09:47 ?1476次閱讀
    鴻蒙OpenHarmony技術(shù):【<b class='flag-5'>Docker</b>編譯環(huán)境】

    Docker容器技術(shù)的安裝和使用

    通過Docker,開發(fā)人員可以更容易地構(gòu)建、交付和運(yùn)行應(yīng)用程序,同時確保應(yīng)用程序的一致性和可移植性。它也使得應(yīng)用程序的部署更加靈活和高效,因?yàn)樗梢?b class='flag-5'>快速地啟動、停止和擴(kuò)展容器,而不會影響其他容器或主機(jī)系統(tǒng)。
    發(fā)表于 04-16 11:24 ?323次閱讀
    <b class='flag-5'>Docker</b>容器技術(shù)的安裝和使用

    精通Docker網(wǎng)絡(luò):Bridge驅(qū)動深度解析

    除了使用 docker0 網(wǎng)橋外,用戶還可以使用自定義的網(wǎng)橋,然后通過 --bridge=BRIDGE 參數(shù)傳遞給 docker daemon。
    的頭像 發(fā)表于 03-31 15:58 ?1450次閱讀
    精通<b class='flag-5'>Docker</b>網(wǎng)絡(luò):Bridge驅(qū)動深度解析

    ARM平臺實(shí)現(xiàn)Docker容器技術(shù)

    ,亦可實(shí)現(xiàn)虛擬化。容器是完全使用沙箱機(jī)制,相互之間不會有任何接口。使用Docker,可像管理應(yīng)用程序一樣管理基礎(chǔ)結(jié)構(gòu)。通過利用Docker快速發(fā)布、測試和部署代碼的方法,可顯著減少產(chǎn)品開發(fā)時間。 ?
    的頭像 發(fā)表于 03-07 13:48 ?811次閱讀
    ARM平臺實(shí)現(xiàn)<b class='flag-5'>Docker</b>容器技術(shù)