網站首頁 編程語言 正文
前言
在前幾期我們介紹了 容器間的互聯可以使用 –Link 參數進行設置,這樣可以在容器內不只訪問ip,也可以訪問對應設置的 域名。先溫習下。操作之前先清除所有的容器。
–link
# 清除所有容器 $root@VM-8-11-ubuntu:~# docker stop $(docker ps -aq) && docker rm $(docker ps -aq) 88f8f241ca30 765ed1889bfa $root@VM-8-11-ubuntu:~# docker run -it --name=mybusy02 -d busybox 82aff31e56f3913b3fa883a08ec95960eff88fc9977360a67264c0d53180844b $root@VM-8-11-ubuntu:~# docker run -it --name mybusy --link mybusy02:mybusy-net -d busybox b77e9762314f868518f799d3c572dec0b2ce13a684de072fb9f9e925135f6459 $root@VM-8-11-ubuntu:~# docker exec -it mybusy ping mybusy-net PING mybusy-net (172.17.0.2): 56 data bytes 64 bytes from 172.17.0.2: seq=0 ttl=64 time=0.131 ms 64 bytes from 172.17.0.2: seq=1 ttl=64 time=0.069 ms 64 bytes from 172.17.0.2: seq=2 ttl=64 time=0.069 ms $root@VM-8-11-ubuntu:~# docker exec -it mybusy cat /etc/hosts 127.0.0.1 localhost ::1 localhost ip6-localhost ip6-loopback fe00::0 ip6-localnet ff00::0 ip6-mcastprefix ff02::1 ip6-allnodes ff02::2 ip6-allrouters 172.17.0.2 mybusy-net 09a4b97fc09d mybusy02 # 我們發現在hosts文件中加入了mybusy02 172.17.0.3 c73be07d21fb
我們發現是互聯了,但是如果mybusy02 想ping 通 mybusy 還需要一個–link。所以就很麻煩,而且官方也推薦我們不要使用 --link 這個參數了。
docker 0 不支持容器名訪問接下來我們就到了今天的重頭戲,自定義網絡了。
自定義網絡
# 主要涉及到的命令 $root@VM-8-11-ubuntu:~# docker network --help Usage: docker network COMMAND Manage networks Commands: connect Connect a container to a network create Create a network disconnect Disconnect a container from a network inspect Display detailed information on one or more networks ls List networks prune Remove all unused networks rm Remove one or more networks Run 'docker network COMMAND --help' for more information on a command. # 這是默認的網絡方式 brudge 就是docker 0的網橋 $root@VM-8-11-ubuntu:~# docker network ls NETWORK ID NAME DRIVER SCOPE cf05ea05d3bd bridge bridge local 0ab28e475dc6 host host local e4c628cc77db none null local
我們來使用create來創建自己的網橋網絡?;A
# --driver 設置network類型 --subnet 設置子網 /16 = 255*255 個ip 減去0.0 和 255.255 約等于65535 $root@VM-8-11-ubuntu:~# docker network create --driver=bridge --subnet=192.168.0.0/16 my-net 1b668a5439b207d2080d95bffe829139cfa2456d691c8019a245e7f9d5a56970 root@VM-8-11-ubuntu:~# docker network ls NETWORK ID NAME DRIVER SCOPE cf05ea05d3bd bridge bridge local 0ab28e475dc6 host host local 1b668a5439b2 my-net bridge local e4c628cc77db none null local # 查看網絡信息 $root@VM-8-11-ubuntu:~# docker network inspect my-net [ { "Name": "my-net", "Id": "1b668a5439b207d2080d95bffe829139cfa2456d691c8019a245e7f9d5a56970", "Created": "2021-12-01T09:47:21.410882291+08:00", "Scope": "local", "Driver": "bridge", "EnableIPv6": false, "IPAM": { "Driver": "default", "Options": {}, "Config": [ { "Subnet": "192.168.0.0/16" } ] }, "Internal": false, "Attachable": false, "Ingress": false, "ConfigFrom": { "Network": "" }, "ConfigOnly": false, "Containers": {}, "Options": {}, "Labels": {} } ]
上面我們介紹了創建網絡的方法以及查看的方法 接下來看看使用的方法
# 創建mybusy 容器設置 my-net網絡 $root@VM-8-11-ubuntu:~# docker run -it --name mybusy --net=my-net -d busybox 180fbc8b04627762a896d8a85d8cb67063c01a0f3ad8a11352ab4695b022c272 # 創建mybusy02 容器設置 my-net網絡 $root@VM-8-11-ubuntu:~# docker run -it --name mybusy02 --net=my-net -d busybox 3c08d592537a9593c960c9664b4724521658f26be7b658a6483e6fbfe30b58a7 # 在容器mybusy ping mybusy02 通了 $root@VM-8-11-ubuntu:~# docker exec -it mybusy ping mybusy02 PING mybusy02 (192.168.0.3): 56 data bytes 64 bytes from 192.168.0.3: seq=0 ttl=64 time=0.110 ms 64 bytes from 192.168.0.3: seq=1 ttl=64 time=0.070 ms
這時我們發現 他們兩互相ping通了,這就很完美了。再來看看下面的 my-net 的網絡配置
root@VM-8-11-ubuntu:~# docker network inspect my-net [ { "Name": "my-net", "Id": "1b668a5439b207d2080d95bffe829139cfa2456d691c8019a245e7f9d5a56970", "Created": "2021-12-01T09:47:21.410882291+08:00", "Scope": "local", "Driver": "bridge", "EnableIPv6": false, "IPAM": { "Driver": "default", "Options": {}, "Config": [ { "Subnet": "192.168.0.0/16" } ] }, "Internal": false, "Attachable": false, "Ingress": false, "ConfigFrom": { "Network": "" }, "ConfigOnly": false, "Containers": { # 這時我們發現 這兩個容器已經加入到這個網絡中了 "180fbc8b04627762a896d8a85d8cb67063c01a0f3ad8a11352ab4695b022c272": { "Name": "mybusy", "EndpointID": "12929182af47e619e3405cab9981ea1671a2bc31f77d3aa589ebcf2c912c12bc", "MacAddress": "02:42:c0:a8:00:02", "IPv4Address": "192.168.0.2/16", "IPv6Address": "" }, "3c08d592537a9593c960c9664b4724521658f26be7b658a6483e6fbfe30b58a7": { "Name": "mybusy02", "EndpointID": "61b08372535d751cee726fc01d4e300390e2a090dba20f1d21ba96385a7a621e", "MacAddress": "02:42:c0:a8:00:03", "IPv4Address": "192.168.0.3/16", "IPv6Address": "" } }, "Options": {}, "Labels": {} } ]
提問
在不同網絡的配置下的容器可以互聯嗎?
答案是可以的。我們可以使用 docker network connect 指令,以下為操作步驟
# 首先查看當前存在同一個網絡中mybusy mybusy02 兩個容器 $root@VM-8-11-ubuntu:~# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 3c08d592537a busybox "sh" 8 minutes ago Up 8 minutes mybusy02 180fbc8b0462 busybox "sh" 8 minutes ago Up 8 minutes mybusy # 創建一個在默認網絡中的 mybusy03 $root@VM-8-11-ubuntu:~# docker run -it --name mybusy03 -d busybox a95b57c96f400ed44efffcc938bccce15830fa1ab5b55716261e4588c14429cb # 查看當前的容器 $root@VM-8-11-ubuntu:~# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES a95b57c96f40 busybox "sh" 21 seconds ago Up 21 seconds mybusy03 3c08d592537a busybox "sh" 8 minutes ago Up 8 minutes mybusy02 180fbc8b0462 busybox "sh" 9 minutes ago Up 9 minutes mybusy # 嘗試從 mybusy ping mybusy03 發現是ping 不通的 因為不在同一網端中 $root@VM-8-11-ubuntu:~# docker exec -it mybusy ping mybusy03 ping: bad address 'mybusy03' # 這時我們查看docker network connect --help 命令查看 $root@VM-8-11-ubuntu:~# docker network connect --help Usage: docker network connect [OPTIONS] NETWORK CONTAINER Connect a container to a network Options: --alias strings Add network-scoped alias for the container --driver-opt strings driver options for the network --ip string IPv4 address (e.g., 172.30.100.104) --ip6 string IPv6 address (e.g., 2001:db8::33) --link list Add link to another container --link-local-ip strings Add a link-local address for the container # 將mybusy03 加入到 my-net 網絡中 $root@VM-8-11-ubuntu:~# docker network connect my-net mybusy03 # 這時我們再 ping 發現通了。是不是很神奇 $root@VM-8-11-ubuntu:~# docker exec -it mybusy ping mybusy03 PING mybusy03 (192.168.0.4): 56 data bytes 64 bytes from 192.168.0.4: seq=0 ttl=64 time=0.197 ms 64 bytes from 192.168.0.4: seq=1 ttl=64 time=0.087 ms
這時我們查看網絡發現 mybusy03 已經加入到 my-net中去了。所以就可以ping 通了。
原文鏈接:https://blog.csdn.net/qq_32798897/article/details/121647630
相關推薦
- 2022-09-17 docker資源控制管理Cgroup的實現_docker
- 2022-08-13 Android自定義ProgressBar實現漂亮的進度提示框_Android
- 2023-07-03 利用ant-design下拉選擇框select的labelInValue屬性給下拉選項添加圖標
- 2023-03-03 C語言malloc與calloc區別詳解_C 語言
- 2023-03-05 Go語言學習之golang-jwt/jwt的教程分享_Golang
- 2022-06-10 C#關鍵字Check簡單介紹_C#教程
- 2023-03-23 Python?shutil模塊實現文件的裁剪、壓縮與解壓縮的方法_python
- 2022-01-21 面試題:說一說es6新增方法
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支