blob: a107728bef1875f16c2f75c616270af772ed4624 [file] [log] [blame]
JohnKeeneyfe56ddf2023-04-25 16:55:30 +01001.. This work is licensed under a Creative Commons Attribution 4.0 International License.
2.. SPDX-License-Identifier: CC-BY-4.0
3.. Copyright (C) 2023 Nordix
4
PatrikBuhr1dd66022023-05-08 10:02:42 +02005Non-RT RIC RAN PM Measurement
6~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
JohnKeeneyfe56ddf2023-04-25 16:55:30 +01007
PatrikBuhr28bb3da2023-05-16 08:56:41 +02008Parent repository for components implementing Non-RT RIC RAN PM Use-cases.
JohnKeeneyfe56ddf2023-04-25 16:55:30 +01009
JohnKeeneyfe56ddf2023-04-25 16:55:30 +010010
PatrikBuhr1dd66022023-05-08 10:02:42 +020011********
12Overview
13********
JohnKeeneydcecbc92023-04-26 22:42:08 +010014
PatrikBuhr1dd66022023-05-08 10:02:42 +020015The OSC Non-RT RIC provides a high performing, fully scalable end-to-end solution for handling
16PM Mesurements. A PM report (containing aggregated PM measurements over a time interval) is
17an XML file. The format is defined by 3GPP (TS 32.432 and 3GPP TS 32.435).
18The files are collected from the RAN and stored. An rApp can subscribe for chosen measurement types from
19measured resources in the network.
20
21
22**********
23Components
24**********
25
26The picture illustrates the components involved.
27
28* The PM Data File Collector fetches the XML files from the RAN.
29* The PM Data Converter converts these to a Json format. The structure and the contents
30 is the same as the XML format.
31* The PM Producer handles filtering and distribution of PM data to subscribers. These subscribers can be rApps.
32* The Influx Logger stores selected PM mesurements into a time series database.
33* HTTPS-SERVER is for testing and implements functionality to simulate file transfer from thye RAN nodes.
34
35The third party products used are:
36
37* Minio object storage, for storing of files.
38* Kafka for transferring of data (not the full PM reports, though)
39* Influx time series database for storing of selected PM mesurements over time.
40
41.. image:: ./Components.png
42 :width: 500pt
43
44For more detailed documentation of the components:
45
46* :doc:`Non-RT RIC - RAN PM - PM Data File Collector (Documentation site) <datafilecollector:index>`.
PatrikBuhr28bb3da2023-05-16 08:56:41 +020047* :doc:`Non-RT RIC - RAN PM - PM Data Data Converter (Documentation site) <kafka-pm-producer:index>`.
JohnKeeneydcecbc92023-04-26 22:42:08 +010048* :doc:`Non-RT RIC - RAN PM - PM Producer (Documentation site) <pmproducer:index>`.
49* :doc:`Non-RT RIC - RAN PM - Influx Logger (Documentation site) <influxlogger:index>`.
PatrikBuhr1dd66022023-05-08 10:02:42 +020050* `Non-RT RIC - Information Coordinator Service (Documentation site) <https://docs.o-ran-sc.org/projects/o-ran-sc-nonrtric-plt-informationcoordinatorservice/en/latest/>`_.
51* HTTPS-SERVER TBD
JohnKeeneydcecbc92023-04-26 22:42:08 +010052
PatrikBuhr1dd66022023-05-08 10:02:42 +020053
54
55*********
56Data Flow
57*********
58
59The figure below gives an overview of the data flow through the components.
60
61.. image:: ./DataFlow.png
62 :width: 900pt
63
641. The RAN node sends a VES event with available PM measurement report files.
652. The VES event is put on a Kafka topic and picked up by the Data File Collector.
663. A PM report file is fetched from the RAN node by a file transfer protocol. Which protocol to use is defined in the VES event.
674. The collected file is stored
685. A File collected object is put on a Kafka topic and is picked up by the PM Data Converter.
696. The file data is read from the file store.
PatrikBuhr499fc372023-05-10 14:07:22 +0200707. A PM report in json format is stored (compressed with gzip).
PatrikBuhr1dd66022023-05-08 10:02:42 +0200718. A message (a Json object) indicating that a new PM report (in Json format) is available is put on a Kafka topic and is picked up by the PM Data Producer.
729. The PM data producer reads the Json file
7310. The subscribed PM data is sent to the PM data consumers (over Kafka). An rApp may be a PM data consumer.
7411. The Influx Logger, which is a PM data consumer, stores PM data in an Influx database.
75
76At anytime an rApp can read logged PM data from the Influx database.
77
78********************
79PM Data Subscription
80********************
81PM measurement data is subscribed by creating an Information Job using the Information Coordination Service (ICS).
82This a subscription broker and is part of what is called Data Managament an Exposure (DME) in O-RAN.
83The ICS makes sure that all data producers gets its data subscriptions (jobs).
84
85In the picture below, an rApp and the Influx Logger are consumers of PM data.
86
87.. image:: ./ControlFlow.png
88 :width: 500pt
89
90The PM Data Influx logger will create a PM data subscription based on a configuration file. An rApp can create
91PM data subscpition. The PM Data producer will deliver received PM measurements according to the subscriptions.
92
93The PM Data file collector will fetch all PM measurement files. The PM Data Converted will convert all fetched xml files
94to json. So these does not use any subscriptions.
95
96**************************************
97PM Subscriber design time dependencies
98**************************************
99
PatrikBuhr28bb3da2023-05-16 08:56:41 +0200100An rApp uses the ICS API to create and manage the subscription of PM Measurements.
101The API documentation is avaiable in `Non-RT RIC - Information Coordinator Service (Documentation site) <https://docs.o-ran-sc.org/projects/o-ran-sc-nonrtric-plt-informationcoordinatorservice/en/latest/>`_.
PatrikBuhr1dd66022023-05-08 10:02:42 +0200102
PatrikBuhr499fc372023-05-10 14:07:22 +0200103The schema for the PM Mesaurement information jobs is defined in :doc:`Non-RT RIC - RAN PM - PM Producer (Documentation site) <pmproducer:index>`.
PatrikBuhr1dd66022023-05-08 10:02:42 +0200104This schema defines parameters used in the subscription (info job) and defines which measurements to subscribe for and on which
105kafka topic the information shall be delivered to.
106
PatrikBuhr28bb3da2023-05-16 08:56:41 +0200107An application retrieving logged PM data from the Influx database needs to consider how the data is stored (the schema). That is
PatrikBuhr1dd66022023-05-08 10:02:42 +0200108defined in :doc:`Non-RT RIC - RAN PM - Influx Logger (Documentation site) <influxlogger:index>`.
109
110.. image:: ./DesignTimeDependencies.png
111 :width: 500pt