Under construction!
This page describes how to run current implementation for the O-DU Slice Assurance usecase.
Standalone script version
The standalone script version of the usecase is implemented in Golang.
It provides a simulator that stub both Dmaap MR and SDNR (orange boxes in the picture below), so both processes can share its data.
Prerequisites
The following need to be installed to run the script according to these instructions:
- Go must be installed, see https://go.dev/doc/install.
- Pull the ran slice assurance usecase repo:
git clone "https://gerrit.o-ran-sc.org/r/nonrtric/rapp/ransliceassurance"
Run using simulators
Run Dmaap MR / SDNR stub
This stub has been coded on Go, similar to the simulator used in O-RU O-DU Closed loop recovery use case previously described. However, this stub simulates both Dmaap VES messages and also SDNC. By default, the stub listens to port 3905, can be changed with the flag "--sdnr-port".
To run the stub, follow the steps below:
- Goto "ransliceassurance/smoversion/stub" in the repo.
- Build the stub, "go build".
- Start the stub, "./stub"
cd ransliceassurance/smoversion/stub go build ./stub [--sdnr-port <portNo>] [--dmaap-port <portNo>] Example: └─ $ ▶ ./sdnr --sdnr-port 3906 Starting DmaapMR stub on port: 3905 Starting SDNR stub on port: 3606
Run O-DU Slice Assurance Rapp
The application takes a number of environment variables for configuration, but only MR_HOST and MR_PORT are required, others are optional. More information can be found in README.md file
cd ransliceassurance/smoversion/ go build
Environment variables can be defined as part of the command line as follow:
Example: └─ $ ▶ MR_HOST=http://localhost MR_PORT=3905 ./oduclosedloop
ICS version
This version of the usecase is implemented as an Information Coordinator Service (ICS) job consumer, and is implemented in Go.
Use case using simulators
There are two simulator that can be used to run this usecase. First, as the standalone version, there is one stub that simulates both received VES messages from Dmaap Adapter with information about performance measurements for the slices in a DU and also simulates SDNR, that sends information about Radio Resource Management Policy Ratio and allows to modify value for RRM Policy Dedicated Ratio from default to higher value, second stub simulates ICS, where job is created with information about the rapp so the Dmaap Adapter can send information to it.
Run Dmaap MR / SDNR stub
To run the stub, follow the steps below:
- Goto "ransliceassurance/icsversion/stub/prodSdnc" in the repo.
- Build the stub, "go build".
- Start the stub, "./prodSdnc"
Run ICS stub
To run the stub, follow the steps below:
- Goto "ransliceassurance/icsversion/stub/ics" in the repo.
- Build the stub, "go build".
- Start the stub, "./ics"
Run O-DU Slice Assurance Rapp
Environment variables can be defined as part of the command line as follow:
Example: └─ $ ▶ CONSUMER_HOST=http://localhost CONSUMER_PORT=3905 ./icsversion
Use case using SMO deployment
For this case, the following components will be needed:
- DU simulator, that will send VES message.
- OAM controller, that will create stream to communicate with VES collector and trigger PM Job event in DU.
- VES Collector, representing the VES (REST) provider at SMO for all kind of events
- ONAP Dmaap, representing SMO DMaaP component, includes message-router
- Dmaap Adapter, that takes information from DMaaP and present it as a coordinated Information Producer
- ICS Information Coordinator Service, that coordinate/Register Information Types, Producers, Consumers, and Jobs.
For starting the OAM Controller and VES Collector, a minimal SMO deployment is needed. This can be started using the instructions from here and ignoring the ONAP-Policy steps. NonRT-RIC should be replaced for docker-compose file located in
ransliceassurance/docker-compose/icsversion
Image | Name |
nexus3.o-ran-sc.org:10004/o-ran-sc/nts-ng-o-ran-du:1.4.5 | ntsim-ng-o-du-1122 |
nexus3.onap.org:10001/onap/sdnc-image:2.2.3 | sdnr |
nexus3.onap.org:10001/onap/org.onap.dcaegen2.collectors.ves.vescollector:1.10.1 | ves-collector |
nexus3.onap.org:10001/onap/sdnc-web-image:2.2.3 | sdnc-web |
nexus3.onap.org:10001/onap/dmaap/dmaap-mr:1.1.18 | onap-dmaap |
nexus3.onap.org:10001/onap/dmaap/kafka111:1.0.4 | kafka |
persistence | |
identity | |
nexus3.onap.org:10001/onap/dmaap/zookeeper:6.0.3 | zookeeper |
curl -X PUT -H "Content-Type: application/yang-data+json" -H "Accept: application/yang-data+json" -d '{"subscription-streams":{"id":"stream-1","administrative-state":"unlocked","user-label":"stream1","ves-endpoint-protocol":"https","ves-endpoint-auth-method":"basic-auth","ves-endpoint-ip":"10.20.11.121","ves-endpoint-port":"8443","ves-endpoint-username":"sample1","ves-endpoint-password":"sample1"}}' -u admin:Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U {{baseUrl}}/rests/data/network-topology:network-topology/topology=topology-netconf/node={{node}}/yang-ext:mount/o-ran-sc-du-hello-world:network-function/subscription-streams=stream-1
cat payload.json {"performance-measurement-jobs":{"id":"pm-1","administrative-state":"unlocked","user-label":"pm","job-tag":"my-job-tag","performance-metrics":["/o-ran-sc-du-hello-world:network-function/o-ran-sc-du-hello-world:distributed-unit-functions[o-ran-sc-du-hello-world:id='O-DU-1211']/o-ran-sc-du-hello-world:cell[o-ran-sc-du-hello-world:id='cell-1']/o-ran-sc-du-hello-world:supported-measurements[o-ran-sc-du-hello-world:performance-measurement-type='user-equipment-average-throughput-uplink']/o-ran-sc-du-hello-world:supported-snssai-subcounter-instances[o-ran-sc-du-hello-world:slice-differentiator='1'][o-ran-sc-du-hello-world:slice-service-type='1']"],"granularity-period":30,"stream-target":"stream-1"}} curl -X PUT -H "Content-Type: application/yang-data+json" -H "Accept: application/yang-data+json" -d @payload.json -u admin:Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U {{baseUrl}}/rests/data/network-topology:network-topology/topology=topology-netconf/node={{node}}/yang-ext:mount/o-ran-sc-du-hello-world:network-function/performance-measurement-jobs=pm-1