Instrumentation
This section describes how the inspectIT Ocelot Java agent can be used to inject predefined or custom monitoring code into the target application.
InspectIT Ocelot gives you a very large degree of freedom when it comes to defining instrumentation. The first step is usually defining your scopes. A scope acts as a selector for finding the methods you want to instrument.
Then, you define actions, which contain the logic of your instrumentation. In short: Actions allow you to specify Java snippets in your configuration which will be executed to extract any data you want. This can be performance data such as the response time or any kind of business data, e.g. the shopping cart size.
Scopes and actions are then combined within rules. While scopes define which methods you instrument, rules define the actual monitoring actions which will be performed to utilize collected data. Examples for such actions would be recording the response time in metrics or extracting the HTTP url for further processing.
tip
All instrumentation settings can be changed without restarting the application! They can even be changed while a previous instrumentation is still in progress.
In this case the inspectIT Ocelot agent will automatically switch to the new instrumentation as soon as the configuration is loaded.
Disabling the Instrumentation
Since version 1.12.2, the agent provides the option to disable its instrumentation process.
When disabled, the agent will revert any instrumentation done and restore the original state of all instrumented classes.
This would be like having no single rule (also none in the agent's default configuration) defined.
This results in no more runtime data (traces and metrics) being recorded from executed methods.
inspectit:
  instrumentation:
    enabled: true
note
Metrics which are not based on instrumentation like e.g. JVM internals (thread statistics, memory statistics, ...) are not affected by this option.
Naming Convention
Differentiating between rules, actions and scopes as well as differentiating between keys and values in the configuration can be tricky from time to time. Therefore, to increase readability of your configuration files the following naming convention is recommended:
- Scope names always start with s_, e.g.s_my_scope.
- Action names always start with a_, e.g.a_my_action.
- Rule names always start with r_, e.g.r_my_rule.
- Field names should be written in snake case, e.g. s_my_scope.
- If you want to use dots for field names, the names have to be enclosed by '[]', e.g.'[my.metric]'. Otherwise, this might lead to configuration errors because of the yaml syntax.