關(guān)于docker清理Overlay2占用磁盤空間的問題(親測有效)
使用Docker過程中,長時間運(yùn)行服務(wù)容器,導(dǎo)致不能進(jìn)行上傳文件等操作,通過命令df -h 發(fā)現(xiàn)overlay占用較高。通過命令docker system prune -a 清理無用鏡像、緩存、掛載數(shù)據(jù),也沒有什么改變。
如果你也被這個問題所困擾,咱們就一起看一下 Docker 是如何使用磁盤空間的,以及如何回收。
docker 占用的空間可以通過下面的命令查看:
$ docker system df
prune指令默認(rèn)會清除所有如下資源:
- 已停止的容器(container)
- 未被任何容器所使用的卷(volume)
- 未被任何容器所關(guān)聯(lián)的網(wǎng)絡(luò)(network)
- 所有懸空鏡像(image)。

查詢 overlay的作用的時候知道:
容器的磁盤占用
每次創(chuàng)建一個容器時,都會有一些文件和目錄被創(chuàng)建,例如:
/var/lib/docker/containers/ID目錄,如果容器使用了默認(rèn)的日志模式,他的所有日志都會以JSON形式保存到此目錄下。/var/lib/docker/overlay2 目錄下含有容器的讀寫層,如果容器使用自己的文件系統(tǒng)保存了數(shù)據(jù),那么就會寫到此目錄下。
進(jìn)入到/var/lib/docker/containers 目錄下 通過 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í)行完腳本之后,通過命令df -h發(fā)現(xiàn) /var/lib/docker/overlay2/ID的占用還是很大

由于構(gòu)建的鏡像,項(xiàng)目日志是存在本地的所以找到日志文件在本地的位置進(jìn)行清理項(xiàng)目日志文件減少磁盤占用
參考:
下面給大家補(bǔ)充介紹下docker overlay2占用大量磁盤空間處理方法
在使用docker時,往往會出現(xiàn)磁盤空間不足,導(dǎo)致該問題的通常原因是因?yàn)閐ocker中部署的系統(tǒng)輸出了大量的日志內(nèi)容。
此時,可通過手動或定時任務(wù)進(jìn)行清除。
針對/var/lib/docker/overlay2空間占用很大網(wǎng)上提供了很多解決方案,其中有些誤導(dǎo)的說法需要去遷移路徑等操作。其實(shí)磁盤空間的占用和overlay沒關(guān)系(它的usage和真實(shí)的disk usage相同),它只是一個docker的虛擬文件系統(tǒng),真實(shí)的文件系統(tǒng)是前者/dev/vda1,可以看到路徑所指為根目錄,所以你要去找是哪里出現(xiàn)了垃圾。
通常情況下與overlay2的同級目錄下會有如下的目錄:
[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
在目錄中會存在以目錄名為前綴,以“-json.log”為后綴的目錄文件。使用如下命令會看到該文件的大?。?/p>
ll -h
然后可使用如下命令對該文件的內(nèi)容進(jìn)行清理:
cat /dev/null > *-json.log
清理完成可不重啟服務(wù),但如果允許建議重啟一下docker服務(wù)。
在此執(zhí)行df -h命令之后,你會發(fā)現(xiàn)overlay2所占的磁盤空間已經(jīng)減小。
參考閱讀:
到此這篇關(guān)于docker清理Overlay2占用磁盤空間的文章就介紹到這了,更多相關(guān)docker清理Overlay2占用磁盤空間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Docker容器跨主機(jī)通信overlay網(wǎng)絡(luò)的解決方案
- docker容器間跨宿主機(jī)通信-基于overlay的實(shí)現(xiàn)方法
- Docker跨主機(jī)容器通信overlay實(shí)現(xiàn)過程詳解
- 詳解Docker 容器跨主機(jī)多網(wǎng)段通信解決方案
- docker部署項(xiàng)目/var/lib/docker/overlay2目錄滿了該如何清理
- 如何通過DOCKER OVERLAY2目錄名查找容器名和容器ID
- Docker Overlay2磁盤空間占用過大清理的方法實(shí)現(xiàn)
- Docker 容器跨主機(jī)通信 overlay的詳細(xì)步驟
相關(guān)文章
docker build鏡像時,無法訪問網(wǎng)絡(luò)問題
這篇文章主要介紹了docker build鏡像時,無法訪問網(wǎng)絡(luò)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Docker安裝部署分布式數(shù)據(jù)庫?OceanBase的詳細(xì)過程
這篇文章主要介紹了Docker安裝部署分布式數(shù)據(jù)庫?OceanBase,快速的體驗(yàn) OceanBase 的自動化部署過程,及了解 OceanBase 集群安裝成功后的目錄特點(diǎn)和使用方法,需要的朋友可以參考下2022-06-06
docker?compose運(yùn)行微服務(wù)項(xiàng)目的方法
這篇文章主要介紹了docker?compose運(yùn)行微服務(wù)項(xiàng)目?,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08

