(二)Docker的网络通讯,容器卷,通信卷~~~玩转它!!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

一、Docker 网络模式

1、docker容器的虚拟网关

  1. loopback:回环网卡、TCP/IP网卡是否生效
  2. virtual bridge: linux
    自身继承了一个虚拟化功能(kvm架构),是原生架构的一个虚拟化平台,安装了一个虚拟化平台之后就会系统就会自动安装虚拟网卡
    (示例:安装workstation ( 虚拟化平台)之后,会在网络适配器中会多出VMnet1、VMnet8、VMnet0)
  3. docker 0:容器的网关,绑定物理网卡,负责做NAT地址转换、端口映射;docker0本身也是一种容器
  4. veth对:一组虚拟设备,用户连接两个不同的名称空间;宿主机内就是veth在这里插入图片描述
    在这里插入图片描述

2、Docker的网络模式

1. Host模式:-net=host;容器和宿主机共享Network namespace(网络名称空间/网络协议栈)
2. Container模式:-net=container:NAME or ID;多个容器共享一 个Network namespace 。
3. None模式:-net=none;容器有独立的Network namespace,但并没有对其进行任何网络设置,如分配veth pair和网桥连接,配置IP等(自闭空间)
4. Bridge模式:-net=bridge(默认为该模式);默认模式通过Veth对连接容器与docker0网桥,网桥分配给容器IP,同时docker 0作为“局域网”内容器的网关,最后和宿主机网卡进行通讯

以上不需要动手配置,真正需要配置的是自定义网络

3、Docker自定义网络

1. docker network ls ##查看网络列表
在这里插入图片描述
2. 查看容器IP

docker inspect  镜像id		##查看镜像状态

实例:
docker inspect 8652b9f0cb4c
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

docker exec centos ps aux		##使用exec执行命令
docker inspect centos		##这时可以使用指定的名称查看

在这里插入图片描述

在这里插入图片描述

  1. 自定义网络固定IP
docker run -itd --name test1 --network bridge --ip 172.17.0.10 centos:latest /bin/bash
	--network:指定网络类型
	--ip:指定ip地址

下图发现这种方式会报错:只能遵守默认的分配地址方式;无法指定
在这里插入图片描述
①:先自定义网络模式

docker network create --subnet=172.18.0.0/16 mynetwork		##创建172.18.0.0/16的网段

在这里插入图片描述
②:网络模式内加入指定的ip地址

docker run -itd --name centos-3 --net mynetwork --ip 172.18.0.10 centos:latest /bin/bash
docker inspect centos-3

在这里插入图片描述
在这里插入图片描述
4. 暴露端口

docker pull nginx
docker run -itd nginx:latest /bin/bash
这时查询虽然有80端口但是无法打开网页

在这里插入图片描述
①:-p:指定端口

docker run -itd -p 444:80 nginx /bin/bash	##暴露出来的端口是444
docker exec ef89e9321985 nginx		##需要把nginx运行起来

在这里插入图片描述
在这里插入图片描述
这时查看页面192.168.35.70:4040已可以访问网页
在这里插入图片描述
②:-P:随机端口

docker run -itd -P nginx /bin/bash	##指定随机的端口,下图显示模式从49153的位置给容器做地址映射
docker exec 3a8b665269df nginx		##仍需要重新开启

在这里插入图片描述
在这里插入图片描述
页面仍然存在
在这里插入图片描述
5. 在宿主机环境执行容器内命令

docker exec -it 容器ID /bin/bash -c 'nginx'
docker exec 容器ID/容器 name 执行的命令

二、Docker数据卷

1、数据卷

数据卷是一个提供容器使用的特殊目录

创建数据卷
docker run -d -v /data1 -v /data2 --name web httpd:centos
挂载主机目录作为数据卷
docker run -d -v /var/www:/data1 --name web-1 httpd:centos

实例:

docker pull centos
docker run -v /var/www:/data1 -v /var/html:/data2 -it --name centos-v4 centos:7 /bin/bash	##宿主机目录/var/www挂载容器中的/data1,/var/html挂载容器中的/data2
cd /data1
touch 1.txt
cd /data2
touch 2.txt
ls /var/www/		##返回宿主机进行查看

在这里插入图片描述

2、数据卷容器

就是一个普通的容器,实现容器间的互联互通

①:数据卷容器
docker run --name web11 -v /data1 -v /data2 -it centos /bin/bash 	##创建data1卷、data2卷
②:新容器挂载数据卷容器web100
docker run -it --volumes-from web11 --name qq centos /bin/bash	 ##允许一个容器,指定卷来源于web11,新的容器名字qq

实例:
容器web11内:
在这里插入图片描述
新的容器qq:
在这里插入图片描述

3、容器互联(使用centos镜像)

docker run -itd -P --name webb centos /bin/bash 		##创建并运行容器取名web1,端口号自动映射
docker run -itd -P --name web2 --link webb:webb centos /bin/bash	##创建并运行容器取名web2,链接到web1和其通信
	--link:打通隧道
yum -y install net-tools	##各自下载ifconfig的工具
验证:
进web2容器 ping webb

在这里插入图片描述

webb:
在这里插入图片描述
web2:
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值