Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Brief Project Overview (brief as it should be known)

Holmes is a root cause analytics application. It is targeted to find out the root cause among tons of alarms with the help of the topology information of resources provided by A&AI. Meanwhile, if needed, it could also correlate one alarm with another if they are topologically related and fulfill the criteria which are set in a specific rule.

Holmes is an application managed by DCAE. The position of Holmes in ONAP is dipicted in the picture bellow.

Image Added

As for the architecture of Holmes itself, it comprises two sub-modules: a rule management module and an engine management module.

Image Added

The rule management module is the entry for all Holmes rules. It interacts with other components (i.g. DCAE) to get rules, save them into the DB and then deploy the active rules into the engine management module.

The engine management module is where all rules run. For now, there's a data source adapter (aka DSA) which is responsible for converting the VES event into the format that Holmes could deal with residing in this module.

New component capabilities for Dublin, i.e. the functional enhancements.

  • Integration with AAF to implement authorization and authentication.

New or modified interfaces

...

  • api/holmes-rule-mgmt/v1/rule
  • api/holmes-engine-mgmt/v1/rule

In addition, we use method methods PUT/POST/DELETE/GET to distinguish different behaviors for the APIs that share the same name.

...

What are the system limits?

  • Scalability of the engine management module is feasible but not perfect. Holmes dispatches all of the active rules into different instances evenly. This could reduce the payload of each engine a little bit, but not much.
  • It could be a bottle neck when it comes to the performance on the interactions with A&AI during alarm analysis. This is now on the discussion list of the A&AI team and we are trying to figure out a way to optimize it.

Involved use cases, architectural capabilities or functional requirements.

...

Listing of new or impacted models used by the project (for information only).

  • None.