This configuration can be used to set up a CORD development environment. It does the following:
NOTE: This configuration is under active development and is not yet finished! Some features are not fully working yet.
The configuration uses XOS to set up an end-to-end dataplane for development of the XOS services and ONOS apps used in CORD. It abstracts away most of the complexity of the CORD hardware using virtual networks and Open vSwitch (OvS) switches. At a high level the dataplane looks like this:
olt virtualbng ---- ---- ONOS ONOS | | client ----> CPqD ----> vCPE ----> OvS ----> Internet 1 2 3 4
On the datapath are two OvS switches, controlled by the olt
and virtualbng
ONOS applications. Once all the pieces are in place, the client at left should be able to obtain an IP address via DHCP from the vCPE and send packets out to the Internet.
All of the components in the above diagram (i.e., client, OvS switches, ONOS, and vCPE) currently run in distinct VMs created by XOS. The numbers in the diagram correspond to networks set up by XOS:
The configuration is intended to be run on CloudLab. It launches an XOS container on Cloudlab that runs the XOS develserver. The container is left running in the background.
To get started on CloudLab:
$ git clone https://github.com/open-cloud/xos.git $ cd xos/xos/configurations/cord/ $ make
Running make
in this directory creates the XOS Docker container and runs the TOSCA engine with cord.yaml
to configure XOS with the CORD services. In addition, a number of VMs are created:
virtualbng
app loadedolt
app loadedvirtualbng
app as controllerolt
app as controllerOnce all the VMs are up and the ONOS apps are configured, XOS should be able to get an address mapping from the virtualbng
ONOS app for the vCPE. To verify that it has received an IP address mapping, look at the Routeable subnet: field in the appropriate Vbng tenant object in XOS. It should contain an IP address in the 10.254.0.0/24 subnet.
The ONOS Docker container runs in the VMs belonging to the mysite_onos slice. All ports exposed by the ONOS container are forwarded to the outside, and can be accessed from the ctl node using the flat-lan-1-net
address of the hosting VM. For example, if the IP addresss of the VM is 10.11.10.30, then it is possible to SSH to ONOS as follows (password is karaf):
$ ssh -p 8101 karaf@10.11.10.30 Password authentication Password: Welcome to Open Network Operating System (ONOS)! ____ _ ______ ____ / __ \/ |/ / __ \/ __/ / /_/ / / /_/ /\ \ \____/_/|_/\____/___/ Hit '<tab>' for a list of available commands and '[cmd] --help' for help on a specific command. Hit '<ctrl-d>' or type 'system:shutdown' or 'logout' to shutdown ONOS. onos>
For instance, to check the IP address mappings managed by the virtualbng
app:
onos> vbngs Private IP - Public IP 10.0.1.3 - 10.254.0.129