blob: 636d727f4dd8219fb1503bf7c4361277f134985c [file] [log] [blame]
Rene_Robert9859c932019-08-14 15:49:28 +02001.. This work is licensed under a Creative Commons Attribution 4.0
2 International License.
3.. http://creativecommons.org/licenses/by/4.0
4
5Instantiate Service, VNF, VF modules and Network
6================================================
7
8
9Overview
10--------
11
12Using VID with A-La-Carte method means that the user needs to performed
13by himself the instantiation of each object : service, VNF(s), VF module(s),
14network(s).
15
16ONAP to VIM interactions will occurs when instantiating/deleting VF module(s)
17or Network(s). In case of an Openstack VIM, Heat Stack(s) will
18be created/deleted.
19
20In the following description, the service model in SDC was composed of 1 VF
21and 1 Virtual Link (Generic Neutron Network)
22
23To be able to instantiate VF-module or Network object, some data need to be
24declared in ONAP SDNC using SDNC Rest API. It is the place where to put
25the instance specific values such as an IP address value specific
26to the VNF instance for example.
27
28In VID, terminologies are sometimes different than in other components:
29
30VNF in VID = VF in SDC
31
32Node instance = VF in SDC
33
34Network = Virtual Link in SDC
35
36
37Pre-requisites
38--------------
39
40pre-instantiation operations must have been performed in AAI and VID,
41via Rest API, to declare some values for:
42
43- Subscriber Name (= customer in AAI)
44- Service Type or product family (= service subscription in AAI)
45- Project
46- Owning Entity
47- Line Of Business
48- Platform
49- LCP Region (= CloudOwner/RegionId in AAI)
50- Tenant
51
52see, in the ONAP User Guides, section about adding a CloudSite
53and section about pre-instantiation Operations
54
55
56Access to VID portal
57--------------------
58
59.. figure:: images/onap-portal.png
60 :align: center
61
62Select the VID icon
63
64.. figure:: images/vid-icon-on-portal.png
65 :align: center
66
67
68Here after, the VID Home page starts
69
70.. figure:: images/home.png
71 :align: center
72
73
74SDNC API selection
75------------------
76
77Select the API for "A-la-carte"
78
79There are two choices:
80
81- VNF_API (old) : VID will use the (old) "VNF" SDNC API
82 to get/check some parameters
83- GR_API (new) : VID will use the "Generic Resource"
84 SDNC API to get/check some parameters
85
86.. figure:: images/API_selection.png
87 :align: center
88
89
90
91Instantiate Service
92-------------------
93
94Click Browse SDC Service Models and search for the service to instantiate.
95
96The view show only service models in the DISTRIBUTED state.
97
98.. figure:: images/browse-service-models.png
99 :align: center
100
101
102Select a service and click Deploy.
103
104A dialog box displays.
105
106Complete the fields indicated by the red star and click Confirm.
107
108.. figure:: images/create-service-instance-alacarte.png
109 :align: center
110
111A status ox appears that shows the ONAP SO instantiation progress
112as well as any messages associated with the process.
113
114.. figure:: images/create-service-instance-alacarte-success.png
115 :align: center
116
117A Service object is created in ONAP.
118
119Click Close and next screen should appear.
120It will allow to declare VNF(s) and Network(s)
121that are part of the service model composition.
122
123.. figure:: images/create-service-instance-alacarte-VNF-network.png
124 :align: center
125
126
127Instantiate a VNF
128-----------------
129
130From previous screen, it is possible to declare a VNF: click on
131"Add node instance" and select the VNF you want to instantiate in the list
132
133The following screen should appear:
134
135.. figure:: images/create-vnf-instance-alacarte.png
136 :align: center
137
138Complete the fields indicated by the red star and click Confirm.
139
140A VNF object will be declared in ONAP.
141
142Once, ONAP SO process is finished, click on close button.
143
144The following screen then should appear:
145
146
147.. figure:: images/create-service-instance-alacarte-after-vnf-instantiated.png
148 :align: center
149
150
151Warning: a this step, no VNF instance (e.g. VM) is created on the Cloud Platform.
152
153Click on "i" blue button to obtain VNF instance display information.
154
155From this screen, it will be possible to get:
156
157- the service instance id value
158- the VNF Type value
159
160Those information will be necessary for the "SDNC preload" step
161to instantiate the VF module
162
163Close that screen
164
165
166Instantiate VF Module
167---------------------
168
169It is now possible to declare a VF Module: click on
170"Add VF-Module" and select the VF-module you want to instantiate in the list
171
172The following screen should appear:
173
174.. figure:: images/create-vfmodule-instance-alacarte.png
175 :align: center
176
177From this screen, it will be possible to get:
178
179- "Model Name" value
180
181At this step, with this "A-La-Carte" method, it is necessary to declare
182some information in ONAP SDNC.
183
184SDNC needs to be aware about the VNF before trying to use ONAP SO
185to instantiate the VF-module.
186
187This group of data is usually called "SDNC preload" and will contain:
188
189- vf-module instance Name
190- vnf instance Name
191- service instance id
192- the list of vnf parameters with values, when not using the default values
193
194Here is an example of SDNC preload for VNF, using "curl" tool
195to push those data using SDNC Rest API:
196
197::
198
199 curl -X POST \
Ittay Sternbe7893c2020-03-03 11:05:54 +0200200 https://sdnc.api.simpledemo.onap.org:30267/restconf/operations/VNF-API:preload-vnf-topology-operation \
Rene_Robert9859c932019-08-14 15:49:28 +0200201 -H 'Accept: application/json' \
202 -H 'Authorization: Basic YWRtaW46S3A4Yko0U1hzek0wV1hsaGFrM2VIbGNzZTJnQXc4NHZhb0dHbUp2VXkyVQ==' \
203 -H 'Content-Type: application/json' \
204 -H 'X-FromAppId: API client' \
205 -H 'X-TransactionId: 0a3f6713-ba96-4971-a6f8-c2da85a3176e' \
206 -H 'cache-control: no-cache' \
207 -d '{
208 "input": {
209 "request-information": {
210 "notification-url": "onap.org",
211 "order-number": "1",
212 "order-version": "1",
213 "request-action": "PreloadVNFRequest",
214 "request-id": "test"
215 },
216 "sdnc-request-header": {
217 "svc-action": "reserve",
218 "svc-notification-url": "http:\/\/onap.org:8080\/adapters\/rest\/SDNCNotify",
219 "svc-request-id": "test"
220 },
221 "vnf-topology-information": {
222 "vnf-assignments": {
223 "availability-zones": [],
224 "vnf-networks": [],
225 "vnf-vms": []
226 },
227 "vnf-parameters": [
228 {
Ittay Sternbe7893c2020-03-03 11:05:54 +0200229 "vnf-parameter-name": "oam_net_id",
230 "vnf-parameter-value": "oam_network_tXWW"
Rene_Robert9859c932019-08-14 15:49:28 +0200231 }
232 ],
233 "vnf-topology-identifier": {
234 "generic-vnf-name": "my-vnf-instance-01",
235 "generic-vnf-type": "Service-model-with-VNF-and-Virtual-Link/FreeRadius_VF 0",
236 "service-type": "09f9ffad-1069-43fa-97e8-da7b9a439601",
237 "vnf-name": "my_vf_module-instance-01",
238 "vnf-type": "FreeradiusVf..base_freeRadius..module-0"
239 }
240 }
241 }
Ittay Sternbe7893c2020-03-03 11:05:54 +0200242 }'
Rene_Robert9859c932019-08-14 15:49:28 +0200243
244
245Data mapping between ONAP SDNC terminology and ONAP SO
246
247- "generic-vnf-name" value must be equal to the VNF instance name value
248 (see VNF instance detail screen)
249- "generic-vnf-type" value must be equal to VNF Type value
250 (see VNF instance detail screen)
251- "service-type" value must be equal to the service instance id value
252 (see VNF instance detail screen)
253- "vnf-name" value must be equal to the VF module instance name value
254- "vnf-type" value must be equal to the "Model Name" value
255 (see create VF module screen)
256
257
258If there is a need for an instance specific value
259of a VNF parameter (for example : an OAM network id value,
260specific to this VNF instance),
261the "vnf-parameters" must be completed with a list of name/value.
262
263Once the "SDNC preload" is completed, send it to SDNC using any Rest API Tool.
264
265Then, continue on VID and complete the fields indicated by the red star
266and click "Confirm".
267
268Warning : be very careful to use exactly the same VF module instance name
269on this screen and in the "SDNC preload"
270
271Wait for success and close the popup screen.
272
273The following screen should appear:
274
275.. figure:: images/create-service-instance-alacarte-after-vfmodule-instantiated.png
276 :align: center
277
278At that point, the VNF is now instantiated in the cloud platform.
279
280
281Instantiate Network
282-------------------
283
284Instantiating a network is quite similar to vf-module instantiation
285(there is also the need for a "SDNC preload")
286
287Click on "Add Network" and select the Network you want
288to instantiate in the list
289
290The following screen should appear:
291
292.. figure:: images/create-network-instance-alacarte.png
293 :align: center
294
295
296Prepare the "SDNC preload" with:
297
298- "network-role": provide any value,
299- "network-technology": use "neutron" as this example will instantiate
300 a network using openstack neutron application
301- "service-type": value must be equal to "Service Name"
302 (=service model name) displayed on VID screen
303- "network-name": value must be equal to the desired network instance name,
304- "network-type": value must be equal to "Model Name""Generic NeutronNet"
305 displayed on VID screen
306
307In addition:
308
309- in "provider-network-information" section, it is possible to indicate
310 some network characteristics
311- it is possible to add a section about "subnets"
312
313Here after, an "SDNC preload" example that can be use for Network
314instantiation.
315
316::
317
318 curl -X POST \
319 http://sdnc.api.simpledemo.onap.org:30202/restconf/operations/VNF-API:preload-network-topology-operation \
320 -H 'Accept: application/json' \
321 -H 'Authorization: Basic YWRtaW46S3A4Yko0U1hzek0wV1hsaGFrM2VIbGNzZTJnQXc4NHZhb0dHbUp2VXkyVQ==' \
322 -H 'Content-Type: application/json' \
323 -H 'X-FromAppId: API client' \
324 -H 'X-TransactionId: 0a3f6713-ba96-4971-a6f8-c2da85a3176e' \
325 -H 'cache-control: no-cache' \
326 -d '{
327 "input": {
328 "request-information": {
329 "request-id": "postman001",
330 "notification-url": "http://so.onap.org",
331 "order-number": "postman001",
332 "request-sub-action": "SUPP",
333 "request-action": "PreloadNetworkRequest",
334 "source": "postman",
335 "order-version": "1.0"
336 },
337 "network-topology-information": {
338 "network-policy": [],
339 "route-table-reference": [],
340 "vpn-bindings": [],
341 "network-topology-identifier": {
342 "network-role": "integration_test_net",
343 "network-technology": "neutron",
344 "service-type": "Service-model-with-VNF-and-Virtual-Link",
345 "network-name": "my-network-instance-001",
346 "network-type": "Generic NeutronNet"
347 },
348 "provider-network-information": {
349 "is-external-network": "false",
350 "is-provider-network": "false",
351 "is-shared-network": "false"
352 },
353 "subnets": [
354 {
355 "subnet-name": "my-sub_network-instance-001",
356 "subnet-role": "OAM",
357 "start-address": "192.168.90.0",
358 "cidr-mask": "24",
359 "ip-version": "4",
360 "dhcp-enabled": "Y",
361 "dhcp-start-address": "",
362 "dhcp-end-address": "",
363 "gateway-address": "192.168.90.1",
364 "host-routes":[]
365 }
366 ]
367 },
368 "sdnc-request-header": {
369 "svc-action": "reserve",
370 "svc-notification-url": "http://so.onap.org",
371 "svc-request-id": "postman001"
372 }
373 }
374 }
375 '
376
377Once the "SDNC preload" is completed, send it to SDNC using any Rest API Tool.
378
379Then, continue on VID and complete the fields indicated by the red star
380and click "Confirm".
381
382Warning : be very careful to use exactly the same network instance name
383on this screen and in the "SDNC preload"
384
385Wait for success and close the popup screen.
386
387The following screen should appear:
388
389.. figure:: images/create-network-instance-alacarte-after-instantiated.png
390 :align: center
391
392At that point, the Network and subnets are now instantiated
393in the cloud platform.
394
395Also, all those network information are available in ONAP AAI,
396under the terminology
397"l3-network", with the "neutron-network-id" and the "neutron-subnet-id"
398provided by
399the openstack platform.
400
401
402Deleting Network, VF module, VNF, Service
403-----------------------------------------
404
405To delete a service instance using VID, it is necessary to delete objects
406in the following sequence:
407
408- delete VF module(s)
409- delete VNF instance(s)
410- delete Network(s)
411- delete service instance
412
413To proceed those deletion, from VID Home screen
414
415- search for existing service instance
416- edit/view the service instance you want to delete
417- click on red button with white cross and confirm for each object