溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)

發(fā)布時(shí)間:2023-03-13 14:14:09 來源:億速云 閱讀:134 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)”文章能幫助大家解決問題。

問題復(fù)現(xiàn)

使用:

sudo docker ps -a

查看當(dāng)前的docker容器:

docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)

我們想啟動(dòng)name為【docker-mongo】的這個(gè)容器,因此要執(zhí)行

sudo docker start docker-mongo

但是執(zhí)行后仍舊沒有重啟,大概率是重啟的時(shí)候報(bào)錯(cuò)了,查看日志:

sudo docker logs -f docker-mongo

可以看到其中有這樣的日志:

{"t":{"$date":"2022-12-29T00:35:32.551+00:00"},"s":"E",  "c":"NETWORK",  "id":23024,   "ctx":"initandlisten",
"msg":"Failed to unlink socket file",
"attr":
	{"path":"/tmp/mongodb-27017.sock",
	"error":"Operation not permitted"
	}
}

查到的解決方法是刪除/tmp/mongodb-27017.sock文件即可。但是問題是我們無法啟動(dòng)docker,也無法進(jìn)入到容器內(nèi)部,所以就有兩種解決方案:

  • 在不啟動(dòng)容器的情況下,進(jìn)入到容器的目錄中,然后對(duì)文件做操作

  • 在啟動(dòng)容器且不啟動(dòng)應(yīng)用的情況下,把容器“夯住”,進(jìn)入容器內(nèi)部調(diào)試

這里我們使用第一種解決方案

解決方法

首先查看docker的這個(gè)容器在硬盤上的目錄結(jié)構(gòu)

sudo docker inspect docker-mongo

可以找到一段配置項(xiàng):

"MergedDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/merged",
"UpperDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/diff",
"WorkDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/work"

這便是容器與本地的地址映射(注意這個(gè)目錄大概率不會(huì)與ID類似,即不會(huì)包含“32f8a297fb99”這個(gè)字段,因此需要手動(dòng)查看目錄與容器ID的對(duì)應(yīng)關(guān)系),所以我們進(jìn)入這個(gè)目錄:

cd /var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51

然后就可以找到與容器內(nèi)文件相似的目錄結(jié)構(gòu)了,比如我想刪除礙事的/tmp/mongodb-27017.sock文件,可以使用:

su # 變?yōu)楣芾韱T權(quán)限
cd /var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/diff
rm mongodb-27017.sock
exit # 退出root用戶

這里根據(jù)自己的情況對(duì)文件進(jìn)行操作,一般是配置錯(cuò)誤導(dǎo)致的docker重啟失敗

然后就可以重啟了:

sudo docker start docker-mongo
sudo docker ps

docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)

重啟成功!

關(guān)于“docker容器因報(bào)錯(cuò)無法啟動(dòng)問題怎么檢查及修復(fù)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI