docker原理解析(1):Docker桥接网络

docker引擎会默认创建一个docker0网桥,它在内核层连通了其他的物理或虚拟网卡,这就将所有容器和宿主机都放到同一个二层网络。

1. docker如何使用网桥

1.1 Linux虚拟网桥的特点

网桥工作在二层(OSI堆栈),是通用网络设备的一种,可以设置IP地址。有了IP地址,Linux便可通过路由表或IP表,在网络层定位网桥,这就相当于有了一个虚拟网卡,即docker0。docker0默认的地址划分:

IP127.17.42.1/16

MAC : 02:42:ac:11:00:0002:42:ac:11:ff:ff,共65534个地址

1.2 docker0网桥连接方式

这里写图片描述

网络配置过程如下:

a. 在宿主机上创建一对虚拟网卡veth pair设备。veth设备总是成对出现的,它们组成了一个数据的通道,数据从一个设备进入,就会从另一个设备出来。因此,veth设备常用来连接两个网络设备。

b. 在容器启动时,Docker引擎将veth pair设备的一端放在新创建的容器中,并命名为eth0。另一端放在宿主机中,以veth***这样类似的名字命名,并将这个网络设备加入到docker0网桥中,可以通过brctl show命令查看。

c. 从docker0子网中分配一个IP给容器使用,并设置docker0的IP地址为容器的默认网关。


2. docker0网桥实现方式

2.1 查看docker0网桥

# yum install bridge-utils   

// 查看主机网桥信息
# brctl show                   

// 查看容器网卡信息
# docker run -d --name test locutus1/centos /bin/bash

cID#ifconfig                   
ctrl+p ; ctrl+q

// 在主机中查看,docker0开放的网络接口veth
# brctl show

# ifconfig                     

2.2 修改docker0网段

# ifconfig docker0 192.168.1.10/24 up  

// 验证docker0更改为目标网段
# ifconfig docker0                 

# service docker restart  

// 查看容器网络接口,验证是否更改为docker0网段            
# docker run -d --name test locutus1/centos /bin/bash

cID#ifconfig                      

2.3 自定义linux虚拟网桥br0

// 新增网桥br0                              
# brctl addbr br0   

# ifconfig br0 172.17.0.0/24 up    

// 修改docker启动配置文件(centos下,docker启动配置文件路径是/etc/sysconfig/docker),添加DOCKER_OPTS值,使docker启用新添加的网桥br0    
# vim /etc/sysconfig/docker

DOCKER_OPTS="-b=br0"         

// 修改docker守护进程配置文件,添加EnvironmentFile绝对路径与启动项$DOCKER_OPTS,其中“ - ”代表ignore error    
# vim /lib/systemd/system/docker.service   

EnvironmentFile=-/etc/sysconfig/docker        
ExecStart=/usr/bin/dockerd $DOCKER_OPTS 

// 重启所有守护进程。重新装载所有守护进程的unit文件,然后重新生成依赖关系树
# systemctl  daemon-reload   

# service docker restart

// 查看容器IP,验证其更改为br0网段   
# docker run -it --name test2 centos /bin/bash   

cID# yum install -y net-tools.x86_64   
cID# ifconfig                
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
      inet 172.17.0.2  netmask 255.255.0.0  broadcast 0.0.0.0
      inet6 fe80::42:acff:fe11:2  prefixlen 64  scopeid 0x20<link>
      ether 02:42:ac:11:00:02  txqueuelen 0  (Ethernet)
      RX packets 1188  bytes 7830677 (7.4 MiB)
      RX errors 0  dropped 0  overruns 0  frame 0
      TX packets 1073  bytes 73229 (71.5 KiB)
      TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在运行docker cp命令时,出现了“bash: docker: command not found”错误,这通常意味着你的系统中没有安装Docker或者Docker没有正确安装。你需要按照以下步骤来解决这个问题: 1. 首先,检查你的系统中是否已经安装了Docker。你可以在终端中输入以下命令来检查: ``` docker --version ``` 如果你看到了Docker的版本信息,那么说明Docker已经正确安装了。否则,你需要安装Docker。 2. 如果你需要安装Docker,请按照以下步骤进行操作: - 在终端中输入以下命令来安装Docker: ``` curl -fsSL https://get.docker.com -o get-docker.sh sudo sh get-docker.sh ``` - 安装完成后,你可以使用以下命令来检查Docker是否正确安装: ``` docker --version ``` 3. 如果你已经安装了Docker但仍然遇到了“bash: docker: command not found”错误,那么你需要检查Docker是否正确配置。你可以按照以下步骤进行操作: - 检查Docker服务是否正在运行: ``` sudo systemctl status docker ``` - 如果Docker服务没有运行,请使用以下命令启动它: ``` sudo systemctl start docker ``` - 如果你希望Docker服务在系统启动时自动启动,请使用以下命令: ``` sudo systemctl enable docker ``` - 确保你的用户已经被添加到Docker用户组中: ``` sudo usermod -aG docker your-user ``` 其中,your-user是你的用户名。 4. 如果你已经按照以上步骤操作但仍然遇到了问题,请尝试重新安装Docker或者升级Docker版本。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值