We describe how to configure, run, and test the OpenstackSwitching application. If you did not set up your environment including openstack and onos, you must set up your environment following the page: How to set up environment from scratch. Also, if you are familiar with how to execute ONOS, we strongly recommend to go though ONOS Tutorial page: Tutorials and Walkthroughs
How to run OpenstackSwitching application
Remove br-int bridge on the Contorl node
$ sudo ovs-vsctl del-br br-int
The process will be unnecessary very soon.
Configure OpenstackSwitching application: network-cfg.json
We need to configure the OpenstackSwitching application using the standard ONOS Network Configuration framework, network-cfg.json file.
App field Field name Description org.onosproject.openstackswitching
do_not_push_flows
"true": it does not push any flow rules to OVS and works as just the Openstack interface.
"false": it pushes all flow rules to OVS
neutron_server
URL to the neutron server
keystone_server
URL to the keystone server for authentication org.onosproject.dhcp
<all> Sample DHCP domain information. You do not touch it. They are just samples and not really used, but we need at least one. org.onosproject.cordvtn:cordvtn:nodes
cordvtn:nodes
Descriptions of hosts. We need to setup information of all hosts we have setup, which are control node and two compute nodes. hostname
description of the host ovsdbIp IP address of the host ovsdbPort
OVSDB Port: 6640, which is set via "ovs-vsctl set-manager" command bridgeId
Datapath ID of the OVS switch in the host devices DPID Driver information to use for the devices. We defined a sona driver which uses OpenstackSwitching pipeline for OVS switches.
The specific information of sona driver is defined in onos-drivers.xml.Copy the network-cfg.json file to ~/onos/tools/package/config. If you updated or just copied the file, then you need to compile the onos again to distribute the network-json file.
Compile and install ONOS
~/onos$ mcis ~/onos$ onos-package ~/onos$ onos-install -f $OC1
You need to set up you own cell information before you install the ONOS.
Login to the ONOS CLI and activate OpenstackSwitching application
onos> app activate org.onosproject.openstackswitching
If this is the first time to install OpenstackSwitching application and vxlan bridge is not created yet, please follow the steps below before activating OpenstackSwitching application.
onos> app activate org.onosproject.cordvtn onos> app deactivate org.onosproject.cordvtn
The cordvtn application has the feature to detect the node configurations in network-cfg.json file and create vxlan and br-int bridges. For now, the feature is not integrated into OpenstackSwitching app yet and we need the cordvtn app until then. Once vxlan and br-int bridges are created, we do not need cordvtn application any more and please deactivate or even uninstall the app before activating the OpenstackSwitching application.
You can see the three devices (control node and two compute nodes) from ONOS CLI, if everything has been configured successfully.
app activate org.onosproject.onos> devices id=of:0000000000000001, available=true, role=MASTER, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.3.2, serial=None, managementAddress=10.40.101.116, protocol=OF_13, channelId=10.40.101.116:60019 id=of:0000000000000002, available=true, role=MASTER, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.3.2, serial=None, managementAddress=10.40.101.176, protocol=OF_13, channelId=10.40.101.176:38230 id=of:0000000000000003, available=true, role=MASTER, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.0.2, serial=None, managementAddress=10.40.101.156, protocol=OF_13, channelId=10.40.101.156:59094
Also, you should be able to see that br-in bridge and vxlan port have been created in all three nodes as below.
$ sudo ovs-vsctl show 1265d109-8a0a-40d5-bfee-f8ee9c7438c1 Manager "ptcp:6640" is_connected: true Bridge br-int Controller "tcp:10.40.101.153:6653" is_connected: true fail_mode: secure Port br-int Interface br-int Port vxlan Interface vxlan type: vxlan options: {key=flow, remote_ip=flow}
- Now it is ready to GO!. Enjoy OpenstackSwitching!!
Tutorials
Walkthrough 1: Basics
Walkthrough 2: L3 ping test with a router
Walkthrough 3: SSH to VMs using SSH key
- HA Test
- Security Group