Docker网络原理

一、本篇侧重点

  1. docker0网络
  2. 自定义网络
  3. 网络连通
  4. 实战:搭建redis集群环境

二、docker0网络

首选看一下宿主机的网络情况

0

docker0属于是桥接网卡,在安装docker的时候自动会有docker0,所有镜像运行后,如果不使用–net指定网卡的话,docker默认分配docker0这个网卡。

后台运行一个tomcat镜像,并输出容器的网卡信息,然后用宿主机ping容器的ip地址

0

运行一个新的容器后,docker会在容器端和docker0上分配做个映射并且从宿主机上能够直接ping通容器,这种映射是成对出现的,这种技术叫veth-pair,就是一对的虚拟设备接口,他们都是成对出现的,一端连着协议,一端彼此相连,因为有这个特性 veth-pair 充当一个桥梁,连接各种虚拟网络设备的。

再启动一个tomcat2,然后用tomcat2去ping一下tomcat1

0

docker0的网络模型

0

Docker中所有网络接口都是虚拟的,虚拟的转发效率高(内网传递文件)

只要容器删除,对应的网桥一对就没了!

三、自定义网络

三、自定义网络

查看docker的网络

0

docker的网络模式有如下几种:

模式 说明
bridge 桥接 docker(默认,自己创建也是用bridge模式)
none 不配置网络,一般不用
host 和所主机共享网络
container 容器网络连通
docker run -d -P --name tomcat1 tomcat
等价于 => docker run -d -P --name tomcat1 --net bridge tomcat

# docker0,特点:默认,域名不能访问。
# 我们可以 自定义一个网络
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
0
# 查看mynet网络信息
docker network inspect mynet
0

再启动2个tomcat的镜像,并指定mynet网络

0

再次查看mynet网卡信息时,可以看到tomcat3和tomcat4的网卡信息已经配置到了mynet网络中了,而且在mynet网络下,2个tomcat可以相互ping通

0

使用自定义网络可以保证不同网络下容器之间的安全和健康,并且方便管理使用docker搭建起来的集群!

四、网络连通

# docker network connect 命令能够使一个没有指定网卡的容器连通到某个网络内
# 新启动一个容器,ping一下在mynet中的tomcat4,然后将tomcat7添加到mynet网络中,再ping下tomcat4,观察变化
0 0

五、搭建redis集群环境

搭建Cluster模式的redis集群环境预计6台redis;

# 创建网卡
docker network create redis-net --subnet 172.10.0.0/16

# 通过脚本创建六个redis配置
for port in $(seq 1 6);\
do \
mkdir -p /usr/local/redis-cluster/node-${port}/conf
touch /usr/local/redis-cluster/node-${port}/conf/redis.conf
cat << EOF >> /usr/local/redis-cluster/node-${port}/conf/redis.conf
port 6379
bind 0.0.0.0
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 172.10.0.1${port}
cluster-announce-port 6379
cluster-announce-bus-port 16379
appendonly yes
EOF
done

# 运行六个redis
docker run -p 6371:6379 -p 16371:16379 --name redis-1 -v /usr/local/redis-cluster/node-1/data:/data -v /usr/local/redis-cluster/node-1/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.11 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

docker run -p 6372:6379 -p 16372:16379 --name redis-2 -v /usr/local/redis-cluster/node-2/data:/data -v /usr/local/redis-cluster/node-2/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.12 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

docker run -p 6373:6379 -p 16373:16379 --name redis-3 -v /usr/local/redis-cluster/node-3/data:/data -v /usr/local/redis-cluster/node-3/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.13 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

docker run -p 6374:6379 -p 16374:16379 --name redis-4 -v /usr/local/redis-cluster/node-4/data:/data -v /usr/local/redis-cluster/node-4/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.14 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

docker run -p 6375:6379 -p 16375:16379 --name redis-5 -v /usr/local/redis-cluster/node-5/data:/data -v /usr/local/redis-cluster/node-5/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.15 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

docker run -p 6376:6379 -p 16376:16379 --name redis-6 -v /usr/local/redis-cluster/node-6/data:/data -v /usr/local/redis-cluster/node-6/conf/redis.conf:/etc/redis/redis.conf -d --net redis-net --ip 172.10.0.16 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf

# 进入正在运行的redis-1容器内
# redis默认没有bash
docker exec -it redis-1 /bin/sh 

# 配置集群模式
redis-cli --cluster create 172.10.0.11:6379 172.10.0.12:6379 172.10.0.13:6379 172.10.0.14:6379 172.10.0.15:6379 172.10.0.16:6379  --cluster-replicas 1
0 0

评论
 本篇
Docker网络原理 Docker网络原理
一、本篇侧重点 docker0网络 自定义网络 网络连通 实战:搭建redis集群环境 二、docker0网络首选看一下宿主机的网络情况 docker0属于是桥接网卡,在安装docker的时候自动会有docker0,所有镜像运行后
2021-06-01
下一篇 
Docker数据卷技术 Docker数据卷技术
一、本篇侧重点 数据卷容器 Docker的具名挂载、匿名挂载、指定路径挂载 Dockerfile Dockerfile指令说明 实战:Dockerfile构建带http-flv模块的nginx镜像 二、数据卷容器 话不多说先上图!
2021-05-25
  目录