Docker配置橋接網路
為了使本地網路中的機器和Docker容器更方便的通訊,我們經常會有將Docker容器配置到和主機同一網段的需求。這個需求其實很容易實現,我們只要將Docker容器和宿主機的網絡卡橋接起來,再給Docker容器配上IP就可以了。
Centos 6按照下面的方法操作(6與7的操作有所不同)
[root@localhost ~]# cd /etc/sysconfig/network-scripts/
[root@localhost network-scripts]# ls
ifcfg-eth0 ifdown-ib ifdown-ppp ifup-aliases ifup-ipv6 ifup-ppp init.ipv6-global
ifcfg-lo ifdown-ippp ifdown-routes ifup-bnep ifup-isdn ifup-routes net.hotplug
ifdown ifdown-ipv6 ifdown-sit ifup-eth ifup-plip ifup-sit network-functions
ifdown-bnep ifdown-isdn ifdown-tunnel ifup-ib ifup-plusb ifup-tunnel network-functions-ipv6
ifdown-eth ifdown-post ifup ifup-ippp ifup-post ifup-wireless
[root@localhost network-scripts]# cp ifcfg-eth0 ifcfg-br0
[[email protected] network-scripts]# vi ifcfg-eth0
DEVICE=eth0
HWADDR=00:0C:29:DB:B2:28
TYPE=Ethernet
UUID=b2268aab-fa2e-49e9-bd67-2572f29e5790
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
IPADDR=192.168.1.179
NETMASK=255.255.255.0
GATEWAY=192.168.1.1
DNS1=114.114.114.114
DNS2 =8.8.4.4
增加BRIDGE=br0,刪除IPADDR、NETMASK、GATEWAY、DNS
DEVICE=eth0
HWADDR=00:0C:29:DB:B2:28
TYPE=Ethernet
UUID=b2268aab-fa2e-49e9-bd67-2572f29e5790
ONBOOT=yes
BRIDGE=br0
BOOTPROTO=none
#IPADDR=192.168.1.179
#NETMASK=255.255.255.0
#GATEWAY=192.168.1.1
#DNS1=114.114.114.114
#DNS2=8.8.4.4
儲存退出
[[email protected] network-scripts]# vi ifcfg-br0
DEVICE=eth0
HWADDR=00:0C:29:DB:B2:28
TYPE=Ethernet
UUID=b2268aab-fa2e-49e9-bd67-2572f29e5790
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
IPADDR=192.168.1.179
NETMASK=255.255.255.0
GATEWAY=192.168.1.1
DNS1=114.114.114.114
DNS2=8.8.4.4
修改DEVICE為br0,Type為Bridge,把eth0的網路設定設定到這裡來
DEVICE=br0
TYPE=Bridge
ONBOOT=yes
BOOTPROTO=static
IPADDR=192.168.1.179
NETMASK=255.255.255.0
GATEWAY=192.168.1.1
DNS1=114.114.114.114
DNS2=8.8.4.4
儲存退出
[root@localhost network-scripts]# service network restart
這一步我出現了問題,不過重啟宿主機後就OK了。
[root@localhost ~]# ifconfig
br0 Link encap:Ethernet HWaddr 00:0C:29:DB:B2:28
inet addr:192.168.1.179 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::20c:29ff:fedb:b228/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:137 errors:0 dropped:0 overruns:0 frame:0
TX packets:93 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:13745 (13.4 KiB) TX bytes:11095 (10.8 KiB)
docker0 Link encap:Ethernet HWaddr C6:01:70:AF:C6:E4
inet addr:172.17.42.1 Bcast:0.0.0.0 Mask:255.255.0.0
inet6 addr: fe80::c401:70ff:feaf:c6e4/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:6 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:0 (0.0 b) TX bytes:468 (468.0 b)
eth0 Link encap:Ethernet HWaddr 00:0C:29:DB:B2:28
inet6 addr: fe80::20c:29ff:fedb:b228/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:137 errors:0 dropped:0 overruns:0 frame:0
TX packets:101 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:15663 (15.2 KiB) TX bytes:11959 (11.6 KiB)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:16 errors:0 dropped:0 overruns:0 frame:0
TX packets:16 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:960 (960.0 b) TX bytes:960 (960.0 b)
[root@localhost ~]# git
-bash: git: command not found
[root@localhost ~]# yum install -y git
[root@localhost ~]# cd /etc/sysconfig/network-scripts/
[root@localhost network-scripts]# git clone https://github.com/jpetazzo/pipework
pipework是由Docker的工程師Jérôme Petazzoni開發的一個Docker網路配置工具
[root@localhost network-scripts]# ls
ifcfg-br0 ifdown-eth ifdown-post ifup ifup-ippp ifup-post ifup-wireless pipework
ifcfg-eth0 ifdown-ib ifdown-ppp ifup-aliases ifup-ipv6 ifup-ppp init.ipv6-global
ifcfg-lo ifdown-ippp ifdown-routes ifup-bnep ifup-isdn ifup-routes net.hotplug
ifdown ifdown-ipv6 ifdown-sit ifup-eth ifup-plip ifup-sit network-functions
ifdown-bnep ifdown-isdn ifdown-tunnel ifup-ib ifup-plusb ifup-tunnel network-functions-ipv6
[root@localhost network-scripts]# cp pipework/pipework /usr/local/bin/
[root@localhost network-scripts]# cd
[root@localhost ~]# docker run -itd --net=none --name docker_bridge centos_with_httpd:genesis bash
5417847d3edf9381acf4bcc94c5345002521f4500415d835f081b022f6d48723
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5417847d3edf centos_with_httpd:genesis "bash" 8 seconds ago Up 6 seconds docker_bridge
[root@localhost ~]# docker exec -it docker_bridge bash
[root@5417847d3edf /]# ifconfig
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
[root@5417847d3edf /]# exit
[root@localhost ~]# rpm -Uvh https://repos.fedorapeople.org/openstack/EOL/openstack-grizzly/epel-6/iproute-2.6.32-130.el6ost.netns.2.x86_64.rpm
不升級會報錯Object “netns” is unknown, try “ip help”
[root@localhost ~]# pipework br0 docker_bridge 192.168.1.187/24
[root@localhost ~]# docker exec -it docker_bridge bash
[root@5417847d3edf /]# ifconfig
eth1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.1.187 netmask 255.255.255.0 broadcast 192.168.1.255
inet6 fe80::bcf2:9cff:fe1e:4796 prefixlen 64 scopeid 0x20<link>
ether be:f2:9c:1e:47:96 txqueuelen 1000 (Ethernet)
RX packets 7 bytes 528 (528.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 7 bytes 510 (510.0 B)
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
ping一下閘道器
[[email protected]5417847d3edf /]# ping 192.168.1.1
PING 192.168.1.1 (192.168.1.1) 56(84) bytes of data.
64 bytes from 192.168.1.1: icmp_seq=1 ttl=64 time=63.1 ms
64 bytes from 192.168.1.1: icmp_seq=2 ttl=64 time=2.12 ms
^C
--- 192.168.1.1 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 2.125/32.637/63.150/30.513 ms
相關推薦
Docker配置橋接網路
為了使本地網路中的機器和Docker容器更方便的通訊,我們經常會有將Docker容器配置到和主機同一網段的需求。這個需求其實很容易實現,我們只要將Docker容器和宿主機的網絡卡橋接起來,再給Docker容器配上IP就可以了。 Centos 6按照下面的方法操
linux下kvm配置橋接網路問題
1、DHCP網橋命令:vim /etc/network/interfaces程式碼:auto lo iface lo inet loopback auto eth0 iface eth0 inet dhcp auto br0 iface br0 inet dhcp br
ubuntu下使用qemu安裝虛擬機器並配置橋接網路
一、虛擬機器的建立: 1.ubuntu下安裝好qemu後,使用如下命令建立虛擬機器: qemu-img create -f qcow2 voltdb.img 10g -
使Docker提供對外服務的網路配置(橋接與埠)
前沿: docker 啟動容器後,如何對外服務? 希望大家看了這篇文章後有些幫助。 docker的有關網路問題沒怎麼搞清楚,請教了下鄧磊同學,感謝 ! Docker生成的容器,一般會給你生成一個ip地址,這個ip地址是和docker0的地址
centos7 docker宿主機配置橋接物理網絡終極實戰
centos7、docker、橋接centos7 docker宿主機配置橋接物理網絡終極實戰1、停止docker daemon,並刪除docker0systemctl stop docker.service ip link set dev docker0 down brctl delbr docker02、
docker數據卷備份恢復以及配置橋接網絡
not curl log cast 單位 分享 bfc eid exit 筆記內容:docker數據卷備份恢復以及網絡相關筆記日期:2018-02-06 25.9 數據卷備份恢復 25.10 docker網絡模式 25.11 opration not permitted錯
docker(五)配置橋接網絡
docker配置橋接網絡 復制網卡配置文件ifcfg-ens33為ifcfg-br0,修改ifcfg-br0 [root@apenglinux-002 ~]# cd /etc/sysconfig/network-scripts/ [root@apenglinux-002 network-scripts]# c
Linux入門-網路配置-橋接模式與NAT的區別
首先,在說到VMware的網路模型之前,先說一下VMware的幾個虛擬裝置:VMnet0:這是VMware用於虛擬橋接網路下的虛擬交換機; VMnet1:這是VMware用於虛擬Host-Only網路下的虛擬交換機; VMnet8:這是VMware用於虛擬NAT
Docker之 預設橋接網路與自定義橋接網絡卡
docker引擎會預設建立一個docker0網橋,它在核心層連通了其他的物理或虛擬網絡卡,這就將所有容器和宿主機都放到同一個二層網路。 1. docker如何使用網橋 1.1 Linux虛擬網橋的特點 網橋工作在二層(OSI堆疊),是通用網路裝置的一種,可以設定IP地址。有了IP地址
docker原理解析(1):Docker橋接網路
docker引擎會預設建立一個docker0網橋,它在核心層連通了其他的物理或虛擬網絡卡,這就將所有容器和宿主機都放到同一個二層網路。 1. docker如何使用網橋 1.1 Linux虛擬網橋的特點 網橋工作在二層(OSI堆疊),是通用網路裝置的一種,可
Go遊戲伺服器開發的一些思考(八):Docker橋接網路及固定IP
為什麼需要Docker的橋接網路 有時我們需要把Docker容器暴露到某個網段,這樣就可以把一個Docker容器看成一臺物理機。這時就需要用到Docker的橋接網路。 比如 在做Redis叢集時,通常現有的Redis管理軟體會通過ssh來管理一組Redis。
Centos7 下建立 Docker 橋接網路
centos7宿主機上建立Docker橋接物理網路過程 宿主機網絡卡資訊: name:ens0 IP:192.168.184.99 GATEWAY:192.168.184.2 DNS:192.168.184.2 1. 停止docker服務 ~#:service dock
Virtualbox下NAT和橋接網路配置
前言 折騰了很久,終於搞明白virtualbox下的網路配置問題了。雖然網上的文件比較全,而且操作也不算很複雜,但是自己還是遇到了不少問題,主要是由於自己的粗心和對計算機網路不熟悉導致的。這裡做個記錄,希望來者可以繞過這些問題。我是主系統是win7,虛擬機器安
配置ovirt-vdsm橋接網路 系統fedora 19
/etc/sysconfig/network-scripts 建立ifcfg-ovirtmgmt [[email protected] network-scripts]# cat ifcfg-ovirtmgmt DEVICE=ovirtmgmt TYPE=Br
Linux橋接網路配置
在虛擬機器網路配置中,選擇橋接的方式。然後進入linux進行設定。 編輯 vim /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 BOO
VMware橋接網路模式配置靜態IP詳細步驟
1.修改虛擬機器網路模式:編輯->虛擬機器網路編輯器,出現以下介面 如圖中配置,點選確定 2.檢視本地ip、預設閘道器、子網掩碼 使用ipconfig命令 3.進入虛擬機器如下路徑:/etc/sysconfig/network-scripts 備份網絡卡 c
centos虛擬機網絡配置--橋接模式
fig rtu emctl 條件 xshell min art systemctl virt 必要條件: 虛擬機鏡像centos7 CentOS-7-x86_64-Minimal-1708_2.iso 工具virtualBox5.2.6 主機系統windows8.
centos6.9設定橋接網路模式方法
第一步:設定 VMware 在 VMware 中開啟【編輯】->【虛擬網路編輯器】,新增 VMnet0,並選擇橋接模式。需要注意的是,需要選擇“橋接到”的網絡卡,使用無線網絡卡就選無線網絡卡,使用有線網絡卡就選有線網絡卡,如下圖: 第二步:設定虛擬機器 在虛擬機器系統上右鍵,進
centos7 橋接網路yum無效解決辦法
Could not retrieve mirrorlist http://mirrorlist.centos.org/?release=7&arch=x86_64&repo=os&infra=stock32 error was 14: curl#6 - "Could no
Ubuntu 設定橋接網路
主機設定橋接網路: https://help.ubuntu.com/community/KVM/Networking https://help.ubuntu.com/community/NetworkConnectionBridge 上面兩個都是ubuntu 的官方幫助文件,都提到了圖形