docker ping不通宿主機怎麼辦
docker ping不通宿主機的解決方法:1、修改daemon.json;2、關閉防火牆;3、修改sysctl.conf;4、重設網橋即可。
本文操作環境:ubuntu16.04系統、Docker 20.10.11、Dell G3電腦。
docker ping不通宿主機怎麼辦?
Docker網橋模式ping不通宿主機
問題描述:
Docker
網路模式分為四種,一般我們不設定時預設為bridge
單橋模式,容器使用獨立的network Namespace
,並連接到docker0
虛擬網路卡。透過docker0
網橋以及Iptables nat
表格配置與宿主機通訊。
此時在堡壘機上進行測試,利用busybox
進行測試:
# 拉取镜像 docker pull busybox # 运行容器 docker run -itd --name busy_bridge busybox
指令docker network inspect bridge
檢視網路:
網路設定成功,進入容器內部,查看ip
,可以看到已經指派ip
,但是ping
外部網路時失敗,無法連接外部網路:
但是在自己本地或阿里雲上進行相同的測試發現能夠連通網絡,這是什麼問題導致的呢?
問題分析:
在網路上找了一個資料後很多都是重啟docker
,然後就能連上了,一般是因為修改了某個配置然後重啟起作用,這裡並沒有什麼作用。一般修改的分為幾種,以下一一試驗:
- 修改
#daemon.json
容器無法存取宿主機是因為網橋分配的網段和宿主機衝突了,需要修改daemon.json
進行指定分配,使用指令vim /etc/docker/daemon.json
進入後添加:
{"bip":"172.16.10.1/24"}
雖然重啟docker
並創建容器即可訪問,但是,原本堡壘機和容器分配的ip
一點衝突也沒有,該方法不行。
- 關閉防火牆
容器無法透過網橋存取宿主機,也無法存取外網,可能是防火牆阻止訪問,可以關閉防火牆或開啟某個連接埠。在伺服器上測試,開啟防火牆,發現容器確實無法存取百度首頁也確實無法存取宿主機,在關閉防火牆並重啟docker
後,容器就能正常存取了。
但是,堡壘機上的防火牆原本就是關閉的,該方法也沒用。
- 修改
sysctl.conf
# docker
主機內部網路正常,與其它主機的連接失效,其它主機不能連接docker
主機上映射的端口,docker
內部也無法連接外部主機,利用docker info
指令查看資訊發現報錯如下:
WARNING: IPv4 forwarding is disabled WARNING: bridge-nf-call-iptables is disabled WARNING: bridge-nf-call-ip6tables is disabled
使用指令vim /etc/sysctl.conf
編輯設定文件,在檔案中增加以下程式碼:
net.bridge.bridge-nf-call-ip6tables=1 net.bridge.bridge-nf-call-iptables=1 net.bridge.bridge-nf-call-arptables=1 net.ipv4.ip_forward=1
然後使用指令systemctl restart network
重啟網絡,再看看docker info
,警告消失。但是依舊沒有用,堡壘機上的容器還是無法透過網橋存取宿主機,無法存取外網。
- 重設網橋
在使用指令yum install bridge-utils
安裝工具後,利用 brctl show
查看網橋,可以發現:
利用docker network create [網橋名]
指令新橋發現其產生的bridge id
還是8000.0000000000
,在新網橋上建立容器,再次查看並沒有什麼變化,說明很可能是網橋的問題。
再次測試,此時網橋ip
為172.17.0.1
,容器ip
為172.0.0.2
,發現宿主功能ping
通網橋,但是無法連接容器,而容器無法連接網橋,無法連接宿主機,更別談外網了,所以這裡可以肯定是網橋出了問題。
问题解决
这里docker network
生成新的网桥不行,说明docker
的network
存在问题,我们利用刚才下载的bridge-utils
来创建网桥。
首先暂停docker
服务,利用指令:
service docker stop
添加网桥:
brctl addbr br0
添加ip
字段:
ip addr add 172.16.0.1/24 dev br0
启用网桥br0
:
ip link set dev br0 up
查看网络br0
:
修改docker
默认网桥:
vim /etc/docker/daemon.json
添加字段:
"bridge":"br0"
重启docker
:
service docker start
此时查看网桥:
在没有挂载容器前,依旧是8000.000000000000
。运行测试容器:
docker run -itd --name busy_test busybox
查看docker ping不通宿主機怎麼辦:
此时容器挂载在网桥上了,再次查看网桥id
:
说明已经其作用,进入测试容器内部,docker ping不通宿主機怎麼辦:
成功!
补充:这里使用docker network
新建网桥,没有用,发现新建网桥挂载容器后,其bridge id
依旧不变,没有起作用,说明堡垒机上的docker network
可能存在问题。
问题补充:
上面的问题是创建自定义网桥,然后在自定义网桥上连接容器a
和b
,结果宿主机无法ping
通a
、b
,且进入容器内部后,两个容器无法ping
通自定义网络,但能彼此相通。
查了很多资料,发现了这篇文章。博主说问题原因是系统内核的网桥模块bridge.ko
加载失败导致,解决问题的方案是升级内核或升级系统。
升级centos
内核参考这篇。
升级完成后,重装Docker
,自定义网桥和容器,成功!不再有网络问题。
推荐学习:《docker视频教程》
以上是docker ping不通宿主機怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

退出 Docker 容器的四種方法:容器終端中使用 Ctrl D 快捷鍵容器終端中輸入 exit 命令宿主機終端中使用 docker stop <container_name> 命令宿主機終端中使用 docker kill <container_name> 命令(強制退出)

可以通過以下步驟查詢 Docker 容器名稱:列出所有容器(docker ps)。篩選容器列表(使用 grep 命令)。獲取容器名稱(位於 "NAMES" 列中)。

Docker 中將文件拷貝到外部主機的方法:使用 docker cp 命令:執行 docker cp [選項] <容器路徑> <主機路徑>。使用數據卷:在主機上創建目錄,在創建容器時使用 -v 參數掛載該目錄到容器內,實現文件雙向同步。

重啟 Docker 容器的方法:獲取容器 ID(docker ps);停止容器(docker stop <container_id>);啟動容器(docker start <container_id>);驗證重啟成功(docker ps)。其他方法:Docker Compose(docker-compose restart)或 Docker API(參考 Docker 文檔)。

在 Docker 中啟動 MySQL 的過程包含以下步驟:拉取 MySQL 鏡像創建並啟動容器,設置根用戶密碼並映射端口驗證連接創建數據庫和用戶授予對數據庫的所有權限

Docker 容器啟動步驟:拉取容器鏡像:運行 "docker pull [鏡像名稱]"。創建容器:使用 "docker create [選項] [鏡像名稱] [命令和參數]"。啟動容器:執行 "docker start [容器名稱或 ID]"。檢查容器狀態:通過 "docker ps" 驗證容器是否正在運行。

在 Docker 中創建容器: 1. 拉取鏡像: docker pull [鏡像名] 2. 創建容器: docker run [選項] [鏡像名] [命令] 3. 啟動容器: docker start [容器名]
