summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--doc/source/configuration.rst9
-rw-r--r--doc/source/index.rst1
-rw-r--r--doc/source/tls.rst75
3 files changed, 85 insertions, 0 deletions
diff --git a/doc/source/configuration.rst b/doc/source/configuration.rst
new file mode 100644
index 00000000..f65382d1
--- /dev/null
+++ b/doc/source/configuration.rst
@@ -0,0 +1,9 @@
+*************
+Configuration
+*************
+
+.. toctree::
+ :maxdepth: 2
+
+ tls.rst
+
diff --git a/doc/source/index.rst b/doc/source/index.rst
index 5c723a12..f323bb26 100644
--- a/doc/source/index.rst
+++ b/doc/source/index.rst
@@ -15,6 +15,7 @@ Contents:
getting_started.rst
openstack.rst
developing.rst
+ configuration.rst
Indices and tables
==================
diff --git a/doc/source/tls.rst b/doc/source/tls.rst
new file mode 100644
index 00000000..29aa617c
--- /dev/null
+++ b/doc/source/tls.rst
@@ -0,0 +1,75 @@
+********************
+Setup TLS Connection
+********************
+
+If you want to use secure channel to connect OpenFlow switches, you
+need to use TLS connection. This document describes how to setup Ryu
+to connect to the Open vSwitch over TLS.
+
+
+Configuring a Public Key Infrastructure
+========================================
+
+If you don't have a PKI, the ovs-pki script included with Open vSwitch
+can help you. This section is based on the INSTALL.SSL in the Open
+vSwitch source code.
+
+NOTE: How to install Open vSwitch isn't described in this
+document. Please refer to the Open vSwitch documents.
+
+
+Create a PKI by using ovs-pki script::
+
+ % ovs-pki init
+ (Default directory is /usr/local/var/lib/openvswitch/pki)
+
+The pki directory consists of controllerca and switchca
+subdirectories. Each directory contains CA files.
+
+
+Create a controller private key and certificate::
+
+ % ovs-pki req+sign ctl controller
+
+ctl-privkey.pem and ctl-cert.pem are generated in the current
+directory.
+
+
+Create a switch private key and certificate::
+
+ % ovs-pki req+sign sc switch
+
+sc-privkey.pem and sc-cert.pem are generated in the current directory.
+
+
+Testing TLS Connection
+======================
+
+Configuring ovs-vswitchd to use CA files using the ovs-vsctl "set-ssl"
+command, e.g.::
+
+ % ovs-vsctl set-ssl sc-privkey.pem sc-cert.pem /usr/local/var/lib/openvswitch/pki/controllerca/cacert.pem
+ % ovs-vsctl add-br br0
+ % ovs-vsctl set-controller br0 ssl:127.0.0.1:6633
+
+
+Run Ryu with CA files::
+
+ % ryu-manager --ctl_privkey ctl-privkey.pem \
+ --ctl_cert ctl-cert.pem \
+ --ca_cert /usr/local/var/lib/openvswitch/pki/switchca/cacert.pem \
+ --verbose
+
+You can see something like::
+
+ loading app ryu.controller.ofp_handler
+ instantiating app ryu.controller.ofp_handler
+ connected socket:<SSLSocket fileno=4 sock=127.0.0.1:6633 peer=127.0.0.1:56493> address:('127.0.0.1', 56493)
+ unhandled event <ryu.controller.dispatcher.EventQueueCreate object at 0x2fdcd90>
+ hello ev <ryu.controller.ofp_event.EventOFPHello object at 0x2fdce90>
+ move onto config mode
+ unhandled event <ryu.controller.dispatcher.EventDispatcherChange object at 0x2fdcfd0>
+ switch features ev version: 0x1 msg_type 0x6 xid 0xc23353f2 port OFPPhyPort(port_no=65534, hw_addr='\x16\xd8u\xe7[C', name='br0\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00', config=1, state=1, curr=0, advertised=0, supported=0, peer=0)
+ move onto main mode
+ unhandled event <ryu.controller.dispatcher.EventDispatcherChange object at 0x2fdcfd0>
+