Docker link實現容器互聯的方式

1.1、容器間通過IP進行網絡訪問

新建兩個容器tomcat01和tomcat02

docker run -d -P --name tomcat01 tomcat
docker run -d -P --name tomcat02 tomcat

在這裡插入圖片描述

使用 ifconfig 命令查看toncat01的網卡信息:

在這裡插入圖片描述

可以看到,tomcat01的IP地址為 172.17.0.2

再查看toncat02的網卡信息:

在這裡插入圖片描述

可以看到,tomcat02的IP地址為 172.17.03

測試容器tomcat01和tomcat02是否能ping通:

tomcat01 ping tomcat02:

在這裡插入圖片描述

tomcat02 ping tomcat01:

在這裡插入圖片描述

根據上面兩張圖所示,不管是tomcat01 ping tomcat02還是tomcat02 ping tomcat01都是可以ping通的。

註:如果容器內沒有ifconfig命令和ping命令,依次執行以下命令:

apt-get update
apt install iputils-ping
apt install net-tools

1.2、容器間通過容器名或容器id進行網絡訪問

容器間如果想通過容器名進行網絡連接,需要使用 docker run –link 來鏈接兩個容器。

–link可以用來鏈接2個容器,使得源容器(被鏈接的容器)和接收容器(主動去鏈接的容器)之間可以互相通信,並且接收容器可以獲取源容器的一些數據,如源容器的環境變量。

–link 的格式

--link <name or id>:alias

–link 添加到另一個容器的鏈接

name和id是源容器的name和id,alias是源容器在link下的別名。

–link 的使用實例

創建容器tomcat03,讓tomcat03作為接收容器(主動去鏈接的容器),上面的tomcat01(別名t1)作為源容器(被鏈接的容器),兩個容器進行鏈接:

docker run -d -P --name tomcat03 --link tomcat01:t1 tomcat

tomcat01 是上面啟動的 7b94f50c43ea 容器的名字,這裡作為源容器,t1 是該容器在link下的別名(alias),通俗易懂的講,站在tomcat03容器的角度,tomcat01 和 t1 都是 7b94f50c43ea 容器的名字,並且作為容器的hostname,tomcat03 用這2個名字中的哪一個都可以訪問到 7b94f50c43ea 容器並與之通信(docker通過DNS自動解析)。

進行鏈接測試:tomcat03 ping tomcat01

ping tomcat01

在這裡插入圖片描述

ping t1

在這裡插入圖片描述

兩個都能ping通,可見,tomcat01 和 t1 都指向172.17.0.2。

但上面這種鏈接隻是單向的,就是隻能接收容器鏈接源容器,源容器不能鏈接到接收容器,也就是 tomcat03 鏈接上瞭 tomcat01,tomcat03能ping通tomcat01,tomcat01並沒有鏈接上tomcat03,tomcat01ping不同tomcat03。但是不影響tomcat01 通過IP ping tomcat03 或者tomcat03 ping tomcat01。

–link 原理

查看 tomcat03 的 hosts 文件,操作系統規定,在進行DNS請求以前,先檢查系自己的hosts文件中是否有這個域名和IP的映射關系。如果有,則直接訪問這個IP地址指定的網絡位置,如果沒有,再向已知的DNS服務器提出域名解析請求。

docker exec -it tomcat03 cat /etc/hosts

在這裡插入圖片描述

在tomcat03的hosts配置文件中,可以看到映射瞭tomcat01的IP、容器名、別名和容器id,所有tomcat03可以通過指定的容器名和tomcat01進行通信。

–link 就是在接收容器(這裡是名為tomcat003的容器)添加瞭一條關於tomcat01容器的名稱解析。有瞭這個名稱解析後就可以不使用ip來和源容器通信瞭,除此之外當源容器重啟,docker會負責更新/etc/hosts文件,因此可以不用擔心容器重啟後IP地址發生瞭改變,解析無法生效的問題。

到此這篇關於Docker link實現容器互聯的文章就介紹到這瞭,更多相關docker 容器互聯內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: