CentOS7上配置Open vSwitch和VXLAN实例

环境

实验环境

主机环境

Open vSwitch

安装Open vSwitch

启动Open vSwitch

SELinux会影响Open vSwitch的运行,比如报错:
error: /etc/openvswitch/conf.db: failed to lock lockfile (No such file or directory)原因是没有权限修改/etc/openvswitch的owner
如果环境允许可用关掉SELinux;想保持enabled需要做如下修改:

查看结果:
[root@node0 ~]# systemctl -l status openvswitch.service

配置Open vSwitch

去掉NetworkManager

改用network.services,修改/etc/sysconfig/network-scripts/下的配置文件
/etc/sysconfig/network-scripts/ifcfg-mgmt0

/etc/sysconfig/network-scripts/ifcfg-ovsbr0

/etc/sysconfig/network-scripts/ifcfg-enp2s0f0

虚拟机

配置网络

libvirt 默认会启用virbr0来作为虚拟机的网桥并启动DHCPD;删除该网桥,使用ovs bridge来替代:

vi /etc/libvirt/qemu/CentOS7.xml

或者通过virt-manager来配置

配置VXLAN

在ovsbr0中添加接口vxlan0
node0上的配置:注意remote_ip node1的ip:192.168.3.5。

启动两个虚拟机后的配置:

测试

以上配置,只列出了node0的操作过程;node1作同样配置,ip不同而已。

node0内部vm间通信

vm1 ping vm2:

wireshark抓包,物理网卡上没有对应的流量,vnet0上的包是普通的ICMP包

node0 vm和node1 vm通信


vm1 ping vm3:

vnet0上抓到的报文:普通ICMP包

物理网卡上抓到的报文:vxlan封装的ICMP包 frame 18

vxlan格式

vxlan报文解码

用新版本wireshark(1.12.2)查看 frame 18

node0 vm和node1 ovsbr0管理口通信

参考:
https://n40lab.wordpress.com/2014/09/04/openvswitch-2-3-0-lts-and-centos-7/
http://networkstatic.net/configuring-vxlan-and-gre-tunnels-on-openvswitch/
http://www.astroarch.com/2014/06/rhev-upgrade-saga-installing-open-vswitch-on-rhel-7/

你可能感兴趣的:(openstack)