• Docker Centos7 下建立 Docker 桥接网络


    为什么要让docker桥接物理网络?

    docker默认提供了一个隔离的内网环境,启动时会建立一个docker0的虚拟网卡,每个容器都是连接到docker0网卡上的。而docker0的ip段为172.17.0.1,若想让容器与宿主机同一网段的其他机器访问,就必须在启动docker的时候将某个端口映射到宿主机的端口上才行,例如:docker run -itd -p 22 centos。这是我们所不能接受的,想想每个应用都要绞尽脑汁的去设置端口,因为不能重复,如果应用有多端口那更是不堪设想啊。所以为了让容器与宿主机同一个网段,我们需要建立自己的桥接网络。

    centos7宿主机上建立Docker桥接物理网络过程

    宿主机网卡信息:
    name:eno16777736
    IP:192.168.0.70
    GATEWAY:192.168.0.1
    DNS:114.114.114.114

    1. 停止docker服务

    ~#:service docker stop
    

    2.删除docker0网卡

    ~#:ip link set dev docker0 down
    ~#:brctl delbr docker0
    

    3.新建桥接物理网络虚拟网卡br0

    ~#:brctl addbr br0
    ~#:ip link set dev br0 up
    ~#:ip addr add 192.168.0.71/24 dev br0 #为br0分配物理网络中的ip地址
    ~#:ip addr del 192.168.0.70/24 dev eno16777736 #将宿主机网卡的IP清空
    ~#:brctl addif br0 eno16777736 #将宿主机网卡挂到br0上  (若xshell端操作会断开,需进入vmware虚拟机进行操作)
    ~#:ip route add default via 192.168.0.1 dev br0 #为br0设置路由
    

    4.设置docker服务启动参数
    这里要注意的是,不同的linux操作系统docker的配置文件所在不同
    centos 在/etc/sysconfig/docker
    其他操作系统请前往下面的网址
    https://docs.docker.com/installation/#installation

    ~#:vim /etc/sysconfig/docker #在OPTIONS='--selinux-enabled'这行中修改为OPTIONS='--selinux-enabled -b=br0'即让docker服务启动时使用br0网卡进行桥接
    

    5.启动docker服务

    ~#:service docker start
    

    6.安装pipework

    ~#:git clone https://github.com/jpetazzo/pipework
    ~#:cp ~/pipework/pipework /usr/local/bin/
    

    7.启动一个手动设置网络的容器
    这里最好不要让docker自动获取ip,下次启动会有变化而且自动获取的ip可能会和物理网段中的ip冲突

    ~#:docker run -itd --net=none --name=weifeng centos /bin/bash
    

    9.为weifeng容器设置一个与桥接物理网络同地址段的ip@网关

    ~#:pipework br0 weifeng 192.168.0.11/24@192.168.0.1
    

    10.进入容器查看ip

    ~#:docker exec -it weifeng /bin/bash

    [root@aa02eef3da60 /]# yum install -y net-tools

     [root@aa02eef3da60 /]# ifconfig

    eth1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500

            inet 192.168.0.11  netmask 255.255.255.0  broadcast 192.168.0.255

            inet6 fe80::1451:5fff:fe49:fc67  prefixlen 64  scopeid 0x20<link>

            ether 16:51:5f:49:fc:67  txqueuelen 1000  (Ethernet)

            RX packets 4359  bytes 15003532 (14.3 MiB)

            RX errors 0  dropped 0  overruns 0  frame 0

            TX packets 3517  bytes 243282 (237.5 KiB)

            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

    lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536

            inet 127.0.0.1  netmask 255.0.0.0

            inet6 ::1  prefixlen 128  scopeid 0x10<host>

            loop  txqueuelen 0  (Local Loopback)

            RX packets 0  bytes 0 (0.0 B)

            RX errors 0  dropped 0  overruns 0  frame 0

            TX packets 0  bytes 0 (0.0 B)

            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0


    参考文章:https://testerhome.com/topics/2648
    
    
  • 相关阅读:
    Mysql学习笔记
    【转】数据库设计:物理结构设计
    primary key与unique的区别
    服务器端口
    事务 脏读、不可重复读、幻影读的分析
    数据库 count和sum区别
    c#局域网聊天软件的实现
    使用jstack分析java程序cpu占用率过高
    典型的垃圾收集器
    垃圾收集算法
  • 原文地址:https://www.cnblogs.com/weifeng1463/p/7468497.html
Copyright © 2020-2023  润新知