...
Code Block |
---|
distributed@mininet-vm:~$ cell docker ONOS_CELL=docker OCI=172.17.0.2 OC1=172.17.0.2 OC2=172.17.0.3 OC3=172.17.0.4 OCN=localhost ONOS_FEATURES=webconsole,onos-api,onos-core,onos-cli,onos-rest,onos-gui,onos-openflow,onos-app-fwd,onos-app-proxyarp,onos-app-mobility ONOS_USER=root ONOS_NIC=172.17.0.* |
First thing we need to do is setup passwordless access to our instances, this will safe you a ton of time especially when developing and pushing your component frequently. ONOS provides a script that will push your local key to the instance:
Code Block |
---|
distributed@mininet-vm:~$ onos-push-keys $OC1
root@172.17.0.5's password: onosrocks
distributed@mininet-vm:~$ onos-push-keys $OC2
root@172.17.0.5's password: onosrocks
distributed@mininet-vm:~$ onos-push-keys $OC3
root@172.17.0.5's password: onosrocks |
The password for your instance is onosrocks. You will need to do this for each instance. Now we just need to package ONOS by running:
Code Block |
---|
distributed@mininet-vm:~$ onos-package
-rw-rw-r-- 1 distributed distributed 41940395 Dec 11 13:20 /tmp/onos-1.0.0.distributed.tar.gz |
This prepares an ONOS installations which can now be shipped to the remote instances:
Code Block |
---|
distributed@mininet-vm:~$ onos-install $OC1
onos start/running, process 308
distributed@mininet-vm:~$ onos-install $OC2
onos start/running, process 302
distributed@mininet-vm:~$ onos-install $OC3
onos start/running, process 300
distributed@mininet-vm:~$ |
This has now installed ONOS on your docker instances.
Verifying that ONOS is deployed
Now ONOS is installed let's quickly run some tests to make sure everything is ok. Let's start by connecting to the ONOS cli:
Code Block |
---|
distributed@mininet-vm:~$ onos -w $OC1
Connection to 172.17.0.2 closed.
Logging in as karaf
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> |
You should drop into the cli. Now in another cli window let's start mininet.
Code Block |
---|
distributed@mininet-vm:~$ ./startmn.sh
mininet> |
Now let's see if we have switches that are connected to ONOS:
Code Block |
---|
onos> devices
id=of:0000000100000001, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000000100000002, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000000200000001, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000000200000002, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000000300000001, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000000300000002, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000010100000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000010200000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000020100000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000020200000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000030100000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:0000030200000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:1111000000000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10
id=of:2222000000000000, available=false, role=NONE, type=SWITCH, mfr=Nicira, Inc., hw=Open vSwitch, sw=2.1.3, serial=None, protocol=OF_10 |
Let's see if we can forward traffic:
Code Block |
---|
mininet> pingall
*** Ping: testing ping reachability
h111 -> h112 h121 h122 h211 h212 h221 h222 h311 h312 h321 h322
h112 -> h111 h121 h122 h211 h212 h221 h222 h311 h312 h321 h322
h121 -> h111 h112 h122 h211 h212 h221 h222 h311 h312 h321 h322
h122 -> h111 h112 h121 h211 h212 h221 h222 h311 h312 h321 h322
h211 -> h111 h112 h121 h122 h212 h221 h222 h311 h312 h321 h322
h212 -> h111 h112 h121 h122 h211 h221 h222 h311 h312 h321 h322
h221 -> h111 h112 h121 h122 h211 h212 h222 h311 h312 h321 h322
h222 -> h111 h112 h121 h122 h211 h212 h221 h311 h312 h321 h322
h311 -> h111 h112 h121 h122 h211 h212 h221 h222 h312 h321 h322
h312 -> h111 h112 h121 h122 h211 h212 h221 h222 h311 h321 h322
h321 -> h111 h112 h121 h122 h211 h212 h221 h222 h311 h312 h322
h322 -> h111 h112 h121 h122 h211 h212 h221 h222 h311 h312 h321
*** Results: 0% dropped (132/132 received) |
Finally let's see if we have switches connected to each instance of ONOS:
Code Block |
---|
onos> masters
172.17.0.2: 5 devices
of:0000000100000001
of:0000000200000001
of:0000000300000001
of:0000020100000000
of:0000030200000000
172.17.0.3: 2 devices
of:0000000100000002
of:0000000300000002
172.17.0.4: 7 devices
of:0000000200000002
of:0000010100000000
of:0000010200000000
of:0000020200000000
of:0000030100000000
of:1111000000000000
of:2222000000000000 |
The number of switches per ONOS instance may be different for you because mastership is simply obtained by the first controller which handshakes with the switch. If you would like to rebalance the switch-onos ratio simply run:
Code Block |
---|
onos> balance-masters |
And now the output of the masters command should give you something similar to this:
Code Block |
---|
onos> masters
172.17.0.2: 5 devices
of:0000000100000001
of:0000000200000001
of:0000000300000001
of:0000020100000000
of:0000030200000000
172.17.0.3: 4 devices
of:0000000100000002
of:0000000300000002
of:0000020200000000
of:1111000000000000
172.17.0.4: 5 devices
of:0000000200000002
of:0000010100000000
of:0000010200000000
of:0000030100000000
of:2222000000000000 |
At this point, you multi-instance ONOS deployment is functional. Let's move on to writing some code.