中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Docker 容器的網絡連接

發布時間:2020-08-26 10:54:46 來源:網絡 閱讀:199 作者:程序員果果 欄目:編程語言

文章首發于公眾號《程序員果果》
地址:https://mp.weixin.qq.com/s/DzF-ZwaY4QtlgM32I5wybg

一、Docker 容器的網絡基礎

docker0(Linux的虛擬網橋)

通過ifconfig查看docker0的網絡設備,docker守護進程就是通過docker0為docker的容器提供網絡連接的各種服務。

[root@localhost ~]# ifconfig docker0
docker0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
 ? ? ?  inet 172.17.0.1  netmask 255.255.0.0  broadcast 0.0.0.0
 ? ? ?  inet6 fe80::42:2fff:fe56:7b2e  prefixlen 64  scopeid 0x20<link>
 ? ? ?  ether 02:42:2f:56:7b:2e  txqueuelen 0  (Ethernet)
 ? ? ?  RX packets 27406  bytes 2657911 (2.5 MiB)
 ? ? ?  RX errors 0  dropped 0  overruns 0  frame 0
 ? ? ?  TX packets 42036  bytes 58020300 (55.3 MiB)
 ? ? ?  TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

docker守護進程就是通過docker0為docker容器提供網絡連接的各種服務。docker0 就是Linux的虛擬網橋 。

OSI七層模型中的網橋:

Docker 容器的網絡連接

Linux虛擬網橋的特點:

  • 可以設置IP地址
  • 相當于擁有一個隱藏的虛擬網卡

docker0的地址劃分:

  • IP:172.17.42.1 子網掩碼: 255.255.0.0
  • MAC: 02:42:ac:11:00:00 到 02:42:ac:11:ff:ff
  • 總共提供65534個地址

docker守護進程在一個容器啟動時,實際上它要創建網絡連接的兩端。一端是在容器中的網絡設備,而另一端是在運行docker守護進程的主機上打開一個名為veth*的一個接口,用來實現docker這個網橋與容器的網絡通信。

Docker 容器的網絡連接

下面我們看一下實際的過程:
需要查看網橋,需要linux的網橋管理程序,在Ubuntu中通過 apt-get install bridge-utils。

$ sudo brctl show
bridge name    bridge id              STP    enabled    interfaces
docker0        8000.0242ed943d02      no

運行一個docker容器,在容器中查看它的網絡設備(如果沒有ifconfig命令,通過apt-get install -y net-tools)。

root@b2a3136f5425:/# ifconfig
eth0 Link encap:Ethernet HWaddr 02:42:ac:11:00:02 
inet addr:172.17.0.2 Bcast:0.0.0.0 Mask:255.255.0.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:145 errors:0 dropped:0 overruns:0 frame:0
TX packets:60 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0 
RX bytes:184985 (184.9 KB) TX bytes:4758 (4.7 KB)

lo Link encap:Local Loopback 
inet addr:127.0.0.1 Mask:255.0.0.0
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0 
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)

docker已經自動創建了eth0的網卡,注意觀察ip地址和mac地址。不要退出容器,再運行如下查看網橋的狀態。

$ sudo brctl show
bridge name    bridge id           STP    enabled    interfaces
docker0    8000.0242ed943d02       no                veth95521e6

我們看到在interface中多了一個veth*的這樣一個接口。通過ifconfig命令同樣可以看到這個網絡接口。

自定義 docker0

  • 修改docker0默認分配的ip地址
sudo ifconfig docker0 192.168.200.1 netmask 255.255.255.0

修改完后,重啟docker服務 sudo service docker restart. 新運行的容器地址就變成了新的ip地址了。

  • 添加虛擬網橋
sudo brctl addbr br0
sudo ifconfig br0 192.168.100.1 netmask 255.255.255.0

更改docker守護進程的啟動配置:

vim /etc/default/docker 中添加 DOCKER_OPS的值 -b=br0.

重啟docker服務即可。

二、Docker 容器的互聯

用于測試的Docker鏡像 Dockerfile:

FROM ubuntu:14.04
RUN apt-get install -y ping
RUN apt-get update
RUN apt-get install -y nginx
RUN apt-get install -y curl
EXPOSE 80
CMD /bin/bash
1. 允許所有容器互聯

在同一宿主機下,docker的容器是通過虛擬網橋來進行連接的。那么在默認情況下,在同一宿主機中運行的容器都是可以互相連接的。
--icc=true 默認
容器的ip地址實際上是一個不可靠的連接,因為它會隨著容器的啟動而改變

docker run --link=容器名:別名

查看在容器中產生的哪些影響

$ env

查看環境變量,可以看到大量以WEBTEST*開頭的環境變量,這些環境變量是在容器啟動時,由docker添加的。我們還可以查看在/ect/host文件,這里添加了webtest的地址映射。當docker重啟啟動容器時 /ect/host所對應的ip地址發生了變化。也就是說,
針對于指定了link選項的容器,在啟動時docker會自動修改ip地址和我們指定的別名之間的映射 。環境變量也會做出相應的改變。

2. 拒絕所有容器間互聯

Docker守護進程的啟動選項
--icc=false

修改vim /etc/default/docker,在末尾添加配置 DOCKER_OPTS="--icc=false"。

需要重啟docker的服務 sudo service docker restart.即使是link也ping不通。

3. 允許特定容器間的連接

Docker守護進程的啟動選項
--icc=false --iptables=true
--link 在容器啟動時添加link
docker利用iptables中的機制,在icc=false時,阻斷所有的docker容器間的訪問,僅僅運行利用link選項配置的容器進行相互的訪問。
注: 如果出現ping不通的情況,可能為iptables的問題(DROP規則在docker之前了)。

sudo iptables -L -n    查看iptables規則的情況
sudo iptables -F    清空iptables規則設置
sudo service docker restart 重新啟用docker的服務
sudo iptables -L -n 再來查看iptables的設置,docker的規則鏈已經在第一位

重新啟動容器即可。

歡迎關注我的公眾號《程序員果果》,關注有驚喜~~
Docker 容器的網絡連接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新乡市| 安陆市| 中宁县| 察隅县| 长岛县| 蛟河市| 明溪县| 长子县| 精河县| 祁连县| 桂林市| 黑山县| 民丰县| 汉川市| 阿勒泰市| 万宁市| 四子王旗| 高州市| 榆中县| 堆龙德庆县| 华宁县| 满城县| 襄汾县| 霍林郭勒市| 高陵县| 剑河县| 辛集市| 怀来县| 游戏| 灯塔市| 道真| 遵义县| 会同县| 华坪县| 淮滨县| 乌兰浩特市| 眉山市| 虎林市| 股票| 平邑县| 抚顺县|