基于RYU restful api实现的VLAN网络虚拟化
前言
本次实验是基于OVS的VLAN虚拟化简易实践方案的进一步的实验,采用RYU restful api进行配置。本质上和上次实验没什么差,究其原因还是因为上次不能较好使用RYU的restful api,现在学会了就实践一把吧。
RESTFUL API 下发流表
工具
- postman
- ryu/app/gui_topolog/gui_topology.py
- ovs
- mininet
实验步骤
之前的实验步骤不在赘述,主要是用RYU的restful api下发push_vlan
ACTION
tip:记得一定要大写
Actions | Description | Example |
---|---|---|
OUTPUT | Output packet from "port" | {"type": "OUTPUT", "port": 3} |
COPY_TTL_OUT | Copy TTL outwards | {"type": "COPY_TTL_OUT"} |
COPY_TTL_IN | Copy TTL inwards | {"type": "COPY_TTL_IN"} |
SET_MPLS_TTL | Set MPLS TTL using "mpls_ttl" | {"type": "SET_MPLS_TTL", "mpls_ttl": 64} |
DEC_MPLS_TTL | Decrement MPLS TTL | {"type": "DEC_MPLS_TTL"} |
PUSH_VLAN | Push a new VLAN tag with "ethertype" | {"type": "PUSH_VLAN", "ethertype": 33024} |
POP_VLAN | Pop the outer VLAN tag | {"type": "POP_VLAN"} |
PUSH_MPLS | Push a new MPLS tag with "ethertype" | {"type": "PUSH_MPLS", "ethertype": 34887} |
POP_MPLS | Pop the outer MPLS tag with "ethertype" | {"type": "POP_MPLS", "ethertype": 2054} |
SET_QUEUE | Set queue id using "queue_id" when outputting to a port | {"type": "SET_QUEUE", "queue_id": 7} |
GROUP | Apply group identified by "group_id" | {"type": "GROUP", "group_id": 5} |
SET_NW_TTL | Set IP TTL using "nw_ttl" | {"type": "SET_NW_TTL", "nw_ttl": 64} |
DEC_NW_TTL | Decrement IP TTL | {"type": "DEC_NW_TTL"} |
SET_FIELD | Set a "field" using "value"(The set of keywords available for "field" is the same as match field) | See Example of set-field action |
PUSH_PBB | Push a new PBB service tag with "ethertype"(Openflow1.3+) | {"type": "PUSH_PBB", "ethertype": 35047} |
POP_PBB | Pop the outer PBB service tag(Openflow1.3+) | {"type": "POP_PBB"} |
COPY_FIELD | Copy value between header and register(Openflow1.5+) | {"type": "COPY_FIELD", "n_bits": 32, "src_offset": 1, "dst_offset": 2, "src_oxm_id": "eth_src", "dst_oxm_id": "eth_dst"} |
METER | Apply meter identified by "meter_id"(Openflow1.5+) | {"type": "METER", "meter_id": 3} |
EXPERIMENTER | Extensible action for the experimenter(Set "base64" or "ascii" to "data_type" field) | {"type": "EXPERIMENTER", "experimenter": 101, "data": "AAECAwQFBgc=", "data_type": "base64"} |
GOTO_TABLE | (Instruction) Setup the next table identified by "table_id" | {"type": "GOTO_TABLE", "table_id": 8} |
WRITE_METADATA | (Instruction) Setup the metadata field using "metadata" and "metadata_mask" | {"type": "WRITE_METADATA", "metadata": 0x3, "metadata_mask": 0x3} |
METER | (Instruction) Apply meter identified by "meter_id"(deprecated in Openflow1.5) | {"type": "METER", "meter_id": 3} |
WRITE_ACTIONS | (Instruction) Write the action(s) onto the datapath action set | {"type": "WRITE_ACTIONS", actions":[{"type":"POP_VLAN",},{ "type":"OUTPUT", "port": 2}]} |
CLEAR_ACTIONS | (Instruction) Clears all actions from the datapath action set |
Example of set-field action
$ curl -X POST -d '{
"dpid": 1,
"match":{
"dl_type": "0x8000"
},
"actions":[
{
"type": "PUSH_VLAN", # Push a new VLAN tag if a input frame is non-VLAN-tagged
"ethertype": 33024 # Ethertype 0x8100(=33024): IEEE 802.1Q VLAN-tagged frame
},
{
"type": "SET_FIELD",
"field": "vlan_vid", # Set VLAN ID
"value": 4102 # Describe sum of vlan_id(e.g. 6) | OFPVID_PRESENT(0x1000=4096)
},
{
"type": "OUTPUT",
"port": 2
}
]
}' http://localhost:8080/stats/flowentry/add
postman
ovs
sudo ovs-ofctl -O OpenFlow13 dump-flows s1
得到结果
OFPST_FLOW reply (OF1.3) (xid=0x2):
cookie=0x0, duration=2350.981s, table=0, n_packets=0, n_bytes=0, priority=1,in_port=1 actions=push_vlan:0x8100,set_field:4096->vlan_vid,output:2
总结
可以基于此写自动化脚本,不过还是有通过restful api层面,感觉还不是太好。下面搞一个不通过restful api层面的下发过程。
参考链接
RYU手册中的restapi之match+action页