From 6d5e6da83f102e7468db68e1ae55e4c8f539a27f Mon Sep 17 00:00:00 2001 From: Laura Sofia Enriquez Date: Thu, 1 Feb 2018 15:58:34 -0300 Subject: Clearwater documentation Documentation for clearwater implementation. Change-Id: I6cc06f82aeb8b75f64b239f629866f22c8cca60e Signed-off-by: Laura Sofia Enriquez --- docs/release/userguide/clearwater-project.rst | 168 +++++++++++++++++++++++++- docs/release/userguide/img/blink01.png | Bin 0 -> 136470 bytes docs/release/userguide/img/blink02.png | Bin 0 -> 181973 bytes docs/release/userguide/img/blink03.png | Bin 0 -> 131215 bytes docs/release/userguide/img/blink04.png | Bin 0 -> 73794 bytes docs/release/userguide/img/call.png | Bin 0 -> 147388 bytes docs/release/userguide/img/twinkle01.png | Bin 0 -> 184693 bytes docs/release/userguide/img/twinkle02.png | Bin 0 -> 175079 bytes docs/release/userguide/img/twinkle03.png | Bin 0 -> 184875 bytes 9 files changed, 162 insertions(+), 6 deletions(-) create mode 100644 docs/release/userguide/img/blink01.png create mode 100644 docs/release/userguide/img/blink02.png create mode 100644 docs/release/userguide/img/blink03.png create mode 100644 docs/release/userguide/img/blink04.png create mode 100644 docs/release/userguide/img/call.png create mode 100644 docs/release/userguide/img/twinkle01.png create mode 100644 docs/release/userguide/img/twinkle02.png create mode 100644 docs/release/userguide/img/twinkle03.png (limited to 'docs/release/userguide') diff --git a/docs/release/userguide/clearwater-project.rst b/docs/release/userguide/clearwater-project.rst index 6a5ac60..38f1c7a 100644 --- a/docs/release/userguide/clearwater-project.rst +++ b/docs/release/userguide/clearwater-project.rst @@ -1,24 +1,25 @@ +*********************************** Clearwater implementation for OPNFV -=================================== +*********************************** CONTAINER4NFV setup a Kubernetes cluster on VMs running with Vagrant and kubeadm. kubeadm assumes you have a set of machines (virtual or bare metal) that are up and running. In this way we can get a cluster with one master node and 2 workers (default). If you want to increase the number of workers nodes, please check the Vagrantfile inside the project. -Is Clearwater suitable for Network Functions Virtualization? +*Is Clearwater suitable for Network Functions Virtualization?* Network Functions Virtualization or NFV is, without any doubt, the hottest topic in the telco network space right now. It’s an approach to building telco networks that moves away from proprietary boxes wherever possible to use software components running on industry-standard virtualized IT infrastructures. Over time, many telcos expect to run all their network functions operating at Layer 2 and above in an NFV environment, including IMS. Since Clearwater was designed from the ground up to run in virtualized environments and take full advantage of the flexibility of the Cloud, it is extremely well suited for NFV. Almost all of the ongoing trials of Clearwater with major network operators are closely associated with NFV-related initiatives. About Clearwater ----------------- +################ -[Clearwater](http://www.projectclearwater.org/about-clearwater/) follows [IMS](https://en.wikipedia.org/wiki/IP_Multimedia_Subsystem) architectural principles and supports all of the key standardized interfaces expected of an IMS core network. But unlike traditional implementations of IMS, Clearwater was designed from the ground up for the Cloud. By incorporating design patterns and open source software components that have been proven in many global Web applications, Clearwater achieves an unprecedented combination of massive scalability and exceptional cost-effectiveness. +`Clearwater `_ follows `IMS `_ architectural principles and supports all of the key standardized interfaces expected of an IMS core network. But unlike traditional implementations of IMS, Clearwater was designed from the ground up for the Cloud. By incorporating design patterns and open source software components that have been proven in many global Web applications, Clearwater achieves an unprecedented combination of massive scalability and exceptional cost-effectiveness. Clearwater provides SIP-based call control for voice and video communications and for SIP-based messaging applications. You can use Clearwater as a standalone solution for mass-market VoIP services, relying on its built-in set of basic calling features and standalone susbscriber database, or you can deploy Clearwater as an IMS core in conjunction with other elements such as Telephony Application Servers and a Home Subscriber Server. -Clearwater was designed from the ground up to be optimized for deployment in virtualized and cloud environments. It leans heavily on established design patterns for building and deploying massively scalable web applications, adapting these design patterns to fit the constraints of SIP and IMS. [The Clearwater architecture](http://www.projectclearwater.org/technical/clearwater-architecture/) therefore has some similarities to the traditional IMS architecture but is not identical. +Clearwater was designed from the ground up to be optimized for deployment in virtualized and cloud environments. It leans heavily on established design patterns for building and deploying massively scalable web applications, adapting these design patterns to fit the constraints of SIP and IMS. `The Clearwater architecture `_ therefore has some similarities to the traditional IMS architecture but is not identical. - All components are horizontally scalable using simple, stateless load-balancing. - All long lived state is stored on dedicated “Vellum” nodes which make use of cloud-optimized storage technologies such as Cassandra. No long lived state is stored on other production nodes, making it quick and easy to dynamically scale the clusters and minimizing the impact if a node is lost. @@ -27,8 +28,163 @@ Clearwater was designed from the ground up to be optimized for deployment in vir Clearwater Architecture ------------------------ +####################### .. image:: img/clearwater_architecture.png :width: 800px :alt: Clearwater Architecture + + +********** +Quickstart +********** + +This repository contains instructions and resources for deploying Metaswitch's Clearwater project with Kubernetes. + + +If you need more information about Clearwater project please checkout our +[documentation](https://github.com/opnfv/container4nfv/blob/master/docs/release/userguide/clearwater-project.rst) +or the `official repository `_. + + +Exposed Services +################ + + +The deployment exposes: + + - the Ellis web UI on port 30080 for self-provisioning. + - STUN/TURN on port 3478 for media relay. + - SIP on port 5060 for service. + - SIP/WebSocket on port 5062 for service. + +SIP devices can register with bono.:5060 and the Ellis provisioning interface can be accessed at port 30080. + + +Prerequirement +############## + +Install Docker and Vagrant +******************************************** + +CONTAINER4NFV uses ``setup_vagrant.sh`` to install all resource used by this repository. + +:: + + container4nfv/src/vagrant# ./setup_vagrant.sh -b libvirt + +Instalation +############## + +Deploy Clearwater with kubeadm +******************************************** + +Check ``clearwater/clearwater_setup.sh`` for details about k8s deployment. + + +:: + + container4nfv/src/vagrant/kubeadm_clearwater# ./deploy.sh + + +Destroy +########## + +:: + + container4nfv/src/vagrant# ./cleanup.sh + + +Making calls through Clearwater +############################### + + +Connect to Ellis service +******************************************** +It's important to connect to Ellis to generate the SIP username, password and domain we will use with the SIP client. +Use your + port 30080 (k8s default port). If you are not which Ellis's url is, please check inside your master node. + +:: + + kubeadm_clearwater# vagrant ssh master + master@vagrant# ifconfig eth0 | grep "inet addr" | cut -d ':' -f 2 | cut -d ' ' -f 1 + 192.168.121.3 + +In your browser connect to `:30080` (ex. 192.168.121.3:30080). + + +After that, signup and generate two users. The signup key is **secret**. Ellis will automatically allocate you a new number and display +its password to you. Remember this password as it will only be displayed once. +From now on, we will use to refer to the SIP username (e.g. 6505551234) and to refer to the password. + + +Config and install two SIP clients +******************************************** +We'll use both Twinkle and Blink SIP client. , since we are going to try this out inside a LAN network. +This is, of course, only a local test inside a LAN network. Configure the clients may be a little bit trickie, so we add some screenshots: + + +Blink setup +******************************************** +1. Add and . + +.. image:: img/blink01.png + :width: 800px + :alt: Blink SIP client + + +2. Configure a proxy to k8s. + + +.. image:: img/blink02.png + :width: 800px + :alt: Blink SIP client + + +3. Configure the network to use TCP only. + + +.. image:: img/blink03.png + :width: 800px + :alt: Blink SIP client + + +.. image:: img/blink04.png + :width: 800px + :alt: Blink SIP client + + +Twinkle setup +******************************************** + +1. Configure a proxy to k8s. + + +.. image:: img/twinkle01.png + :width: 800px + :alt: Twinkle SIP client + + +2. Add and . + + +.. image:: img/twinkle02.png + :width: 800px + :alt: Twinkle SIP client + + +3. Configure the network to use TCP only. + + +.. image:: img/twinkle03.png + :width: 800px + :alt: Twinkle SIP client + + +Make the call +******************************************** + + +.. image:: img/call.png + :width: 800px + :alt: Call diff --git a/docs/release/userguide/img/blink01.png b/docs/release/userguide/img/blink01.png new file mode 100644 index 0000000..ac74788 Binary files /dev/null and b/docs/release/userguide/img/blink01.png differ diff --git a/docs/release/userguide/img/blink02.png b/docs/release/userguide/img/blink02.png new file mode 100644 index 0000000..7eb8d46 Binary files /dev/null and b/docs/release/userguide/img/blink02.png differ diff --git a/docs/release/userguide/img/blink03.png b/docs/release/userguide/img/blink03.png new file mode 100644 index 0000000..ae6220a Binary files /dev/null and b/docs/release/userguide/img/blink03.png differ diff --git a/docs/release/userguide/img/blink04.png b/docs/release/userguide/img/blink04.png new file mode 100644 index 0000000..17511b5 Binary files /dev/null and b/docs/release/userguide/img/blink04.png differ diff --git a/docs/release/userguide/img/call.png b/docs/release/userguide/img/call.png new file mode 100644 index 0000000..ec4cdbf Binary files /dev/null and b/docs/release/userguide/img/call.png differ diff --git a/docs/release/userguide/img/twinkle01.png b/docs/release/userguide/img/twinkle01.png new file mode 100644 index 0000000..e424d51 Binary files /dev/null and b/docs/release/userguide/img/twinkle01.png differ diff --git a/docs/release/userguide/img/twinkle02.png b/docs/release/userguide/img/twinkle02.png new file mode 100644 index 0000000..8d95bae Binary files /dev/null and b/docs/release/userguide/img/twinkle02.png differ diff --git a/docs/release/userguide/img/twinkle03.png b/docs/release/userguide/img/twinkle03.png new file mode 100644 index 0000000..4b4b5c7 Binary files /dev/null and b/docs/release/userguide/img/twinkle03.png differ -- cgit 1.2.3-korg