Linux服務(wù)器安裝Docker,啟動(dòng)失敗問(wèn)題的解決
背景
Docker啟動(dòng)失敗的原因和使用了阿里云的源有關(guān)。
如果大家有使用到阿里云的源倉(cāng)庫(kù),可以繼續(xù)看下是否也可以解決問(wèn)題。
啟動(dòng)失敗
在Linux服務(wù)器上安裝docker,執(zhí)行docker 和docker version沒(méi)有問(wèn)題。
但是執(zhí)行docker images等命令報(bào)錯(cuò),按照提示首先
執(zhí)行:systemctl status docker
可以看到,報(bào)錯(cuò)信息為“無(wú)法啟動(dòng)Docker應(yīng)用的容器引擎”,這里其實(shí)只能看到啟動(dòng)失敗,狀態(tài)為failed,沒(méi)有更多提示信息。
查看具體報(bào)錯(cuò) & 解決
執(zhí)行命令:dockerd
這時(shí),我們發(fā)現(xiàn)已經(jīng)找到了正確的debug方式了:這里報(bào)錯(cuò)的具體信息為“啟動(dòng)守護(hù)進(jìn)程時(shí),初始化graphdriver失敗:overlay2.override_kernel_check選項(xiàng)未知”。
這時(shí)我們需要去daemon的json配置文件:/etc/docker/daemon.json,將stroage-driver替換一下。
{ "exec-opts": ["native.cgroupdriver=systemd"], "log-driver": "json-file", "log-opts": { "max-size": "100m" }, "storage-driver": "overlay2", "storage-opts": [ "overlay2.override_kernel_check=true" ] ## 替換成下面 "storage-driver": "overlay" }
然后嘗試啟動(dòng)docker:systemctl start docker ,同樣用dockerd命令看到有以下錯(cuò)誤:
這里意思是:
“守護(hù)進(jìn)程初始化網(wǎng)絡(luò)控制器報(bào)錯(cuò):地址列表沒(méi)有可用的IP”。
這是為什么呢?這是因?yàn)镈ocker會(huì)檢查bridge list里的IP,如果發(fā)現(xiàn)有和服務(wù)器或者路由表IP有重疊,就會(huì)丟棄該IP,導(dǎo)致報(bào)錯(cuò)。
這時(shí),我們查看阿里云服務(wù)器路由表:route -n
可以看到,172網(wǎng)段其實(shí)是和Docker的list bridge里有重疊。
所以我們可以手動(dòng)增加網(wǎng)卡,如圖中所示:
sudo ip link add name docker0 type bridge sudo ip addr add dev docker0 172.17.0.1/16
再重啟docker應(yīng)該就可以了:systemctl start docker
設(shè)置docker開(kāi)機(jī)自啟動(dòng):systemctl enable docker
總結(jié)
我這邊遇到的問(wèn)題和解決方法就是上面這樣。
也可以參考這篇文章:http://www.dbjr.com.cn/article/280108.htm
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Docker在線(xiàn)、離線(xiàn)安裝及其常用命令操作
這篇文章主要介紹了Docker在線(xiàn)、離線(xiàn)安裝及其常用命令操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11淺談Docker Desktop for Linux和Docker Engine
本文主要介紹了Docker Desktop for Linux和Docker Engine區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10Linux下docker 容器退出bash的兩種實(shí)現(xiàn)方法
這篇文章主要介紹了Linux下docker 容器退出bash的兩種實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11ubuntu vps安裝docker報(bào)錯(cuò):Cannot connect to the Docker daemon at
這篇文章主要介紹了解決ubuntu vps安裝docker時(shí)報(bào)錯(cuò):Cannot connect to the Docker daemon at unix:///var/run/docker.sock.問(wèn)題的相關(guān)資料,文中介紹非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-04-04docker 中的–mount 和-v 參數(shù)區(qū)別解析
這篇文章主要介紹了docker 中的–mount 和-v 參數(shù)區(qū)別解析,--mount 更為靈活,適用于更復(fù)雜的掛載需求,使用哪種方式主要取決于個(gè)人或團(tuán)隊(duì)的偏好和具體的使用場(chǎng)景,需要的朋友可以參考下2023-12-12docker部署redis報(bào)錯(cuò)內(nèi)存分配過(guò)度解決辦法
Docker很適合用于測(cè)試發(fā)布,將Docker封裝后可以直接提供給測(cè)試人員進(jìn)行運(yùn)行,不再需要測(cè)試人員與運(yùn)維、開(kāi)發(fā)進(jìn)行配合,進(jìn)行環(huán)境搭建與部署,這篇文章主要給大家介紹了關(guān)于docker部署redis報(bào)錯(cuò)內(nèi)存分配過(guò)度的解決辦法,需要的朋友可以參考下2023-11-11Docker使用過(guò)程中的一些注意事項(xiàng)
這篇文章主要為大家介紹了在使用Docker過(guò)程中的一些注意事項(xiàng),就個(gè)人的一些經(jīng)驗(yàn)分享給大家,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-10-10