目錄
- 問題復現(xiàn)
- 解決方法
- 總結
問題復現(xiàn)
使用:
sudo docker ps -a
查看當前的docker容器:

我們想啟動name為【docker-mongo】的這個容器,因此要執(zhí)行
sudo docker start docker-mongo
但是執(zhí)行后仍舊沒有重啟,大概率是重啟的時候報錯了,查看日志:
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文件即可。但是問題是我們無法啟動docker,也無法進入到容器內部,所以就有兩種解決方案:
- 在不啟動容器的情況下,進入到容器的目錄中,然后對文件做操作
- 在啟動容器且不啟動應用的情況下,把容器“夯住”,進入容器內部調試
這里我們使用第一種解決方案
解決方法
首先查看docker的這個容器在硬盤上的目錄結構
sudo docker inspect docker-mongo
可以找到一段配置項:
"MergedDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/merged", "UpperDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/diff", "WorkDir": "/var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/work"
這便是容器與本地的地址映射(注意這個目錄大概率不會與ID類似,即不會包含“32f8a297fb99”這個字段,因此需要手動查看目錄與容器ID的對應關系),所以我們進入這個目錄:
cd /var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51
然后就可以找到與容器內文件相似的目錄結構了,比如我想刪除礙事的/tmp/mongodb-27017.sock文件,可以使用:
su # 變?yōu)楣芾韱T權限 cd /var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/diff rm mongodb-27017.sock exit # 退出root用戶
這里根據(jù)自己的情況對文件進行操作,一般是配置錯誤導致的docker重啟失敗
然后就可以重啟了:
sudo docker start docker-mongo sudo docker ps

重啟成功!






