目录
[2.Linux 部署 OVS 集群(服务端)](#2.Linux 部署 OVS 集群(服务端))
[3.Linux 部署VXLAN](#3.Linux 部署VXLAN)
一、实验
1.环境
(1) 主机
表1 宿主机
|----------------|-----|--------------------|----------------|---------------------------------|
| 主机 | 架构 | 软件 | IP | 备注 |
| ovs_controller | 控制端 | | 192.168.204.63 | 1个NAT网卡 (204网段) |
| ovs_server01 | 服务端 | OpenvSwitch v2.5.1 | 192.168.204.61 | 1个NAT网卡 (204网段), 1个仅主机网卡 (88网段) |
| ovs_server02 | 服务端 | OpenvSwitch v2.5.1 | 192.168.204.62 | 1个NAT网卡 (204网段), 1个仅主机网卡 (88网段) |
表2 目标云主机
|---------------|------------|-----------------|
| 云主机 | IP | 备注 |
| cloudserver01 | 172.16.1.1 | 宿主机ovs_server01 |
| cloudserver02 | 172.16.1.2 | 宿主机ovs_server02 |
(2) 查看IP
ovs_controller
data:image/s3,"s3://crabby-images/9ef82/9ef8203fa5d7c6f7114e2e76cce18e5bd47c96c1" alt=""
ovs_server01
data:image/s3,"s3://crabby-images/283b5/283b509a6a689d31d44f47436e803faf07e0e614" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/418b0/418b0348bd34bbc68967f25ac73bcd2305581f83" alt=""
(3)修改hostname
bash
[root@localhost ~]# vim /etc/hostname
data:image/s3,"s3://crabby-images/d331d/d331d77bb5dbc6acadef57b221c7d5c50d392e34" alt=""
ovs_controller
data:image/s3,"s3://crabby-images/ccd0e/ccd0efb62c021f7375530e91a49d0646e7fc833a" alt=""
ovs_server01
data:image/s3,"s3://crabby-images/e0d0c/e0d0c8cdd742cbd5f8e476a24e37686d79621ebe" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/e5e12/e5e1287a6c4921d9ec2d6621b6cf8d7f68cbe5db" alt=""
(4) 修改hosts
bash
[root@localhost ~]# vim /etc/hosts
data:image/s3,"s3://crabby-images/94d78/94d78e6eacbcda85064821c70b55c9d15ab8dfbd" alt=""
修改前:
data:image/s3,"s3://crabby-images/e2f8a/e2f8ac70c179ce0f8696b979deaf384cd3d84fe5" alt=""
修改后:
ovs_controller
ovs_server01
ovs_server02
2.Linux 部署 OVS 集群(服务端)
(1)查阅
bash
1)官网
https://www.openvswitch.org/download/
2)GitHub
https://github.com/openvswitch/ovs
(2) 安装OVS依赖软件
bash
yum install -y openssl-devel kernel-devel
yum groupinstall -y "Development Tools"
ovs_server01
data:image/s3,"s3://crabby-images/d0a3b/d0a3bb47956d6aa4392cd1133734789f83e736e6" alt=""
data:image/s3,"s3://crabby-images/35e75/35e756c03f9d757f59e44b3608c5e622eece6e30" alt=""
ovs_server02
(2)添加用户
bash
adduser ovswitch
su - ovswitch
ovs_server01
data:image/s3,"s3://crabby-images/8d107/8d10782104cc3ade7960e19f695e607f6c43d407" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/b6866/b6866489f61961e557123ea0781dbd10a96bd850" alt=""
(3)下载并解压
选择一个稳定版
data:image/s3,"s3://crabby-images/ee071/ee07161c4b121f4a8a8a3f329a2ca52907630476" alt=""
bash
wget https://www.openvswitch.org/releases/openvswitch-2.5.1.tar.gz
tar xfz openvswitch-2.5.1.tar.gz
ovs_server01
data:image/s3,"s3://crabby-images/0adde/0adde4f5d50186134bb5f9d8748e9cdebc5e4dc6" alt=""
data:image/s3,"s3://crabby-images/024d1/024d1e4896ec7f64851d7088282d2022041761e0" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/c5b87/c5b87c35e85bd31f119d8510c430d7250e9729eb" alt=""
data:image/s3,"s3://crabby-images/76c83/76c83fe564fe9bee9721b143bdfa0651b69564f5" alt=""
(4) 源码包⽅式⽣成RPM包
bash
mkdir -p ~/rpmbuild/SOURCES
sed 's/openvswitch-kmod, //g' openvswitch-2.5.1/rhel/openvswitch.spec > openvswitch-2.5.1/rhel/openvswitch_no_kmod.spec
cp openvswitch-2.5.1.tar.gz rpmbuild/SOURCES
rpmbuild -bb --without=check ~/openvswitch-2.5.1/rhel/openvswitch_no_kmod.spec
ovs_server01
data:image/s3,"s3://crabby-images/da082/da08231cf3cc6d4648ebdb257fca96d566862874" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/07d45/07d45345fdd07b2ec122a2f9934680b6291656b9" alt=""
(5)查看并退出用户
bash
ls /home/ovswitch/rpmbuild/RPMS/x86_64/
exit
ovs_server01
data:image/s3,"s3://crabby-images/bb4b1/bb4b10c128ca2106d8d9abc36431870d9634696b" alt=""
data:image/s3,"s3://crabby-images/8eb7f/8eb7f3047dc11b4816ac43bef8328262bb063e50" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/450ac/450ac756e7b4ec2d20ad2d4b5afe44fbb8178e95" alt=""
data:image/s3,"s3://crabby-images/7b497/7b497de7ffc2aa761f022294f8c1d89c8174ea3a" alt=""
(6)RPM包安装
bash
yum localinstall -y /home/ovswitch/rpmbuild/RPMS/x86_64/openvswitch-2.5.1-1.x86_64.rpm
ovs_server01
data:image/s3,"s3://crabby-images/61139/6113903fbec75597ea84c769564eef0842964f7c" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/67c2a/67c2a9a416cccc46362f89e434ba1d4f1f31a849" alt=""
(7)设置开机自启
bash
1)查看
systemctl status openvswitch.service
2)启动
systemctl start openvswitch.service
3)开机自启
systemctl enable openvswitch.service
4)再次查看
systemctl status openvswitch.service
ovs_server01
data:image/s3,"s3://crabby-images/dbf6a/dbf6a7325aba0f60d2c2c59e644aaaea2e6c2e86" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/59d19/59d19e9c222e58d048fecfc979a88266cc60b537" alt=""
(7)安装virt-manager与virsh(libvrit-client)
bash
yum install -y virt-manager libvirt-client
ovs_server01
data:image/s3,"s3://crabby-images/f406c/f406ca6621662d3e1c0a1213041d1baf9e7f1811" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/2ac0e/2ac0e9dc55c0b8329b6c19e954108b13be9722a8" alt=""
(8)关闭防⽕墙
bash
systemctl stop firewalld.service
systemctl disable firewalld.service
ovs_server01
ovs_server02
data:image/s3,"s3://crabby-images/02513/025130ae844d09a7a8b1baf935cbad7f8a46fdff" alt=""
(9)查看
bash
ovs-vsctl show
ovs_server01
data:image/s3,"s3://crabby-images/1a741/1a74169ec4fef6b74bf99deb98480e6d23e7806d" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/20c16/20c167f1a10b28f2b10966889a54ae90aad69bfe" alt=""
3.Linux 部署VXLAN
(1)添加OVS
ovs_server01
bash
ovs-vsctl add-br ovs01
data:image/s3,"s3://crabby-images/de1f1/de1f14902a0f0b24b28995d44346e4ec50830c34" alt=""
ovs_server02
bash
ovs-vsctl add-br ovs02
data:image/s3,"s3://crabby-images/102d2/102d25789da73c001dd579bd6c7919afc7988d37" alt=""
(2)添加OVS internal
ovs_server01
bash
ovs-vsctl add-port ovs01 if01 -- set interface if01 type=internal
data:image/s3,"s3://crabby-images/d1ee5/d1ee55b74a437281fbb9763cbfeec7558e47890a" alt=""
ovs_server02
bash
ovs-vsctl add-port ovs02 if02 -- set interface if02 type=internal
data:image/s3,"s3://crabby-images/75ec3/75ec39f5dad1d987d8d169e8ba34db49ec0a8f2e" alt=""
(3)查看
bash
ovs-vsctl show
ovs_server01
data:image/s3,"s3://crabby-images/59ad2/59ad20c35aaef1fc8a524fdd43e593cb35229c8d" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/2cad8/2cad8786cc1f9c982c21bbebce647ff116128c71" alt=""
(4)ovs_server01创建云主机
bash
virt-manager
data:image/s3,"s3://crabby-images/2f860/2f86068d2704747670ea47eaf53bbbbdd5b7e2ba" alt=""
新建虚拟机
data:image/s3,"s3://crabby-images/b25a9/b25a9df64b39200653bbf6c9858e73e4008c9fa4" alt=""
前进
data:image/s3,"s3://crabby-images/2a94a/2a94af133190ed3f5c557bfd6c51e869103d3751" alt=""
使用镜像
data:image/s3,"s3://crabby-images/2d757/2d7577621bd9d4ae53bf159ccb2e956c47c7d2e4" alt=""
data:image/s3,"s3://crabby-images/f7a3f/f7a3f6265e0b5e4047f0f57d220aac18b1fff9d1" alt=""
修改内存
data:image/s3,"s3://crabby-images/562cb/562cb89a5a4a575810f0f55d588d5c631ae37e51" alt=""
data:image/s3,"s3://crabby-images/05827/0582771db6559afd6102fdb3243c25b4a51ccee3" alt=""
选择网络if01
data:image/s3,"s3://crabby-images/ee504/ee5047a2896e61d2f0db16ab6e109fd503317864" alt=""
强制关机
data:image/s3,"s3://crabby-images/74b7a/74b7a824a0591a733c167c39f01095609d6369d4" alt=""
挂载镜像
data:image/s3,"s3://crabby-images/06545/06545bdbef2373adf07d5f1d38ee9e6a84803c84" alt=""
data:image/s3,"s3://crabby-images/03a60/03a6095ceec2350fb6ead231fb623bf7f7374b2a" alt=""
修改启动项为光驱
data:image/s3,"s3://crabby-images/f5982/f5982b5aba77ea16215a1c36ec5db66d59096f63" alt=""
开机选择第3个命令行
data:image/s3,"s3://crabby-images/fc4e1/fc4e1010aef71585e61eaad25d55cf20156527ba" alt=""
data:image/s3,"s3://crabby-images/281ef/281effbe6b913e951cc464b897e3b89f2e32c65e" alt=""
(5)ovs_server02创建云主机
bash
virt-manager
data:image/s3,"s3://crabby-images/3c8b3/3c8b38ff4ffb2ee277b7ccfd3afb8be3995b08ba" alt=""
新建虚拟机
data:image/s3,"s3://crabby-images/b25a9/b25a9df64b39200653bbf6c9858e73e4008c9fa4" alt=""
前进
data:image/s3,"s3://crabby-images/2a94a/2a94af133190ed3f5c557bfd6c51e869103d3751" alt=""
使用镜像
data:image/s3,"s3://crabby-images/2d757/2d7577621bd9d4ae53bf159ccb2e956c47c7d2e4" alt=""
data:image/s3,"s3://crabby-images/f7a3f/f7a3f6265e0b5e4047f0f57d220aac18b1fff9d1" alt=""
修改内存
data:image/s3,"s3://crabby-images/562cb/562cb89a5a4a575810f0f55d588d5c631ae37e51" alt=""
data:image/s3,"s3://crabby-images/05827/0582771db6559afd6102fdb3243c25b4a51ccee3" alt=""
选择网络if01
data:image/s3,"s3://crabby-images/da53b/da53b22ac9c2b57503926747531cb017796cd84b" alt=""
强制关机
data:image/s3,"s3://crabby-images/74b7a/74b7a824a0591a733c167c39f01095609d6369d4" alt=""
挂载镜像
data:image/s3,"s3://crabby-images/0695a/0695a83078b1386662a7d2846a4c670bce3eb5e2" alt=""
data:image/s3,"s3://crabby-images/e9942/e99425f6ccb7859a39ce7079e6d1358a3c95d167" alt=""
修改启动项为光驱
data:image/s3,"s3://crabby-images/be4c7/be4c7e59e0a2f7587746463e36b349634c0d4ea1" alt=""
开机选择第3个命令行
data:image/s3,"s3://crabby-images/91ed1/91ed120f5754d05e0550bd39c262bdbb9535930e" alt=""
data:image/s3,"s3://crabby-images/e9c82/e9c82b849e26ef45a5386ab91863a66a5a030a28" alt=""
(7)查看云主机网卡并修改
cloudserver01
bash
sudo ifconfig
sudo ifconfig eth0 172.16.1.1 netmask 255.255.255.0
data:image/s3,"s3://crabby-images/a57a4/a57a45885e680d67e87b6cdd01b718e4016b7e84" alt=""
cloudserver02
bash
sudo ifconfig
sudo ifconfig eth0 172.16.1.2 netmask 255.255.255.0
data:image/s3,"s3://crabby-images/6f372/6f372b2d94d8cd0ee21f3617fec8dbc20ab4f690" alt=""
(8) 测试网络
云主机1 ping 云主机2 ,目前不通
data:image/s3,"s3://crabby-images/81bdb/81bdb0f585070e8983578f81b56714cd3be7b42a" alt=""
(9)部署VXLAN端⼝
ovs_server01
bash
ovs-vsctl add-port ovs01 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=192.168.204.62 options:key=10001
data:image/s3,"s3://crabby-images/7ab85/7ab858d670dd59482c18faef9b7add74c4d6df18" alt=""
ovs_server02
bash
ovs-vsctl add-port ovs02 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=192.168.204.61 options:key=10001
data:image/s3,"s3://crabby-images/1b83d/1b83d2ecd8fc2601776c1e2ceaf79b0acb145d6d" alt=""
(10)查看
bash
ovs-vsctl show
ovs_server01
data:image/s3,"s3://crabby-images/2e6ea/2e6eaed4ca21a05ac4e751029aa7fe3470fbb954" alt=""
ovs_server02
data:image/s3,"s3://crabby-images/4786c/4786cb548fc42b8dae3b834695066289f69a6be9" alt=""
(11) 测试网络
云主机1 ping 云主机2 ,目前已通
data:image/s3,"s3://crabby-images/2a6ca/2a6ca743509fb74fa838ffc28843f3ffe3e5321a" alt=""
(12)流量抓包(tcpdump)
ovs_server01
data:image/s3,"s3://crabby-images/00e20/00e20d692d2fe6477589c84339a3a2825ed3864e" alt=""
云主机1 ping 云主机2
data:image/s3,"s3://crabby-images/088f1/088f10097e90e145165ccdd5e80505e0c8b176ca" alt=""
观察抓取的流量(源端口一直在变化,目的端口都为4789)
data:image/s3,"s3://crabby-images/1f89f/1f89fcaf31ee220a6438169865a38cfb4752540f" alt=""
(13) 流量抓包(Wireshark)
云主机1 ping 云主机2
data:image/s3,"s3://crabby-images/088f1/088f10097e90e145165ccdd5e80505e0c8b176ca" alt=""
观察抓取的流量
data:image/s3,"s3://crabby-images/ce3b7/ce3b7b33a0b93829ee04ce15373df5a8b55fecfe" alt=""
(14)流量分析(Wireshark)
原始数据:
data:image/s3,"s3://crabby-images/e0c29/e0c2994653a59b7b558f9c013256097639b5d774" alt=""
VXLAN隧道封装了VNI (实现多租户隔离)
data:image/s3,"s3://crabby-images/85c7d/85c7d3a65649f05cc678bdbd9fe48c2a638eeec8" alt=""
原始数据(二层包)封装在UDP,原端口随机,目的端口为4789
data:image/s3,"s3://crabby-images/8a2dd/8a2dd2fee230b193fa7b5562e206eb3cb201b9cb" alt=""
新IP头:
data:image/s3,"s3://crabby-images/eb30e/eb30eefbb34774e80112776306d2f68da644a30b" alt=""