Open vSwitch中有多個命令,分別有不一樣的做用,大體以下:html
ovs-vsctl
用於控制ovs dbovs-ofctl
用於管理OpenFlow switch 的 flowovs-dpctl
用於管理ovs的datapathovs-appctl
用於查詢和管理ovs daemon
本文主要介紹ovs-vsctl
。如下命令查詢主機上已有的 OVS bridge,以及其中的 port。bash
ovs-vsctl show
例子app
$ ovs-vsctl show fc562da8-fb36-4d62-8b47-5502e72069dc Bridge br-vxlan Port "vxlan0" Interface "vxlan0" type: vxlan options: {remote_ip="10.10.10.1"} Port br-vxlan Interface br-vxlan type: internal Port "veth2" Interface "veth2" ovs_version: "2.5.0"
Bridge 相關命令
建立 bridge
建立bridge(或switch,如下統稱爲bridge) br0
socket
使用選項
--may-exist
後,若欲建立的bridge已存在,該命令什麼也不作,也不報錯。tcp
ovs-vsctl [--may-exist] add-br br0
刪除bridge
刪除 bridge br0
spa
使用選項
--if-exists
後,若欲刪除的bridge不存在,該命令什麼也不作,也不報錯。unix
ovs-vsctl [--if-exists] del-br br0
查詢已有的 bridge
ovs-vsctl list-br
端口相關命令
添加端口
添加端口(物理端口或vNIC)eth1到bridge eth1中code
ovs-vsctl [--may-exist] add-port br0 eth1
建立 bond
在br0上建立一個bond了eth0,eth1和eth2的bond端口bond0htm
# ovs-vsctl add-bond <bridge> <port> <iface...> ovs-vsctl add-bond br0 bond0 eth0 eth1 eth2
移除端口
從br0上移除端口eth1ip
ovs-vsctl [--if-exists] del-port br0 eth1
列出端口
列出br0上的端口(不包括internal port)
ovs-vsctl list-ports br0
查看端口詳細數據
列出OVS中端口eth1的詳細數據
$ ovs-vsctl list interface eth1
OpenFlow 控制器相關
添加控制器
# ovs-vsctl set-controller <bridge> <target...> ovs-vsctl set-controller br0 tcp:1.2.3.4:6633 # 設置多個controller ovs-vsctl set-controller br0 tcp:1.2.3.4:6633 tcp:4.3.2.1:6633 # 添加使用unix socket通訊的controller ovs-vsctl set-controller br0 unix:/var/run/xx/xx.sock
移除控制器
ovs-vsctl del-controller br0
查詢 brige 上已配置的控制器
ovs-vsctl get-controller br0
VLAN 相關
配置端口爲Access口
設置br0中的端口eth0爲VLAN 10的access口
ovs-vsctl set port eth0 tag=10
添加eth1到指定bridge br0中,同時將其配置成指定VLAN 10的access端口
ovs-svctl add-port br0 eth1 tag=10
配置端口爲Trunk口
在br0上添加port eth1爲VLAN 9,10,11的trunk
ovs-vsctl add-port br0 eth1 trunk=9,10,11
VXLAN 相關
在bridge ovs0中添加遠端IP爲10.10.10.1的VXLAN endpoint端口vxlan0
# key=100表示設置vni爲100,不設置默認爲0 ovs-vsctl add-port ovs0 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=10.10.10.1 options:key=100 # 不設key值,vni默認爲0 ovs-vsctl add-port ovs0 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=10.10.10.1 # key=flow的話,表示該port的vni能夠經過openflow的actions來進行設置 # 如: actions=set_field:100->tun_id # 或: actions=set_tunnel:100 ovs-vsctl add-port ovs0 vxlan0 -- set interface vxlan0 type=vxlan options:remote_ip=10.10.10.1 options:key=flow
其餘
Atomic operation
一條命令建立bridge br0的,並添加eth0到br0中
ovs-vsctl add-br br0 -- add-port br0 eth0
建立 internal port
OVS internal port 能夠配置IP地址,普通 port 上配置的IP地址是不起做用的。在 br0 上建立一個internal port in0
:
ovs-vsctl add-br br0 in0 -- set interface in0 type=internal ip addr add 10.10.10.10/24 dev in0 # 建立internal port的同時將其設置爲VLAN 10的access port ovs-vsctl add-br br0 in1 tag=10 -- set interface in1 type=internal ip addr add 20.20.20.20/24 dev in1
設置 OpenFlow port id
# 將已在ovs中的端口veth1的OpenFlow端口設置成100 ovs-vsctl set interface veth1 ofport_request=100 # 將端口veth1添加到bridge br0中,並將veth1的OpenFlow端口設置成200 ovs-vsctl add-port br0 veth1 -- set interface veth1 ofport_request=200
{% admonition note Note %} OpenFlow的端口 id 在設置 flow 的匹配字段 in_port 以及 actions 字段的 output 中都會用到。
能夠經過命令ovs-ofctl show br0來查看 br0 中各端口的 OpenFlow 端口 id,該 id 並不求是按順序的。 {% endadmonition %}
設置OpenFlow版本
ovs-vsctl set bridge br0 protocols=OpenFlow10,OpenFlow12,OpenFlow13