Modified vFW DT Use case description
[integration.git] / docs / docs_vFWDT.rst
1 .. This work is licensed under a Creative Commons Attribution 4.0
2    International License. http://creativecommons.org/licenses/by/4.0
3    
4 .. _docs_vfw_traffic:
5
6 .. contents::
7    :depth: 3
8 ..
9
10 vFW Traffic Distribution Use Case
11 ---------------------------------
12 Description
13 ~~~~~~~~~~~
14
15 The purpose of this work is to show Traffic Distribiution functionality implemented in Casablanca nad Dublin releases on vFW Use Case. 
16 The orchstration workflow triggers a change to traffic distribution (redistribution) done by a traffic balancing/distribution entity (aka anchor point). 
17 The DistributeTraffic action targets the traffic balancing/distribution entity, in some cases DNS, other cases a load balancer external to the VNF instance, as examples. 
18 Traffic distribution (weight) changes intended to take a VNF instance out of service are completed only when all in-flight traffic/transactions have been completed. 
19 DistributeTrafficCheck command may be used to verify initial conditions of redistribution or can be used to verify the state of VNFs and redistribution itself. 
20 To complete the traffic redistribution process, gracefully taking a VNF instance out-of-service/into-service, without dropping in-flight calls or sessions, 
21 QuiesceTraffic/ResumeTraffic command may need to follow traffic distribution changes (assigning weight 0 or very low weight to VNF instance). The VNF application remains in an active state.
22
23
24 Traffic Distribution functionality is an outcome of Change Management project. Further details can be found on following pages
25
26 https://wiki.onap.org/display/DW/Change+Management+Extensions (DistributeTraffic LCM and Use Case)
27
28 https://wiki.onap.org/display/DW/Change+Management+Dublin+Extensions (Distribute Traffic Workflow with Optimization Framework)
29
30 Test Scenario
31 ~~~~~~~~~~~~~
32
33 .. figure:: files/dt-use-case.png
34    :scale: 40 %
35    :align: center
36
37    Figure 1 The idea of Traffic Distribution Use Case
38
39 The idea of the simplified scenario presented in Casablanca release is shown on Figure 1. In a result of the DistributeTraffic LCM action traffic flow originated from vPKG to vFW 1 and vSINK 1 is redirected to vFW 2 and vSINK 2 (as it is seen on Figure 2). 
40 Result of the change can be observed also on the vSINKs' dashboards which show a current incoming traffic. Observation of the dashboard from vSINK 1 and vSINK 2 proves that API works properly.
41
42 .. figure:: files/dt-result.png
43    :scale: 60 %
44    :align: center
45
46    Figure 2 The result of traffic distribution
47
48 The purpose of the workj in Dublin release was to built a Traffic Distribution Workflow that takes as an input configuration parameters delivered by Optimization Framework and on their basis several LCM actions are executed in specific workflow. 
49
50 .. figure:: files/dt-workflow.png
51    :scale: 60 %
52    :align: center
53
54    Figure 3 The Traffic Distribution Workflow
55
56 The prepared Traffic Distribution Workflow has following steps:
57
58 - Workflow sends placement request to Optimization Framework (**1**) specific information about vPKG and vFW-SINK models and VNF-ID of vFW that we want to migrate traffic out from. 
59   Optimization Framework role is to find the vFW-SINK VNF/VF-module instance where traffic should be migrated to and vPKG which will be associated with this vFW. 
60   Altough in our case the calculation is very simple the mechanism is ready to work for service instances with VNF having houndreds of VF-odules spread accross different data centers.
61
62 - Optimization Framework takes from the Policy Framework policies (**2-3**) for VNFs and for relations between each other (in our case there is checked ACTIVE status of vFW-SINK and vPKG VF-modules and the Region to which they belong)
63
64 - Optimization Framework, base on the information from the polcies and service topology information taken from A&AI (**4-11**), offers traffc distribution anchor and destination canidates' pairs (**12-13**) (pairs of VF-modules data with information about their V-Servers and their network interfaces). This information is returned to the workflow script (**14**). 
65
66 - Information from Optimization Framework can be used to construct APPC LCM requests for DistributeTrafficCheck and DistributeTraffic commands (**15, 24, 33, 42**). This information is used to fill CDT templates with proper data for further Ansible playbooks execution (**17, 26, 35, 44**)
67
68 - In the first DistributeTrafficCheck LCM request on vPGN VNF/VF-Module APPC, over Ansible, checks if already configured destinatrion of vPKG packages is different than already configured. If not workflow is stopped (**23**).
69
70 - Next, APPC performs the DistributeTraffic action like it is shown on Figure 1 and Figure 2 (**25-31**). If operation is completed properly traffic should be redirected to vFW 2 and vSINK 2 instance. If not, workflow is stopped (**32**).
71
72 - Finally, APPC executes the DistributeTrafficCheck action on vFW 1 in order to verify that it does not receives any traffic anymore (**34-40**) and on vFW 2 in order to verify that it receives traffic forwrdd from vFW 2 (**43-49**)
73
74 Scenario Setup
75 --------------
76
77 In order to setup the scenario and to test the DistributeTraffic LCM API in action you need to perform the following steps:
78
79 1. Create an instance of vFWDT (vPKG , 2 x vFW, 2 x vSINK) – dedicated for the DistributeTraffic LCM API tests
80
81 #. Gather A&AI facts for Traffic Distribution use case configuration
82
83 #. Install Traffic Distribution workflow packages
84
85 #. Configure Optimization Framework for Traffic Distribution workflow
86
87 #. Configure vPKG and vFW VNFs in APPC CDT tool
88
89 #. Configure Ansible Server to work with vPKG and vFW VMs
90
91 #. Execute Traffic Distribution Workflow 
92
93 You will use the following ONAP K8s VMs or containers:
94
95 -  ONAP Rancher Server – workflow setup and its execution
96
97 -  APPC MariaDB container – setup Ansible adapter for vFWDT VNFs
98
99 -  APPC Ansible Server container – setup of Ansible Server, configuration of playbook and input parameters for LCM actions
100
101 .. note:: In all occurences <K8S-NODE-IP> constant is the IP address of any K8s Node of ONAP OOM installation which hosts ONAP pods i.e. k8s-node-1 and <K8S-RANCHER-IP> constant is the IP address of K8S Rancher Server
102
103 vFWDT Service Instantiation
104 ~~~~~~~~~~~~~~~~~~~~~~~~~~~
105
106 In order to test a DistributeTraffic LCM API functionality a dedicated vFW instance must be prepared. It differs from a standard vFW instance by having an additional VF-module with a second instance of vFW and a second instance of vSINK. Thanks to that when a service instance is deployed there are already available two instances of vFW and vSINK that can be used for verification of DistributeTraffic LCM API – there is no need to use the ScaleOut function to test DistributeTraffic functionality what simplifies preparations for tests.
107
108 In order to instantiate vFWDT service please follow the procedure for standard vFW with following changes. You can create such service manually or you can use robot framework. For manual instantiation:
109
110 1. Please use the following HEAT templates:
111
112 https://github.com/onap/demo/tree/master/heat/vFWDT
113
114 2. Create Virtual Service in SDC with composition like it is shown on Figure 3
115
116 .. figure:: files/vfwdt-service.png
117    :scale: 60 %
118    :align: center
119
120    Figure 3 Composition of vFWDT Service
121
122 3. Use the following payload files in the SDNC-Preload phase during the VF-Module instantiation
123
124 - :download:`vPKG preload example <files/vpkg-preload.json>`
125
126 - :download:`vFW/SNK 1 preload example <files/vfw-1-preload.json>`
127
128 - :download:`vFW/SNK 2 preload example <files/vfw-2-preload.json>`
129
130 .. note:: Use publikc-key that is a pair for private key files used to log into ONAP OOM Rancher server. It will simplify further configuration
131
132 .. note:: vFWDT has a specific configuration of the networks – different than the one in original vFW use case (see Figure 4). Two networks must be created before the heat stack creation: *onap-private* network (10.0.0.0/16 typically) and *onap-external-private* (e.g. "10.100.0.0/16"). The latter one should be connected over a router to the external network that gives an access to VMs. Thanks to that VMs can have a floating IP from the external network assigned automatically in a time of stacks' creation. Moreover, the vPKG heat stack must be created before the vFW/vSINK stacks (it means that the VF-module for vPKG must be created as a first one). The vPKG stack creates two networks for the vFWDT use case: *protected* and *unprotected*; so these networks must be present before the stacks for vFW/vSINK are created.
133
134 .. figure:: files/vfwdt-networks.png
135    :scale: 15 %
136    :align: center
137
138    Figure 4 Configuration of networks for vFWDT service
139
140 4. Go to *robot* folder in Rancher server (being *root* user)
141
142 Go to the Rancher node and locate *demo-k8s.sh* script in *oom/kubernetes/robot* directory. This script will be used to run heatbridge procedure which will update A&AI information taken from OpenStack
143
144 5. Run robot *heatbridge* in order to upload service topology information into A&AI
145
146 ::
147
148     ./demo-k8s.sh onap heatbridge <stack_name> <service_instance_id> <service> <oam-ip-address>
149
150 where:
151
152 - <stack_name> - HEAT stack name from: OpenStack -> Orchestration -> Stacks
153 - <service_instance_id> - is service_instance_id which you can get from VID or AAI REST API
154 - <service> - in our case it should be vFWDT but may different (vFW, vFWCL) if you have assigned different service type in SDC
155 - <oam-ip-address> - it is the name of HEAT input which stores ONAP management network name
156
157 Much easier way to create vFWDT service instance is to trigger it from the robot framework. Robot automates creation of service instance and it runs also heatbridge. To create vFWDT this way:
158
159 1. Go to *robot* folder in Rancher server (being *root* user)
160
161 Go to the Rancher node and locate *demo-k8s.sh* script in *oom/kubernetes/robot* directory. This script will be used to run instantiate vFWDT service
162
163 2. Run robot scripts for vFWDT instantiation
164
165 ::
166
167     ./demo-k8s.sh onap init
168     ./ete-k8s.sh onap instantiateVFWDT
169
170
171 .. note:: You can verify the status of robot's service instantiation process by going to http://<K8S-NODE-IP>:30209/logs/ (login/password: test/test)
172
173 After successful instantiation of vFWDT service go to the OpenStack dashboard and project which is configured for VNFs deployment and locate vFWDT VMs. Choose one and try to ssh into one them to proove that further ansible configuration action will be possible
174
175 ::
176
177     ssh -i <rancher_private_key> ubuntu@<VM-IP>
178
179
180 .. note:: The same private key file is used to ssh into Rancher server and VMs created by ONAP
181
182 Preparation of Workflow Script Environment
183 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
184
185 1. Enter over ssh Rancher server using root user
186
187 ::
188
189     ssh -i <rancher_private_key> root@<K8S-RANCHER-IP>
190
191 2. Clone onap/demo repository
192
193 ::
194
195     git clone --single-branch --branch dublin "https://gerrit.onap.org/r/demo"
196
197 3. Enter vFWDT tutorial directory
198
199 ::
200
201     cd demo/tutorials/vFWDT
202     ls
203
204 which should show following folders
205
206 ::
207
208     root@sb01-rancher:~/demo/tutorials/vFWDT# ls
209     playbooks  preloads  workflow
210
211
212 .. note:: Remeber vFWDT tutorial directory `~/demo/tutorials/vFWDT` for further use
213
214 4. Install python dependencies
215
216 ::
217
218     sudo apt-get install python3-pip
219     pip3 install -r workflow/requirements.txt --user
220
221 Gathering Scenario Facts
222 ------------------------
223 In order to configure CDT tool for execution of Ansible playbooks and for execution of Traffic distribution workflow we need following A&AI facts for vFWDT service
224
225 - **vnf-id** of generic-vnf vFW instance that we want to migrate traffic out from
226 - **vnf-type** of vPKG VNF - required to configure CDT for Distribute Traffic LCMs
227 - **vnf-type** of vFW-SINK VNFs - required to configure CDT for Distribute Traffic LCMs
228
229 Gathering facts from VID Portal
230 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
231
232 1. Enter the VID portal
233
234 :: 
235     
236     https://<K8S-NODE-IP>:30200/vid/welcome.htm
237
238 2. In the left hand menu enter **Search for Existing Service Instances**
239
240 3. Select proper subscriber from the list and press **Submit** button. When service instance of vFWDT Service Type appears Click on **View/Edit** link
241
242 .. note:: The name of the subscriber you can read from the robot logs if your have created vFWDT instance with robot. Otherwise this should be *Demonstration* subscriber
243
244 4. For each VNF in vFWDT service instance note its *vnf-id* and *vnf-type*
245
246 .. figure:: files/vfwdt-vid-vpkg.png
247    :scale: 60 %
248    :align: center
249
250    Figure 5 vnf-type and vnf-id for vPKG VNF
251
252 .. figure:: files/vfwdt-vid-vnf-1.png
253    :scale: 60 %
254    :align: center
255
256    Figure 6 vnf-type and vnf-id for vFW-SINK 1 VNF
257
258 .. figure:: files/vfwdt-vid-vnf-2.png
259    :scale: 60 %
260    :align: center
261
262    Figure 7 vnf-type and vnf-id for vFW-SINK 2 VNF
263
264 Gathering facts directly from A&AI
265 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
266
267 1. Enter OpenStack dashboard on whicvh vFWDT instance was created and got to **Project->Compute->Instances** and read VM names of vPKG VM and 2 vFW VMs created in vFWDT service instance
268
269 2. Open Postman or any other REST client
270
271 3. In Postman in General Settings disable *SSL Certificate verification*
272
273 4. You can use also following Postman Collection for AAI :download:`AAI Postman Collection <files/vfwdt-aai-postman.json>`
274
275 5. Alternatively create Collection and set its *Authorization* to *Basic Auth* type with login/password: AAI/AAI
276
277 6. Create new GET query for *tenants* type with following link and read *tenant-id* value
278
279 ::
280
281     https://<K8S-NODE-IP>:30233/aai/v14/cloud-infrastructure/cloud-regions/cloud-region/CloudOwner/RegionOne/tenants/
282
283 .. note:: *CloudOwner* and *Region* names are fixed for default setup of ONAP
284
285 7. Create new GET query for *vserver* type with following link replacing <tenant-id> with value read before and <vm-name> with vPKG VM name read from OpenStack dashboard
286
287 ::
288
289     https://<K8S-NODE-IP>:30233/aai/v14/cloud-infrastructure/cloud-regions/cloud-region/CloudOwner/RegionOne/tenants/tenant/<tenant-id>/vservers/?vserver-name=<vm-name>
290
291 Read from the response (realtionship with *generic-vnf* type) vnf-id of vPKG VNF
292
293 .. note:: If you do not receive any vserver candidate it means that heatbridge procedure was not performed or was not completed successfuly. It is mandatory to continue this tutorial
294
295 8. Create new GET query for *generic-vnf* type with following link replacing <vnf-id> with value read from previous GET response
296
297 ::
298
299     https://<K8S-NODE-IP>:30233/aai/v14/network/generic-vnfs/generic-vnf/<vnf-id>
300
301 9. Repeat this procedure also for 2 vFW VMs and note their *vnf-type* and *vnf-id*
302
303 Configuration of ONAP Environment
304 ---------------------------------
305 This sections show the steps necessary to configure CDT and Ansible server what is required for execution of APPC LCM actions in the workflow script
306
307 Testing Gathered Facts on Workflow Script
308 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
309
310 Having collected *vnf-id* and *vnf-type* parameters we can execute Traffic Distribution Workflow Python script. It works in two modes. First one executes ony initial phase where AAI and OOF 
311 is used to collect neccessary information for configuration of APPC and for further execution phase. The second mode performs also second phase which executes APPC LCM actions.
312
313 At this stage we will execute script in the initial mode to generate some configuration helpful in CDT and Ansible configuration.
314
315 1. Enter vFWDT tutorial directory on Rancher server (already created in `Preparation of Workflow Script Environment`_) and execute there workflow script with follwoing parameters
316
317 ::
318
319     python3 workflow.py <VNF-ID> <K8S-NODE-IP> True False True True
320
321 For now and for further use workflow script has following input parameters:
322
323 - vnf-id of vFW VNF instance that traffic should be migrated out from
324 - IP of ONAP OOM Node
325 - if script should use and build OOF response cache (cache it speed-ups further executions of script)
326 - if instead of vFWDT service instance vFW or vFWCL one is used (should be False always)
327 - if only configuration information will be collected (True for initial phase and False for full execution of workflow)
328 - if APPC LCM action status should be verified and FAILURE should stop workflow (when False FAILED status of LCM action does not stop execution of further LCM actions)
329
330 2. The script at this stage should give simmilar output 
331
332 ::
333
334     Executing workflow for VNF ID '909d396b-4d99-4c6a-a59b-abe948873303' on ONAP with IP 10.12.5.63
335
336     OOF Cache True, is CL vFW False, only info False, check LCM result True
337
338     vFWDT Service Information:
339     {
340         "vf-module-id": "0dce0e61-9309-449a-8e3e-f001635aaab1",
341         "service-info": {
342             "global-customer-id": "DemoCust_ccc04407-1740-4359-b3c4-51bbcb62d9f6",
343             "service-type": "vFWDT",
344             "service-instance-id": "ab37d391-95c6-4844-b7c3-23d111bfa2ce"
345         },
346         "vfw-model-info": {
347             "model-version-id": "f7fc17ba-48b9-456b-acc1-f89f31eda8cc",
348             "vnf-type": "vFWDT 2019-05-20 21:10:/vFWDT_vFWSNK b463aa83-b1fc 0",
349             "model-invariant-id": "0dfe8d6d-21c1-42f6-867a-1867cebb7751",
350             "vnf-name": "Ete_vFWDTvFWSNK_ccc04407_1"
351         },
352         "vpgn-model-info": {
353             "model-version-id": "0f8a2467-af44-4d7c-ac55-a346dcad9e0e",
354             "vnf-type": "vFWDT 2019-05-20 21:10:/vFWDT_vPKG a646a255-9bee 0",
355             "model-invariant-id": "75e5ec48-f43e-40d2-9877-867cf182e3d0",
356             "vnf-name": "Ete_vFWDTvPKG_ccc04407_0"
357         }
358     }
359
360     Ansible Inventory:
361     [vpgn]
362     vofwl01pgn4407 ansible_ssh_host=10.0.210.103 ansible_ssh_user=ubuntu
363     [vfw-sink]
364     vofwl01vfw4407 ansible_ssh_host=10.0.110.1 ansible_ssh_user=ubuntu
365     vofwl02vfw4407 ansible_ssh_host=10.0.110.4 ansible_ssh_user=ubuntu
366
367 The result should have almoast the same information for *vnf-id's* of both vFW VNFs. *vnf-type* for vPKG and vFW VNFs should be the same like those collected in previous steps. 
368 Ansible Inventory section contains information about the content Ansible Inventor file that will be configured later on `Configuration of Ansible Server`_
369
370 Configuration of VNF in the APPC CDT tool
371 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
372
373 Following steps aim to configure DistributeTraffic LCM action for our vPKG and vFW-SINK VNFs in APPC CDT tool.
374
375 1. Enter the Controller Design Tool portal
376
377 ::
378
379     https://<K8S-NODE-IP>:30289/index.html
380
381 2. Click on *MY VNFS* button and login to CDT portal giving i.e. *demo* user name
382
383 3. Click on the *CREATE NEW VNF TYPE* button
384
385 .. figure:: files/vfwdt-create-vnf-type.png
386    :scale: 70 %
387    :align: center
388
389    Figure 8 Creation of new VNF type in CDT
390
391 4. Enter previously retrieved VNF Type for vPKG VNF and press the *NEXT* button
392
393 .. figure:: files/vfwdt-enter-vnf-type.png
394    :scale: 70 %
395    :align: center
396
397    Figure 9 Creation of new VNF type in CDT
398
399 5. For already created VNF Type (if the view does not open itself) click the *View/Edit* button. In the LCM action edit view in the first tab please choose:
400
401 -  *DistributeTraffic* as Action name
402
403 -  *ANSIBLE* as Device Protocol
404
405 -  *Y* value in Template dropdown menu
406
407 -  *admin* as User Name
408
409 -  *8000* as Port Number
410
411
412 .. figure:: files/vfwdt-new-lcm-ref-data.png
413    :scale: 70 %
414    :align: center
415
416    Figure 10 DistributeTraffic LCM action editing
417
418 6. Go to the *Template* tab and in the editor paste the request template of the DistributeTraffic LCM action for vPKG VNF type
419
420 ::
421
422     {
423         "InventoryNames": "VM",
424         "PlaybookName": "${()=(book_name)}",
425         "NodeList": [{
426             "vm-info": [{
427                 "ne_id": "${()=(ne_id)}", 
428                 "fixed_ip_address": "${()=(fixed_ip_address)}"
429             }], 
430             "site": "site",
431             "vnfc-type": "vpgn"
432         }],
433         "EnvParameters": {
434             "ConfigFileName": "../traffic_distribution_config.json",
435             "vnf_instance": "vfwdt",
436         },
437         "FileParameters": {
438             "traffic_distribution_config.json": "${()=(file_parameter_content)}"
439         },
440         "Timeout": 3600
441     }
442
443 .. note:: For all this VNF types and for all actions CDT template is the same except **vnfc-type** parameter that for vPKG VNF type should have value *vpgn* and for vFW-SINK VNF type should have value *vfw-sink*
444
445 The meaning of selected template parameters is following:
446
447 - **EnvParameters** group contains all the parameters that will be passed directly to the Ansible playbook during the request's execution. *vnf_instance* is an obligatory parameter for VNF Ansible LCMs. In our case for simplification it has predefined value
448 - **InventoryNames** parameter is obligatory if you want to have NodeList with limited VMs or VNFCs that playbook should be executed on. It can have value *VM* or *VNFC*. In our case *VM* valuye means that NodeList will have information about VMs on which playbook should be executed. In this use case this is always only one VM
449 - **NodeList** parameter value must match the group of VMs like it was specified in the Ansible inventory file. *PlaybookName* must be the same as the name of playbook that was uploaded before to the Ansible server.
450 - **FileParameters**
451
452
453 .. figure:: files/vfwdt-create-template.png
454    :scale: 70 %
455    :align: center
456
457    Figure 11 LCM DistributeTraffic request template
458
459 7. Afterwards press the *SYNCHRONIZE WITH TEMPLATE PARAMETERS* button. You will be moved to the *Parameter Definition* tab. The new parameters will be listed there.
460
461 .. figure:: files/vfwdt-template-parameters.png
462    :scale: 70 %
463    :align: center
464
465    Figure 12 Summary of parameters specified for DistributeTraffic LCM action.
466
467 .. note:: For each parameter you can define its: mandatory presence; default value; source (Manual/A&AI). For our case modification of this settings is not necessary
468
469 8. Finally, go back to the *Reference Data* tab and click *SAVE ALL TO APPC*.
470
471 .. note:: Remember to configure DistributeTraffic and DistributeTrafficCheck actions for vPKG VNF type and DistributeTrafficCheck action for vFW-SINK
472
473 Configuration of Ansible Server
474 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
475
476 After an instantiation of the vFWDT service the Ansible server must be configured in order to allow it a reconfiguration of vPKG VM.
477
478 1. Copy from Rancher server private key file used for vFWDT VMs' creation and used for access to Rancher server into the :file:`/opt/ansible-server/Playbooks/onap.pem` file
479
480 ::
481
482     sudo kubectl cp <path/to/file>/onap.pem onap/`kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep appc-ansible`:/opt/ansible-server/Playbooks/
483
484 .. note:: The private key file must be the same like configured at this stage `vFWDT Service Instantiation`_
485
486 2. Enter the Rancher server and then enter the APPC Ansible server container
487
488 ::
489
490     kubectl exec -it -n onap `kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep appc-ansible` -- sh
491
492 3. Give the private key file a proper access rights
493
494 ::
495
496     cd /opt/ansible-server/Playbooks/
497     chmod 400 onap.pem
498     chown ansible:ansible onap.pem
499
500 4. Edit the :file:`/opt/ansible-server/Playbooks/Ansible\ \_\ inventory` file including all the hosts of vFWDT service instance used in this use case. 
501    The content of the file is generated by workflow script `Testing Gathered Facts on Workflow Script`_
502
503 ::
504
505     [vpgn]
506     vofwl01pgn4407 ansible_ssh_host=10.0.210.103 ansible_ssh_user=ubuntu
507     [vfw-sink]
508     vofwl01vfw4407 ansible_ssh_host=10.0.110.1 ansible_ssh_user=ubuntu
509     vofwl02vfw4407 ansible_ssh_host=10.0.110.4 ansible_ssh_user=ubuntu
510
511 .. note:: Names of hosts and their IP addresses will be different. The names of the host groups are the same like 'vnfc-type' attributes configured in the CDT templates
512
513 5. Configure the default private key file used by Ansible server to access hosts over ssh
514
515 ::
516
517     vi /etc/ansible/ansible.cfg
518
519 ::
520
521     [defaults]
522     host_key_checking = False
523     private_key_file = /opt/ansible-server/Playbooks/onap.pem
524
525
526 .. note:: This is the default privaye key file. In the `/opt/ansible-server/Playbooks/Ansible\ \_\ inventory` different key could be configured but APPC in time of execution of playbbok on Ansible server creates its own dedicated inventory file which does not have private key file specified. In consequence, this key file configured is mandatory for proper execution of playbooks by APPC
527
528
529 6. Test that the Ansible server can access over ssh vFWDT hosts configured in the ansible inventory 
530
531 ::
532
533     ansible –i Ansible_inventory vpgn,vfw-sink –m ping
534
535
536 7. Download the distribute traffic playbook into the :file:`/opt/ansible-server/Playbooks` directory
537
538 Exit Ansible server pod and enter vFWDT tutorial directory `Preparation of Workflow Script Environment`_ on Rancher server. Afterwards, copy playbooks into Ansible server pod
539
540 ::
541
542     sudo kubectl cp playbooks/vfw-sink onap/`kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep appc-ansible`:/opt/ansible-server/Playbooks/
543     sudo kubectl cp playbooks/vpgn onap/`kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep appc-ansible`:/opt/ansible-server/Playbooks/
544
545 8. After the configuration of Ansible serverthe structure of `/opt/ansible-server/Playbooks` directory should be following
546
547 ::
548
549     /opt/ansible-server/Playbooks $ ls -R
550     .:
551     Ansible_inventory  onap.pem           vfw-sink           vpgn
552
553     ./vfw-sink:
554     latest
555
556     ./vfw-sink/latest:
557     ansible
558
559     ./vfw-sink/latest/ansible:
560     distributetrafficcheck
561
562     ./vfw-sink/latest/ansible/distributetrafficcheck:
563     site.yml
564
565     ./vpgn:
566     latest
567
568     ./vpgn/latest:
569     ansible
570
571     ./vpgn/latest/ansible:
572     distributetraffic       distributetrafficcheck
573
574     ./vpgn/latest/ansible/distributetraffic:
575     site.yml
576
577     ./vpgn/latest/ansible/distributetrafficcheck:
578     site.yml
579
580
581 Configuration of APPC DB for Ansible
582 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
583
584 For each VNF that uses the Ansible protocol you need to configure *PASSWORD* and *URL* field in the *DEVICE_AUTHENTICATION* table. This step must be performed after configuration in CDT which populates data in *DEVICE_AUTHENTICATION* table.
585
586 1. Enter the APPC DB container
587
588 ::
589
590     kubectl exec -it -n onap `kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep appc-db-0` -- sh
591
592 2. Enter the APPC DB CLI (password is *gamma*)
593
594 ::
595
596     mysql -u sdnctl -p
597
598 3. Execute the following SQL commands
599
600 ::
601
602     MariaDB [(none)]> use sdnctl;
603     MariaDB [sdnctl]> UPDATE DEVICE_AUTHENTICATION SET URL = 'http://appc-ansible-server:8000/Dispatch' WHERE ACTION LIKE 'DistributeTraffic%';
604     MariaDB [sdnctl]> UPDATE DEVICE_AUTHENTICATION SET PASSWORD = 'admin' WHERE ACTION LIKE 'DistributeTraffic%';
605     MariaDB [sdnctl]> select * from DEVICE_AUTHENTICATION;
606
607 Result should be simmilar to the following one:
608
609 ::
610
611     +--------------------------+------------------------------------------------------+----------+------------------------+-----------+----------+-------------+------------------------------------------+
612     | DEVICE_AUTHENTICATION_ID | VNF_TYPE                                             | PROTOCOL | ACTION                 | USER_NAME | PASSWORD | PORT_NUMBER | URL                                      |
613     +--------------------------+------------------------------------------------------+----------+------------------------+-----------+----------+-------------+------------------------------------------+
614     |                      137 | vFWDT 2019-05-20 21:10:/vFWDT_vPKG a646a255-9bee 0   | ANSIBLE  | DistributeTraffic      | admin     | admin    |        8000 | http://appc-ansible-server:8000/Dispatch |
615     |                      143 | vFWDT 2019-05-20 21:10:/vFWDT_vFWSNK b463aa83-b1fc 0 | ANSIBLE  | DistributeTraffic      | admin     | admin    |        8000 | http://appc-ansible-server:8000/Dispatch |
616     |                      149 | vFWDT 2019-05-20 21:10:/vFWDT_vFWSNK b463aa83-b1fc 0 | ANSIBLE  | DistributeTrafficCheck | admin     | admin    |        8000 | http://appc-ansible-server:8000/Dispatch |
617     |                      152 | vFWDT 2019-05-20 21:10:/vFWDT_vPKG a646a255-9bee 0   | ANSIBLE  | DistributeTrafficCheck | admin     | admin    |        8000 | http://appc-ansible-server:8000/Dispatch |
618     +--------------------------+------------------------------------------------------+----------+------------------------+-----------+----------+-------------+------------------------------------------+
619     4 rows in set (0.00 sec)
620
621
622 Testing Traffic Distribution Workflow
623 -------------------------------------
624
625 Since all the configuration of components of ONAP is already prepared it is possible to enter second phase of Traffic Distribution Workflow execution - 
626 the execution of DistributeTraffic and DistributeTrafficCheck LCM actions with configuration resolved before by OptimizationFramework. 
627
628
629 Workflow Execution
630 ~~~~~~~~~~~~~~~~~~
631
632 In order to run Traffic Distribution Workflow execute following commands from the vFWDT tutorial directory `Preparation of Workflow Script Environment`_ on Rancher server.
633
634 ::
635
636     cd workflow
637     python3 workflow.py 909d396b-4d99-4c6a-a59b-abe948873303 10.12.5.63 True False False True
638
639
640 The order of executed LCM actions is following:
641
642 1. DistributeTrafficCheck on vPKG VM - ansible playbook checks if traffic destinations specified by OOF is not configued in the vPKG and traffic does not go from vPKG already.
643    If vPKG send alreadyt traffic to destination the playbook will fail and workflow will break.
644 2. DistributeTraffic on vPKG VM - ansible playbook reconfigures vPKG in order to send traffic to destination specified before by OOF. When everything is fine at this stage
645    change of the traffic should be observed on following dashboards (please turn on automatic reload of graphs)
646
647     ::
648         
649         http://<vSINK-1-IP>:667/
650         http://<vSINK-2-IP>:667/
651
652 3. DistributeTrafficCheck on vFW-1 VM - ansible playbook checks if traffic is not present on vFW from which traffic should be migrated out. If traffic is still present after 30 seconds playbook fails
653 4. DistributeTrafficCheck on vFW-2 VM - ansible playbook checks if traffic is present on vFW from which traffic should be migrated out. If traffic is still not present after 30 seconds playbook fails
654
655
656 Workflow Results
657 ~~~~~~~~~~~~~~~~
658
659 Expected result of workflow execution, when everythin is fine, is following:
660
661 ::
662
663     Distribute Traffic Workflow Execution:
664     APPC REQ 0 - DistributeTrafficCheck
665     Request Accepted. Receiving result status...
666     Checking LCM DistributeTrafficCheck Status
667     IN_PROGRESS
668     IN_PROGRESS
669     IN_PROGRESS
670     IN_PROGRESS
671     SUCCESSFUL
672     APPC REQ 1 - DistributeTraffic
673     Request Accepted. Receiving result status...
674     Checking LCM DistributeTraffic Status
675     IN_PROGRESS
676     IN_PROGRESS
677     IN_PROGRESS
678     IN_PROGRESS
679     IN_PROGRESS
680     IN_PROGRESS
681     IN_PROGRESS
682     IN_PROGRESS
683     IN_PROGRESS
684     IN_PROGRESS
685     IN_PROGRESS
686     IN_PROGRESS
687     IN_PROGRESS
688     IN_PROGRESS
689     IN_PROGRESS
690     IN_PROGRESS
691     IN_PROGRESS
692     IN_PROGRESS
693     IN_PROGRESS
694     SUCCESSFUL
695     APPC REQ 2 - DistributeTrafficCheck
696     Request Accepted. Receiving result status...
697     Checking LCM DistributeTrafficCheck Status
698     IN_PROGRESS
699     IN_PROGRESS
700     IN_PROGRESS
701     IN_PROGRESS
702     IN_PROGRESS
703     IN_PROGRESS
704     IN_PROGRESS
705     IN_PROGRESS
706     IN_PROGRESS
707     SUCCESSFUL
708     APPC REQ 3 - DistributeTrafficCheck
709     Request Accepted. Receiving result status...
710     Checking LCM DistributeTrafficCheck Status
711     IN_PROGRESS
712     IN_PROGRESS
713     IN_PROGRESS
714     IN_PROGRESS
715     IN_PROGRESS
716     IN_PROGRESS
717     IN_PROGRESS
718     SUCCESSFUL
719
720 In case of failure the result can be following:
721
722 ::
723
724     Distribute Traffic Workflow Execution:
725     APPC REQ 0 - DistributeTrafficCheck
726     Request Accepted. Receiving result status...
727     Checking LCM DistributeTrafficCheck Status
728     IN_PROGRESS
729     IN_PROGRESS
730     IN_PROGRESS
731     IN_PROGRESS
732     IN_PROGRESS
733     IN_PROGRESS
734     IN_PROGRESS
735     IN_PROGRESS
736     IN_PROGRESS
737     IN_PROGRESS
738     IN_PROGRESS
739     IN_PROGRESS
740     IN_PROGRESS
741     IN_PROGRESS
742     IN_PROGRESS
743     FAILED
744     Traceback (most recent call last):
745     File "workflow.py", line 563, in <module>
746         sys.argv[5].lower() == 'true', sys.argv[6].lower() == 'true')
747     File "workflow.py", line 557, in execute_workflow
748         confirm_appc_lcm_action(onap_ip, req, check_result)
749     File "workflow.py", line 529, in confirm_appc_lcm_action
750         raise Exception("LCM {} {} - {}".format(req['input']['action'], status['status'], status['status-reason']))
751     Exception: LCM DistributeTrafficCheck FAILED - FAILED
752
753 .. note:: When CDT and Ansible is configured properly Traffic Distribution Workflow can fail when you pass as a vnf-id argument the ID of vFW VNF which does not handle traffic at the moment. To solve that pass the VNF ID of the other vFW VNF instance. Because of the same reason you cannot execute twice in a row workflow for the same VNF ID if first execution succedds.