目錄
- 問題復現
- 解決方法
- 總結
問題復現
使用:
sudo docker ps -a
查看當前的docker容器:
我們想啟動name為【docker-mongo】的這個容器,因此要執行
sudo docker start docker-mongo
但是執行后仍舊沒有重啟,大概率是重啟的時候報錯了,查看日志:
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 # 變為管理員權限 cd /var/lib/docker/overlay2/457e851851b8ef6e1b56ebd89aaefab3133e8e1013adc59a98af72e6e5b93a51/diff rm mongodb-27017.sock exit # 退出root用戶
這里根據自己的情況對文件進行操作,一般是配置錯誤導致的docker重啟失敗
然后就可以重啟了:
sudo docker start docker-mongo sudo docker ps
重啟成功!