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

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

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

Docker占用資源過(guò)高,如何快速清理Docker?

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

docker 減肥記

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

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

1

查看 docker 占用的資源

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

這需要綜合使用不同的命令來(lái)完成。

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

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

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

docker network ls:列出 network。

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

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

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

2

讓我們先從那些未被使用的資源開(kāi)始。

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

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

$ docker system prune

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

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

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

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

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

Docker占用資源過(guò)高,如何快速清理Docker?

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

Docker占用資源過(guò)高,如何快速清理Docker?

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

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

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

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

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

3

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

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

讓我們一起來(lái)看看都需要做些什么?

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

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

由于 docker 并不介意我們?cè)俅瓮V挂粋€(gè)已經(jīng)停止了的容器,干脆簡(jiǎn)單粗暴點(diǎn),直接列出所有的容器(包括已經(jīng)停止的)!

$ docker container ls -a -q

Docker占用資源過(guò)高,如何快速清理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 命令類(lèi)似,也可以完全刪除某一類(lèi)資源:

刪除容器: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ù)但是卻很繁瑣,我們可以通過(guò) shell 的別名功能來(lái)簡(jiǎn)化這些命令的執(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'

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

Docker占用資源過(guò)高,如何快速清理Docker?

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

5

總結(jié)

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

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

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

    關(guān)注

    0

    文章

    446

    瀏覽量

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

    關(guān)注

    0

    文章

    1

    瀏覽量

    1215

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

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

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

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

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

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

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

    如何利用樹(shù)莓派安裝DockerDocker-compose呢?

    本文主要演示了樹(shù)莓派如何安裝DockerDocker-compose的過(guò)程。
    的頭像 發(fā)表于 12-14 16:19 ?2312次閱讀
    如何利用樹(shù)莓派安裝<b class='flag-5'>Docker</b>和<b class='flag-5'>Docker</b>-compose呢?

    docker內(nèi)存不足的解決辦法

    內(nèi)存和CPU。通過(guò)這個(gè)命令,我們可以發(fā)現(xiàn)哪個(gè)容器占用了大量的內(nèi)存資源。 調(diào)整Docker守護(hù)進(jìn)程的內(nèi)存限制: Docker守護(hù)進(jìn)程本身也會(huì)消耗一些內(nèi)存
    的頭像 發(fā)表于 11-23 10:41 ?2164次閱讀

    docker容器有幾種狀態(tài)

    Docker 容器的各種狀態(tài)及其含義。 Created(已創(chuàng)建):當(dāng)我們使用 docker create 命令創(chuàng)建一個(gè)容器時(shí),它會(huì)進(jìn)入已創(chuàng)建狀態(tài)。在這個(gè)狀態(tài)下,容器的文件系統(tǒng)和網(wǎng)絡(luò)等資源都已被創(chuàng)建,但容器本身尚未啟動(dòng)。它可以在
    的頭像 發(fā)表于 11-23 09:50 ?1773次閱讀

    docker核心組件有哪些

    Docker 是一種開(kāi)源的容器化平臺(tái),它能夠?qū)崿F(xiàn)將應(yīng)用程序及其依賴項(xiàng)打包到一個(gè)可移植的容器中,從而實(shí)現(xiàn)快速、可重復(fù)、可擴(kuò)展的部署和管理。Docker 的核心組件包括 Docker En
    的頭像 發(fā)表于 11-23 09:47 ?1467次閱讀

    docker進(jìn)入容器的方法有哪些

    Docker是一種流行的容器化平臺(tái),它能夠快速構(gòu)建、交付和運(yùn)行應(yīng)用程序。在使用Docker時(shí),我們經(jīng)常需要進(jìn)入容器進(jìn)行調(diào)試、管理和運(yùn)行命令等操作。本文將詳細(xì)介紹Docker進(jìn)入容器的各
    的頭像 發(fā)表于 11-23 09:45 ?8900次閱讀

    如何啟動(dòng)本機(jī)docker服務(wù)

    Docker是一個(gè)開(kāi)源項(xiàng)目,可以幫助開(kāi)發(fā)者打包應(yīng)用程序及其依賴,并且能夠?qū)⑵渥鳛楠?dú)立的容器來(lái)運(yùn)行。本文將詳細(xì)介紹如何在本機(jī)上啟動(dòng)Docker服務(wù)。 第一步:安裝Docker 在開(kāi)始之前,首先需要
    的頭像 發(fā)表于 11-23 09:43 ?1482次閱讀

    linux關(guān)閉docker的命令

    在 Linux 系統(tǒng)中,關(guān)閉 Docker 的操作可以通過(guò)以下多種方式進(jìn)行。本文將詳細(xì)講解每一種方式,并提供示例代碼和命令,以幫助讀者更好地理解和實(shí)踐。 使用 docker 命令 最常用的方法
    的頭像 發(fā)表于 11-23 09:39 ?2367次閱讀

    Docker與虛擬機(jī)的區(qū)別

    Docker和虛擬機(jī)是兩種不同的虛擬化技術(shù),它們?cè)趯?shí)現(xiàn)方式、資源消耗、運(yùn)行性能等方面存在許多差異。本文將會(huì)詳細(xì)介紹它們的區(qū)別。 一、實(shí)現(xiàn)方式 1.1 虛擬機(jī) 虛擬機(jī)是通過(guò)在物理主機(jī)上模擬出多個(gè)獨(dú)立
    的頭像 發(fā)表于 11-23 09:37 ?6777次閱讀

    docker exec命令的使用方法

    Docker是一種開(kāi)源的容器化平臺(tái),可以讓開(kāi)發(fā)人員在容器中打包和運(yùn)行應(yīng)用程序。它提供了一種快速、可靠和一致的方式來(lái)構(gòu)建、部署和運(yùn)行應(yīng)用程序。Docker exec命令是Docker提供
    的頭像 發(fā)表于 11-23 09:33 ?1325次閱讀

    docker部署mysql的壞處

    Docker 是一種虛擬化技術(shù),它允許開(kāi)發(fā)人員在容器內(nèi)打包應(yīng)用程序及其所有依賴項(xiàng),從而實(shí)現(xiàn)在不同環(huán)境中運(yùn)行相同的應(yīng)用程序的能力。然而,在使用 Docker 部署 MySQL 時(shí),也存在一些潛在
    的頭像 發(fā)表于 11-23 09:29 ?1166次閱讀

    linux docker安裝部署

    Docker是一種開(kāi)源的容器化平臺(tái),可以幫助開(kāi)發(fā)者在不同的環(huán)境中快速構(gòu)建、測(cè)試和部署應(yīng)用程序。它能夠解決不同操作系統(tǒng)之間的兼容性問(wèn)題,簡(jiǎn)化了應(yīng)用程序的部署過(guò)程,并提供了高效的資源利用。本文將帶您詳細(xì)
    的頭像 發(fā)表于 11-23 09:27 ?858次閱讀

    如何使用 Docker容器化技術(shù)

    對(duì)于開(kāi)發(fā)人員來(lái)說(shuō),Docker肯定都不陌生,今天小編帶大家重新學(xué)習(xí)一下Docker。 什么是 Docker 官話: Docker 是一種開(kāi)源的容器化平臺(tái),它可以幫助開(kāi)發(fā)者將應(yīng)用程序與其
    的頭像 發(fā)表于 09-30 11:24 ?1.6w次閱讀