[svc]linux下网桥-docker网桥
网桥和交换机
2口交换机=网桥

交换机: 工作在数据链路层,根据源mac学习(控制层),目的mac转发(数据层).
linux的网卡

vmware workstation中的桥接
参考: http://blog.daocloud.io/docker-bridge/

docker0的桥接
参考: http://blog.daocloud.io/docker-bridge/






网桥操作工具
yum install bridge-utils -y
如果需要使用网桥模式,需要关掉NetworkManager服务
systemctl stop NetworkManager
systemctl disable NetworkManager
两张网卡放在一个bro下
我们已经知道了br网卡是虚拟网桥,相当于一个交换机,可以把eth0接入 eth1接入
实现如图

方法1: 命令行配置
- 添加br0
brctl addbr br0
- 将eth0连到br0
brctl addif br0 eth0
brctl addif br0 eth1
- 清理eth0的地址-这里有点问题吧
ifconfig eth0 0.0.0.0
- 配置br0的地址
ifconfig br0 192.168.1.10 netmask 255.255.255.0 up # 我发现这样可以添加回环口
brctl addif br0 ath0
方法2: 持久化配置
参考: http://www.solutionsatexperts.com/how-to-create-a-bridge-interface-on-rhelcentos/
- 规划
Combine eth1 and eth2 physical interfaces and create a virtual interface br0, assign IP to it.
eth1 : No IP
eth2 : No IP
Note: eth1 and eth2 connect to same physical layer / media.
br0 – > eth1
– > eth2
Note: br0 is a virtual interface mapped to eth0 and eth1
br0 – > 192.168.1.10
Netmask – > 255.255.255.0
Gateway – > 192.168.1.1
DNS – > 8.8.8.8
- 操作步骤
Step 1: Disable Network Manager
Step 2: Create virtual interface br0
Step 3: Configure Physcial interfaces eth1 and eth2
Step 4: Restart network service and verify network settings
Step 1: Disable Network Manager
systemctl stop NetworkManager # 网卡开启桥接模式需要关掉NetworkManager
Step 2: Create virtual interface br0
Add ifcfg-br0 file under /etc/sysconfig/network-script/
#vi /etc/sysconfig/network-scripts/ifcfg-br0
DEVICE=br0
TYPE=Bridge
ONBOOT=yes
BOOTPROTO=static
IPADDR=192.168.1.10
NETMASK=255.255.254.0
GATEWAY=192.168.1.1
DNS1=114.114.114.114
DNS2=8.8.8.8
Save & Exit(:wq)
Step 3: Configure Physcial interfaces eth1 and eth2
vi /etc/sysconfig/network-script/ifcfg-eth1
DEVICE=eth1
BOOTPROTO=static
ONBOOT=yes
BRIDGE=br0
TYPE=Ethernet
Save & Exit (:wq)
Step 4: Restart network service and verify network settings
Restart the network services
# systemctl restart network
Verify network settings
# ifconfig -a
需求一台pc要通过另一台两口的linux上网
这里要理解,两个网桥之间交互数据: 查路由表(或者nat)

思路其实很简单:
- 1.就是将虚拟出一个bridge口
- 2.将对应的有线LAN和无线LAN都绑定在这个虚拟bridge口上,并给这个bridge口分配一个地址
- 3.其他子网微机配置网关为bridge口的地址便可以了。
- 4.当然,因为是设备是网关模式,路由和nat也是必须的了。
源地址转换
iptables -t nat -A POSTROUTING -o eth1 -j SNAT --to 192.168.1.10
brctl命令
$ docker run -itd --name=b1 busybox
$ brctl show
bridge name bridge id STP enabled interfaces
docker0 8000.0242fb188161 no veth0a226d0
$ docker run -itd --name=b2 busybox
$ brctl show
bridge name bridge id STP enabled interfaces
docker0 8000.0242fb188161 no veth0a226d0
vethd9de1b2
$ brctl show
show showmacs showstp
- 看到容器的mac地址,docker0这个交换机下接了2个
$ brctl showmacs docker0
port no mac addr is local? ageing timer
1 02:42:ac:11:00:02 no 2.36
$ docker exec -it b1 ip ad
14: eth0@if15: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue
link/ether 02:42:ac:11:00:02
linux下回环口的配置
参考: 虚拟网卡添加: http://blog.csdn.net/yydcj/article/details/8447567
http://www.centoscn.com/image-text/config/2016/1113/8145.html
也可以只通过添加br0并给设置地址的方式,设置回环口.
ifconfig lo 130.0.0.1
[svc]linux下网桥-docker网桥的更多相关文章
- Linux下,非Docker启动Elasticsearch 6.3.0,安装ik分词器插件,以及使用Kibana测试Elasticsearch,
Linux下,非Docker启动Elasticsearch 6.3.0 查看java版本,需要1.8版本 java -version yum -y install java 创建用户,因为elasti ...
- linux 下安装docker
Linux 下的 Docker 安装与使用 一.安装与配置 安装一些必要的系统工具: sudo yum install -y yum-utils device-mapper-persistent-da ...
- 在Kali linux下使用docker配置sqli-labs(国内源的配置和系统软件更新)
本篇blog导航: ~前言 ~第一步:在安装好的kali配置国内源 ~第二步:安装docker ~第三步:docker下安装sqli-labs ~写在最后. 前言: 最近闲来无事,在闯关sqli-la ...
- Docker学习笔记二(linux下安装Docker)
Docker学习笔记二(linux下安装Docker) 1.在线安装linux Docker 这种方式首先要保证linux 环境下可以上网,当然,小编是在自己的电脑上安装了虚拟机,在虚拟机上安装了,l ...
- linux下brctl配置网桥
原文:http://zhumeng8337797.blog.163.com/blog/static/1007689142011643834429/ 先装好网卡,连上网线,这是废话,不用说了. 然后开始 ...
- Linux下部署docker记录(0)-基础环境安装
以下是centos系统安装docker的操作记录 1)第一种方法:采用系统自带的docker安装,但是这一般都不是最新版的docker安装epel源[root@docker-server ~]# wg ...
- mac和linux下使用Docker,部署SpringBoot项目到docker
主要是看一下如何在linux及mac上安装docker,创建docker镜像,部署SpringBoot项目到docker,并借助于DaoCloud进行docker镜像下载加速等. 我用的电脑是mac, ...
- Linux下安装docker,更改镜像仓库地址,并部署springboot应用
今天做不成的事,明天也不会做好. 各位同学大家好,随着docker的快速发展,越来越多的人开始使用,一方面随着容器化这个趋势越来越火,docker成为了其中的佼佼者:二来容器化确实降低了运维的门槛,让 ...
- 巧用linux版powershell,管理linux下的docker
大家好,我把用powershell的docker马甲命令的好处,放在了页面下方,从第五章开始. powershell 传教士 原创文章 始于 2017-09-07 允许转载,但必须保留名字和出处,否则 ...
随机推荐
- JAVA Socket通信 打造属于自己的网盘
近一个月没敲JAVA代码了,最近老师布置了一个写JAVA网盘的作业,总共花了十几个小时,总算写完了,debug真的累,感觉自己还是菜了,没有那种有一个想法就能马上用代码实现的能力....不扯了,下面开 ...
- 关于Git的总结
首先我们先看一张图: 首先我们必须要先理解这几个概念:暂存区,本地仓库,远程仓库 暂存区:这个是我们每一次进行代码修改的地方,例如我们ieda的所编译的代码就是缓存区 本地仓库:是我们每一次pull, ...
- 安卓 logcat设置 Android logcat Settings
安卓 logcat设置 Android logcat Settings 作者:韩梦飞沙 Author:han_meng_fei_sha 邮箱:313134555@qq.com E-mail: 3131 ...
- 潭州课堂25班:Ph201805201 第十一课 继承,多继承和魔术方法,属性和方法 (课堂笔记)
继承: class p : cls_name = 'p' def __init__(self): print('正在实例化') def __del__(self): print('正在销毁') cla ...
- [国家集训队]Crash的数字表格
Description: 求$ \sum_{i=1}^n \sum_{j=1}^m lcm(i,j) $ Hint: $ n,m<=10^7 $ Solution: 这题有每次询问 \(O(n) ...
- 多线程里面this.getName()和currentThread.getName()有什么区别
public class hello extends Thread { public hello(){ System.out.println("Thread.currentThread(). ...
- 关于Oracle游标out参数多层调用的BUG,ORA-06504
数据库版本 Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bit 测试代码 declare p_cur sys_refcu ...
- PHP Redis 对象方法手册
redis(Remote Dictionary Server)是一种Nosql技术,它是一个开源的高级kv存储和数据结构存储系统. redis不仅仅是能够存储key和value这种简单的键值对,还能存 ...
- MYSQL时间类别总结: TIMESTAMP、DATETIME、DATE、TIME、YEAR
总结背景: 对于MYSQL数据库日期类型或多有了解, 但并很清晰其中一些规则. 基本都是面向浏览器编码, 这实质上也是一种方式. 但期间遇到两个问题: 时常遇到建表中出现多个datetime或者ti ...
- C# SpinLock实现
关于SpinLock自旋锁网上已经有很多说明,这里也copy了一部分,我这里主要关注微软的实现,学习人家的实现方式. 如果由于垃圾回收,基于对象的锁对象开销太高,可以使用SpinLock结构..NET ...