blob: bb8d4fb0f90561e3a302906bdaf92f99939c2619 [file] [log] [blame]
.. This work is licensed under a Creative Commons Attribution 4.0 International License.
.. SPDX-License-Identifier: CC-BY-4.0
.. Copyright (C) 2023 Nordix
Influx Logger
~~~~~~~~~~~~~
************
Introduction
************
The task of the Influx Logger is to receive PM Measurement reports from a Kafka topic and to
store the measurements in an Influx time series database.
.. image:: ./Architecture.png
:width: 1000pt
This product is a part of :doc:`NONRTRIC <nonrtric:index>`.
***************
Database Schema
***************
The PM Measurements are stored in the influx database. Each measured resource is mapped to a measurement in Influx.
The name of the measurement is the Full Distinguished Name of the resource.
Each measurement type (counter) is mapped to a field. The name of the field is the same as the name of the measurement type.
In addition there is field which stores the GranularityPeriod in seconds of each report.
The GP is for how long time the counters have been aggregated.
The time is the end time of the report. The start time is then the logged time minus the granularity period.
Here follows an example of one Influx table which contains aggregated values for a measured resource.
.. image:: ./Schema.png
:width: 1000pt
******************************************
Setting up the PM measurement subscription
******************************************
The influx logger will create its data subscription automatically. This is done by reading a file that
defines the data to log and which Kafka topic to use (1). The contents of this file is used to create
the information job for subscribing of PM measurement (2). ICS will make sure that all PM Measurement producers
are ordered to start producing data (3).
.. image:: ./Subscription.png
:width: 1000pt
An example jobDefinition.json file: ":download:`link <../config/jobDefinition.json>`"
********************
Input PM Measurement
********************
The PM measurement information received from the Kafka topic is produced by the pm-producer.
Here follows an example of the expected input object:
.. code-block:: javascript
{
"event":{
"commonEventHeader":{
"domain":"perf3gpp",
"eventId":"9efa1210-f285-455f-9c6a-3a659b1f1882",
"eventName":"perf3gpp_gnb-Ericsson_pmMeasResult",
"sourceName":"O-DU-1122",
"reportingEntityName":"",
"startEpochMicrosec":951912000000,
"lastEpochMicrosec":951912900000,
"timeZoneOffset":"+00:00"
},
"perf3gppFields":{
"perf3gppFieldsVersion":"1.0",
"measDataCollection":{
"granularityPeriod":900,
"measuredEntityUserName":"RNC Telecomville",
"measuredEntityDn":"SubNetwork=CountryNN,MeContext=MEC-Gbg-1,ManagedElement=RNC-Gbg-1",
"measuredEntitySoftwareVersion":"",
"measInfoList":[
{
"measInfoId":{
"sMeasInfoId":"PM=1,PmGroup=NRCellDU_GNBDU"
},
"measTypes":{
"sMeasTypesList":[
"succImmediateAssignProcs"
]
},
"measValuesList":[
{
"measObjInstId":"RncFunction=RF-1,UtranCell=Gbg-997",
"suspectFlag":"false",
"measResults":[
{
"p":1,
"sValue":"1113"
}
]
},
{
"measObjInstId":"RncFunction=RF-1,UtranCell=Gbg-998",
"suspectFlag":"false",
"measResults":[
{
"p":1,
"sValue":"234"
}
]
},
{
"measObjInstId":"RncFunction=RF-1,UtranCell=Gbg-999",
"suspectFlag":"true",
"measResults":[
{
"p":1,
"sValue":"789"
}
]
}
]
}
]
}
}
}
}
*************
Configuration
*************
The component is configured via its application.yaml
An example application.yaml configuration file: ":download:`link <../config/application.yaml>`"