關(guān)于docker清理Overlay2占用磁盤(pán)空間的問(wèn)題(親測(cè)有效)
使用Docker過(guò)程中,長(zhǎng)時(shí)間運(yùn)行服務(wù)容器,導(dǎo)致不能進(jìn)行上傳文件等操作,通過(guò)命令df -h
發(fā)現(xiàn)overlay占用較高。通過(guò)命令docker system prune -a
清理無(wú)用鏡像、緩存、掛載數(shù)據(jù),也沒(méi)有什么改變。
如果你也被這個(gè)問(wèn)題所困擾,咱們就一起看一下 Docker 是如何使用磁盤(pán)空間的,以及如何回收。
docker 占用的空間可以通過(guò)下面的命令查看:
$ docker system df
prune
指令默認(rèn)會(huì)清除所有如下資源:
- 已停止的容器(container)
- 未被任何容器所使用的卷(volume)
- 未被任何容器所關(guān)聯(lián)的網(wǎng)絡(luò)(network)
- 所有懸空鏡像(image)。
查詢 overlay的作用的時(shí)候知道:
容器的磁盤(pán)占用
每次創(chuàng)建一個(gè)容器時(shí),都會(huì)有一些文件和目錄被創(chuàng)建,例如:
/var/lib/docker/containers/ID目錄,如果容器使用了默認(rèn)的日志模式,他的所有日志都會(huì)以JSON形式保存到此目錄下。/var/lib/docker/overlay2 目錄下含有容器的讀寫(xiě)層,如果容器使用自己的文件系統(tǒng)保存了數(shù)據(jù),那么就會(huì)寫(xiě)到此目錄下。
進(jìn)入到/var/lib/docker/containers
目錄下 通過(guò) du -h --max-depth=1
查找大文件占用,發(fā)現(xiàn)這些文件中占用空間最大的是***-json.log**文件。而此文件的內(nèi)容為docker生成的日志文件。
清理腳本:
#!/bin/bash echo "======== start clean docker containers logs ========" logs=$(find /var/lib/docker/containers/ -name *-json.log) for log in $logs do echo "clean logs : $log" cat /dev/null > $log done echo "======== end clean docker containers logs ========"
執(zhí)行完腳本之后,通過(guò)命令df -h
發(fā)現(xiàn) /var/lib/docker/overlay2/ID
的占用還是很大
由于構(gòu)建的鏡像,項(xiàng)目日志是存在本地的所以找到日志文件在本地的位置進(jìn)行清理項(xiàng)目日志文件減少磁盤(pán)占用
參考:
下面給大家補(bǔ)充介紹下docker overlay2占用大量磁盤(pán)空間處理方法
在使用docker時(shí),往往會(huì)出現(xiàn)磁盤(pán)空間不足,導(dǎo)致該問(wèn)題的通常原因是因?yàn)閐ocker中部署的系統(tǒng)輸出了大量的日志內(nèi)容。
此時(shí),可通過(guò)手動(dòng)或定時(shí)任務(wù)進(jìn)行清除。
針對(duì)/var/lib/docker/overlay2空間占用很大網(wǎng)上提供了很多解決方案,其中有些誤導(dǎo)的說(shuō)法需要去遷移路徑等操作。其實(shí)磁盤(pán)空間的占用和overlay沒(méi)關(guān)系(它的usage和真實(shí)的disk usage相同),它只是一個(gè)docker的虛擬文件系統(tǒng),真實(shí)的文件系統(tǒng)是前者/dev/vda1,可以看到路徑所指為根目錄,所以你要去找是哪里出現(xiàn)了垃圾。
通常情況下與overlay2的同級(jí)目錄下會(huì)有如下的目錄:
[root@iZ docker]# ls builder buildkit containerd containers image network overlay2 plugins runtimes swarm tmp trust volumes
而往往占用大量空間的日志文件位于containers下,該目錄下存在如下目錄:
[root@iZ containers]# ls 123ace927dc96745bac8ae09d0feddbdef853ff089c831bc80547b2d1115b0ac 635619a5ce22b551c5c75095b8b01647b9a02c839be64cd465e1542bfbec8ee6 a979b62fc10ab0ac54af4799d40c2c5865099883ff124012328ab3a8587c1dda
在目錄中會(huì)存在以目錄名為前綴,以“-json.log”為后綴的目錄文件。使用如下命令會(huì)看到該文件的大?。?/p>
ll -h
然后可使用如下命令對(duì)該文件的內(nèi)容進(jìn)行清理:
cat /dev/null > *-json.log
清理完成可不重啟服務(wù),但如果允許建議重啟一下docker服務(wù)。
在此執(zhí)行df -h命令之后,你會(huì)發(fā)現(xiàn)overlay2所占的磁盤(pán)空間已經(jīng)減小。
參考閱讀:
到此這篇關(guān)于docker清理Overlay2占用磁盤(pán)空間的文章就介紹到這了,更多相關(guān)docker清理Overlay2占用磁盤(pán)空間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Docker容器跨主機(jī)通信overlay網(wǎng)絡(luò)的解決方案
- docker容器間跨宿主機(jī)通信-基于overlay的實(shí)現(xiàn)方法
- Docker跨主機(jī)容器通信overlay實(shí)現(xiàn)過(guò)程詳解
- 詳解Docker 容器跨主機(jī)多網(wǎng)段通信解決方案
- docker部署項(xiàng)目/var/lib/docker/overlay2目錄滿了該如何清理
- 如何通過(guò)DOCKER OVERLAY2目錄名查找容器名和容器ID
- Docker Overlay2磁盤(pán)空間占用過(guò)大清理的方法實(shí)現(xiàn)
- Docker 容器跨主機(jī)通信 overlay的詳細(xì)步驟
相關(guān)文章
Rancher無(wú)法添加主機(jī)問(wèn)題的解決方法
這篇文章主要給大家介紹了關(guān)于Rancher無(wú)法添加主機(jī)問(wèn)題的解決方法,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06docker build鏡像時(shí),無(wú)法訪問(wèn)網(wǎng)絡(luò)問(wèn)題
這篇文章主要介紹了docker build鏡像時(shí),無(wú)法訪問(wèn)網(wǎng)絡(luò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Docker安裝部署分布式數(shù)據(jù)庫(kù)?OceanBase的詳細(xì)過(guò)程
這篇文章主要介紹了Docker安裝部署分布式數(shù)據(jù)庫(kù)?OceanBase,快速的體驗(yàn) OceanBase 的自動(dòng)化部署過(guò)程,及了解 OceanBase 集群安裝成功后的目錄特點(diǎn)和使用方法,需要的朋友可以參考下2022-06-06docker?compose運(yùn)行微服務(wù)項(xiàng)目的方法
這篇文章主要介紹了docker?compose運(yùn)行微服務(wù)項(xiàng)目?,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08安裝harbor作為docker鏡像倉(cāng)庫(kù)的問(wèn)題
這篇文章主要介紹了安裝harbor作為docker鏡像倉(cāng)庫(kù),主要包括docker和docker-compose離線部署,安裝harbor作為本地的倉(cāng)庫(kù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06