国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 建站經驗 > 正文

深入理解docker的四種網絡方式

2019-11-02 17:00:14
字體:
來源:轉載
供稿:網友

bridge方式(默認)

Host IP為186.100.8.117, 容器網絡為172.17.0.0/16

下邊我們看下docker所提供的四種網絡:

創建容器:(由于是默認設置,這里沒指定網絡--net="bridge"。另外可以看到容器內創建了eth0)

[root@localhost ~]# docker run -i -t mysql:latest /bin/bashroot@e2187aa35875:/usr/local/mysql# ip addr1: lo: mtu 65536 qdisc noqueue state UNKNOWN  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  inet 127.0.0.1/8 scope host lo    valid_lft forever preferred_lft forever  inet6 ::1/128 scope host    valid_lft forever preferred_lft forever75: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000  link/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff  inet 172.17.0.2/16 scope global eth0    valid_lft forever preferred_lft forever  inet6 fe80::42:acff:fe11:2/64 scope link    valid_lft forever preferred_lft forever

容器與Host網絡是連通的:

root@e2187aa35875:/usr/local/mysql# ping 186.100.8.117PING 186.100.8.117 (186.100.8.117): 48 data bytes56 bytes from 186.100.8.117: icmp_seq=0 ttl=64 time=0.124 ms

eth0實際上是veth pair的一端,另一端(vethb689485)連在docker0網橋上:

[root@localhost ~]# ethtool -S vethb689485NIC statistics:   peer_ifindex: 75[root@localhost ~]# brctl showbridge name   bridge id        STP enabled   interfacesdocker0     8000.56847afe9799    no       vethb689485

通過Iptables實現容器內訪問外部網絡:

[root@localhost ~]# iptables-save |grep 172.17.0.*-A POSTROUTING -s 172.17.0.0/16 ! -o docker0 -j MASQUERADE-A FORWARD -d 172.17.0.2/32 ! -i docker0 -o docker0 -p tcp -m tcp --dport 5000 -j ACCEPT

none方式

指定方法: --net="none"

可以看到,這樣創建出來的容器完全沒有網絡:

[root@localhost ~]# docker run -i -t --net="none" mysql:latest /bin/bashroot@061364719a22:/usr/local/mysql# ip addr1: lo: mtu 65536 qdisc noqueue state UNKNOWN  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  inet 127.0.0.1/8 scope host lo    valid_lft forever preferred_lft forever  inet6 ::1/128 scope host    valid_lft forever preferred_lft foreverroot@061364719a22:/usr/local/mysql# ping 186.100.8.117PING 186.100.8.117 (186.100.8.117): 48 data bytesping: sending packet: Network is unreachable

那這種方式,有什么用途呢?

實際上nova-docker用的就是這種方式,這種方式將網絡創建的責任完全交給用戶。

可以實現更加靈活復雜的網絡。

另外這種容器可以可以通過link容器實現通信。(后邊詳細說)

host方式

指定方法:--net="host"

這種創建出來的容器,可以看到host上所有的網絡設備。

容器中,對這些設備(比如DUBS)有全部的訪問權限。因此docker提示我們,這種方式是不安全的。

如果在隔離良好的環境中(比如租戶的虛擬機中)使用這種方式,問題不大。

container復用方式

指定方法: --net="container:name or id"

如下例子可以看出來,兩者的網絡完全相同。

[root@localhost ~]# docker run -i -t  mysql:latest /bin/bashroot@02aac28b9234:/usr/local/mysql# ip addr1: lo: mtu 65536 qdisc noqueue state UNKNOWN  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  inet 127.0.0.1/8 scope host lo    valid_lft forever preferred_lft forever  inet6 ::1/128 scope host    valid_lft forever preferred_lft forever77: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000  link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff  inet 172.17.0.3/16 scope global eth0    valid_lft forever preferred_lft forever  inet6 fe80::42:acff:fe11:3/64 scope link    valid_lft forever preferred_lft forever[root@localhost ~]# docker run -i -t --net="container:02aac28b9234" mysql:latest /bin/bashroot@02aac28b9234:/usr/local/mysql# ip addr1: lo: mtu 65536 qdisc noqueue state UNKNOWN  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  inet 127.0.0.1/8 scope host lo    valid_lft forever preferred_lft forever  inet6 ::1/128 scope host    valid_lft forever preferred_lft forever77: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000  link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff  inet 172.17.0.3/16 scope global eth0    valid_lft forever preferred_lft forever  inet6 fe80::42:acff:fe11:3/64 scope link    valid_lft forever preferred_lft forever
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 兴隆县| 循化| 肥西县| 松江区| 全椒县| 黄浦区| 漳平市| 黔西县| 临澧县| 唐海县| 常宁市| 日土县| 会泽县| 巴中市| 阆中市| 玉环县| 徐汇区| 杭锦后旗| 新沂市| 华亭县| 会同县| 乾安县| 湖北省| 东光县| 屯留县| 凤城市| 延寿县| 夏邑县| 阿克苏市| 故城县| 梨树县| 黄山市| 皮山县| 西安市| 新蔡县| 江川县| 百色市| 思茅市| 资兴市| 元阳县| 西充县|