大家好,今天分享一下docker 网络
查看镜像

删掉本机上所有的镜像
[root@localhost ~]# docker rmi -f $(docker images)
本机已经没有镜像了
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
也没有正在运行的容器
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
查看网络信息
[root@localhost ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
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 forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:87:af:a6 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.12/24 brd 192.168.1.255 scope global noprefixroute ens33
valid_lft forever preferred_lft forever
inet6 fe80::617f:ef93:80d4:e14e/64 scope link noprefixroute
valid_lft forever preferred_lft forever
3: ens37: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:87:af:b0 brd ff:ff:ff:ff:ff:ff
inet 172.16.2.1/24 brd 172.16.2.255 scope global noprefixroute ens37
valid_lft forever preferred_lft forever
inet6 fe80::a025:c647:1891:b2c6/64 scope link noprefixroute
valid_lft forever preferred_lft forever
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
link/ether 52:54:00:8e:d3:64 brd ff:ff:ff:ff:ff:ff
inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN group default qlen 1000
link/ether 52:54:00:8e:d3:64 brd ff:ff:ff:ff:ff:ff
6: docker0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default
link/ether 02:42:93:56:5f:89 brd ff:ff:ff:ff:ff:ff
inet 172.17.0.1/16 brd 172.17.255.255 scope global docker0
valid_lft forever preferred_lft forever
inet6 fe80::42:93ff:fe56:5f89/64 scope link
valid_lft forever preferred_lft forever
这是我们Linux主机上的本地环回口当中(用于本地的测试)
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
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 forever
这是我们Linux主机上的本地网卡(我是用它来上网的)
与公网通信
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:87:af:a6 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.12/24 brd 192.168.1.255 scope global noprefixroute ens33
valid_lft forever preferred_lft forever
inet6 fe80::617f:ef93:80d4:e14e/64 scope link noprefixroute
valid_lft forever preferred_lft forever
这是Linux主机上另外一张网卡(用于局域网内部通信)
3: ens37: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:87:af:b0 brd ff:ff:ff:ff:ff:ff
inet 172.16.2.1/24 brd 172.16.2.255 scope global noprefixroute ens37
valid_lft forever preferred_lft forever
inet6 fe80::a025:c647:1891:b2c6/64 scope link noprefixroute
valid_lft forever preferred_lft forever
这个是我们docker0的网卡,是我们docker容器网络的网关
5: docker0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default
link/ether 02:42:e3:cd:a4:c7 brd ff:ff:ff:ff:ff:ff
inet 172.17.0.1/16 brd 172.17.255.255 scope global docker0
valid_lft forever preferred_lft forever
inet6 fe80::42:e3ff:fecd:a4c7/64 scope link
valid_lft forever preferred_lft forever
运行一个Tomcat容器
[root@localhost ~]# docker run -d -P --name tomcat01 tomcat
Unable to find image 'tomcat:latest' locally
latest: Pulling from library/tomcat
0e29546d541c: Pull complete
9b829c73b52b: Pull complete
cb5b7ae36172: Pull complete
6494e4811622: Pull complete
668f6fcc5fa5: Pull complete
dc120c3e0290: Pull complete
8f7c0eebb7b1: Pull complete
77b694f83996: Pull complete
0f611256ec3a: Pull complete
4f25def12f23: Pull complete
Digest: sha256:9dee185c3b161cdfede1f5e35e8b56ebc9de88ed3a79526939701f3537a52324
Status: Downloaded newer image for tomcat:latest
WARNING: IPv4 forwarding is disabled. Networking will not work.
ea94a603d6d56ff71fc7d25977149e10fea52a70332e7c1387f0166d1cc4ca3e
查看镜像
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
tomcat latest fb5657adc892 5 months ago 680MB
运行容器
[root@localhost ~]# docker run -d -p 3355:8080 --name tomcat0144 tomcat
9e4458d25e3554de9755d1328c8339f259e20cfd1a0d5be203aba2bed2a4f214
[root@localhost ~]#
查看容器
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9e4458d25e35 tomcat "catalina.sh run" About a minute ago Up About a minute 0.0.0.0:3355->8080/tcp, :::3355->8080/tcp tomcat0144
这个容器的系统信息
[root@localhost ~]# docker inspect 9e4458d25e35
"IPAddress": "172.17.0.2", //这是tomcat容器的ip 地址,和docker0的地址同段
"IPPrefixLen": 16,
"IPv6Gateway": "",
"MacAddress": "02:42:ac:11:00:02",
我们在容器之外ping 容器的ip 地址
[root@localhost ~]# ping 172.17.0.2
PING 172.17.0.2 (172.17.0.2) 56(84) bytes of data.
64 bytes from 172.17.0.2: icmp_seq=1 ttl=64 time=0.079 ms
64 bytes from 172.17.0.2: icmp_seq=2 ttl=64 time=0.045 ms
64 bytes from 172.17.0.2: icmp_seq=3 ttl=64 time=0.049 ms
64 bytes from 172.17.0.2: icmp_seq=4 ttl=64 time=0.045 ms
64 bytes from 172.17.0.2: icmp_seq=5 ttl=64 time=0.047 ms
说明,本地Linux主机可以ping 通docker容器内部
我们每启动一个docker 容器 ,docker 就会给容器一个相关的ip 地址,而docker0是docker 网络的网关
只有成功安装了docker ,本地系统就会有一个docker0的网卡
docker 0的地址是docker 容器进行通信的网关

再启动一个nginx容器
[root@localhost ~]# docker run -d -P --name nginx022 nginx
Unable to find image 'nginx:latest' locally
latest: Pulling from library/nginx
Digest: sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31
Status: Downloaded newer image for nginx:latest
d80059a706cf286d87e8681b6e4d6aa9d7ce37cfbdcab94c5ffef3e97f5c8294
查看容器id
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d80059a706cf nginx "/docker-entrypoint.…" 18 seconds ago Up 12 seconds 0.0.0.0:49153->80/tcp, :::49153->80/tcp nginx022
9e4458d25e35 tomcat "catalina.sh run" 34 minutes ago Up 34 minutes 0.0.0.0:3355->8080/tcp, :::3355->8080/tcp tomcat0144
查看nginx容器的系统信息
[root@localhost ~]# docker inspect d80059a706cf
"Gateway": "172.17.0.1",
"IPAddress": "172.17.0.3",
进入nginx 容器
无法ping 通 tomcat 容器的ip
root@d80059a706cf:/# ping 172.17.0.2
bash: ping: command not found
好了,有关于docker网络的解释就到这里了,谢谢大家
1501

被折叠的 条评论
为什么被折叠?



