创建基于ovs的vxlan隧道

本文展示了如何利用OpenvSwitch(OVS)成功建立VXLAN隧道。通过`tcpdump`命令捕获的数据包显示,VXLAN隧道已经正确地封装并传输了ICMP请求和响应,验证了隧道的正常工作。
1.在两台虚拟机上安装openvswitch
    1.1 安装openvswitch
        $ sudo apt install openvswitch-switch

    1.2 查看进程
        $ ps -ef | grep ovs

    1.3 查看ovs的版本
        $ ovs-appctl --version

        

    1.4 查看ovs支持的OpenFlow协议的版本
        $ ovs-ofctl --version
        

2.在两台虚拟机上配置网桥
    2.1 在ubuntu1上添加名为br0和br1的两个网桥:
        $ sudo ovs-vsctl add-br br0
        $ sudo ovs-vsctl add-br br1

        查看网卡:$ ip a
         

        在br0上添加一个端口,将enp0s3挂载到br0上:
            $ sudo ovs-vsctl add-port br0 enp0s3
        这样做的目的是方便我们在虚拟网桥上添加多个端口供我们使用,不必受限于enp0s3的有限端口。

        此时我们将原先enp0s3分配的ip清除并指定给br0,让虚拟机网络能通过br0继续工作:
            $ sudo ifconfig enp0s3 0 up && sudo ifconfig br0 192.168.1.92/24 up

        根据实际情况配置一下br0的网关:
            $ sudo route add default gw 192.168.1.1 br0

  
### OVS-DPDK与VXLAN集成 #### 配置环境准备 为了实现Open vSwitch (OVS) 和 Data Plane Development Kit (DPDK) 的 VXLAN 功能,需确保操作系统内核支持 IOMMU 并已启用 Hugepages。这些设置对于提高性能至关重要[^1]。 #### 安装依赖包 在配置之前,应先安装必要的软件包: ```bash sudo apt-get update && sudo apt-get install -y \ build-essential libssl-dev libffi-dev python-dev \ python-pip bridge-utils iputils-ping net-tools ethtool \ linux-headers-$(uname -r) ``` #### 编译并安装OVS-DPDK 获取最新版源码编译安装带有 DPDK 支持的 Open vSwitch 版本非常重要。这一步骤能保证获得最新的特性和修复的安全漏洞。 ```bash git clone https://github.com/openvswitch/ovs.git cd ovs ./boot.sh ./configure --with-dpdk=/usr/local/ make sudo make install ``` #### 启动OVS服务 启动前要确认 `dpdk-init` 已经被加载到 `/etc/default/openvswitch-switch` 文件中,并设置了适当数量的巨大页数。 ```bash sudo systemctl enable openvswitch-switch sudo systemctl start openvswitch-switch ``` #### 设置HugePages 编辑 grub 参数来增加 hugepage 数量: ```bash echo 'default_hugepagesz=1G hugepagesz=1G hugepages=4' | sudo tee -a /etc/default/grub sudo update-grub reboot ``` #### 创建VXLAN隧道端口 创建基于 DPDK 的 VXLAN 接口用于跨物理位置的数据中心间通信。 ```bash ovs-vsctl add-br br0 -- set Bridge br0 datapath_type=netdev ovs-vsctl add-port br0 dpdk0 -- set Interface dpdk0 type=dpdk options:dpdk-devargs=0000:0b:00.0 ovs-vsctl add-port br0 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=<REMOTE_IP> options:key=flow ``` 以上命令假设远程 IP 地址 `<REMOTE_IP>` 是目标数据中心内的另一台服务器地址;实际操作时请替换为具体数值。 #### 测试连接性 通过 ping 或者其他网络诊断工具验证两个站点之间的连通性是否正常工作。 ```bash ping <REMOTE_IP> ``` 如果一切顺利,则表明已经成功完成了 OVS-DPDK 与 VXLAN 的集成配置过程。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值