Going with the casablanca spec for Dublin - for the library to implement this spec - retrofit portal/sdk (or SO's library) - need to have an AOP enabled library like our reference - 3rd choice is to AOP enable AAI's
deprecated - |
Table of Contents |
---|
Statement of Work
Detail any changes to the existing casablanca spec (implementing in Dublin) - Active Logging Specifications - for the upcoming E release.
Each specification is created in the release prior to where it is implemented
Work to align the logs, ship them, consolidate, provide for analysis, backup and restore them will be done from a developer perspective for the Dublin release.
Requirements
R1: Provide for consistent logs across ONAP that allow for cross pod indexing
R2: Validate/Implement log shipping to the existing ELK stack
Analysis
Existing ONAP Logging State - Infrastructure and Schema
...
Tech
...
Code Block | ||
---|---|---|
| ||
aaf-cm
aaf-fs
aaf-gui
aaf-hello
aaf-locate
aaf-oauth
aaf-service
aaf-sms-vault-0
|
...
Code Block | ||
---|---|---|
| ||
aai-babel
aai-champ
aai-data-router
aai-gizmo
aai-graphadmin
aai-modelloader
aai-resources
aai-search-data
aai-sparky-be
aai-spike
aai-traversal
|
...
Code Block | ||
---|---|---|
| ||
appc-0
|
ref
Code Block | ||
---|---|---|
| ||
20181031
ubuntu@a-osn-cd:~/oom/kubernetes$ kubectl get pods --all-namespaces | grep /2
onap onap-clamp-clamp-9dfd65f8f-rhdlc 0/2 Init:0/1 0 6m
onap onap-dmaap-message-router-kafka-74f9bff668-h6flz 0/1 Init:0/2 0 6m
onap onap-esr-esr-server-6d7dd55794-rp9zz 0/2 Pending 0 6m
onap onap-msb-msb-discovery-59d48c65b-k68cj 0/2 Init:0/1 0 6m
onap onap-msb-msb-eag-76857bcc54-8zbpp 0/2 Pending 0 6m
onap onap-msb-msb-iag-59697db845-mlpz8 0/2 Pending 0 6m
onap onap-multicloud-multicloud-5765cd745-bb57j 0/2 Pending 0 6m
onap onap-multicloud-multicloud-azure-6c99454479-4457s 0/2 Pending 0 6m
onap onap-multicloud-multicloud-ocata-79cc9dfb76-w6bx4 0/2 Pending 0 6m
onap onap-multicloud-multicloud-pike-547d878bb5-d9cjj 0/2 Pending 0 6m
onap onap-multicloud-multicloud-vio-67979f99bc-gvzxz 0/2 Pending 0 6m
onap onap-multicloud-multicloud-windriver-748868744d-69sjr 0/2 Pending 0 6m
onap onap-policy-pap-5b95866fff-6wxln 0/2 Pending 0 5m
onap onap-policy-pdp-0 0/2 Init:0/1 0 5m
onap onap-pomba-pomba-aaictxbuilder-5d45d589-nnxck 0/2 Pending 0 5m
onap onap-pomba-pomba-networkdiscovery-8487cc6667-2j6wq 0/2 Pending 0 5m
onap onap-pomba-pomba-networkdiscoveryctxbuilder-c9c5c8f98-2svzw 0/2 Pending 0 5m
onap onap-pomba-pomba-search-data-7548469497-9pjq4 0/2 Pending 0 5m
onap onap-pomba-pomba-servicedecomposition-8985f9849-2cdl7 0/2 Pending 0 5m
onap onap-portal-portal-app-5cc7b45bd9-45c6c 0/2 Init:0/1 0 5m
onap onap-portal-portal-db-config-dwrrt 0/2 Pending 0 5m
onap onap-portal-portal-sdk-5bb84db56c-x4zcj 0/2 Init:0/1 0 5m
onap onap-sdc-sdc-be-68d86d55cf-pxf66 0/2 Pending 0 5m
onap onap-sdc-sdc-fe-67ccb88464-9qbwj 0/2 Pending 0 5m
onap onap-sdc-sdc-onboarding-be-67b4bc94b-2gscq 0/2 Pending 0 5m
onap onap-sdc-sdc-wfd-fe-87d9cd457-26crq 0/2 Pending 0 5m
onap onap-sdnc-sdnc-0 0/2 Pending 0 5m
onap onap-sdnc-sdnc-db-0 0/2 Pending 0 5m
onap onap-vfc-vfc-catalog-85bd56b986-c6zld 0/2 Pending 0 4m
onap onap-vfc-vfc-generic-vnfm-driver-dc4864b96-c9b6h 0/2 Pending 0 4m
onap onap-vfc-vfc-huawei-vnfm-driver-589c6c8467-swdqt 0/2 Pending 0 4m
onap onap-vfc-vfc-juju-vnfm-driver-7cb5dc655d-mkb7l 0/2 Pending 0 4m
onap onap-vfc-vfc-nokia-vnfm-driver-57c4f5d9cd-jh9mb 0/2 ContainerCreating 0 4m
onap onap-vfc-vfc-nslcm-675c748bb7-t6rfz 0/2 Init:0/1 0 4m
onap onap-vfc-vfc-resmgr-599fb9c6f7-64djz 0/2 Pending 0 4m
onap onap-vfc-vfc-vnflcm-75cc76d968-9dblx 0/2 Pending 0 4m
onap onap-vfc-vfc-vnfmgr-5f866c5458-4h56p 0/2 Init:0/1 0 4m
onap onap-vfc-vfc-vnfres-579459469f-f2kns 0/2 Pending 0 4m
onap onap-vfc-vfc-zte-vnfm-driver-5dd4b87cd7-ppj42 0/2 Pending 0 4m
onap onap-vid-vid-599d9c54f9-79vfl 0/2 Pending 0 4m |
ONAP Module Dependencies - Compile and Runtime
Existing Library Research
Library Selected for Reference Implementation
Java
Python
Specification
Use Cases
Design Issues
Developer Guide
Testing Guide
...
Features
Key words are: out of the box, reuse components, iterative changes - not major spec changes.
There is one primary use case and one enabler use case
UC1: Provide for transaction tracing via elasticsearch or dashboard for distributed transactions across ONAP components - enabled by the logs shipped to the ELK stack - in real time. UC2: Provide for UC1 tracing via standardized logs - ideally via marker/mdc (label/key:value pair) markup |
Logging Alignment before enhancement
Plan is to take the portal/sdk library - align the rest of onap to this library and then add marker/mdc (labels and key/value pair) support as required in phase 2
Work will include 1) verify pipeline 2) verify logback format
Open Standards
Look at a standard that will allow us to use standard parsing libraries all the way to eventual AI/ML by adopting a standard like open tracing.
Infrastructure Improvements
including filebeat sidecar anti-pattern/replacement, elk stack upgrade, deployment template, library language scope (python, swift...)
Monitoring
Investigate out of the box prometheus monitoring
S3P
backup/restore, security, log format monitoring, elk dashboards
3rd party consumption alignment
Lower in priority will be to align onap with requirements of Acumos and ECOMP for example - the focus will be on alignment of ONAP components only - to the primary goal of providing a transaction tracing system via the ELK stack.