This is a Grafana datasource for showing metrics from Instana AI-Powered APM for dynamic applications.
Attention: Grafana 10.0.0+ is suggested.
For On-premise customers Instana Release 260+ is required.
- Dynamic Focus queries
- Applications and Websites
- Automatic completion for available types and metrics
- Utilizes Instana REST API
- Security via access token
-
Secure Information Storage:
- To align with the latest updates from the Grafana team, all secure information, including the API key, should now be stored in
secureJsonData
instead ofjsonData
.
- To align with the latest updates from the Grafana team, all secure information, including the API key, should now be stored in
-
API Token Migration:
- The API token, currently stored in
jsonData
, is now migrated tosecureJsonData
starting from version 4.0.0. This is a breaking change, and existing users must reauthenticate their datasources.
- The API token, currently stored in
-
Configuration Page Update:
- To prevent data source breakage, existing users must reauthenticate by entering the URL and API Token on the configuration page.
-
Migration Instructions:
-
Reauthentication Steps:
- Visit the configuration page and re-enter the URL and API Token for each datasource.
-
Proxy Authentication:
- Authentication now only takes place over the data source proxy method. Use-proxy via authentication is the only option in our datasource plugin.
-
Grafana Version Requirement:
- This version (4.0.0) is now the base version of instana-grafana-datasource, and Grafana 10.0.0 or higher is required.
-
API Token Reset:
- Once credentials are saved, the API Token is stored on the server. Users have the option to reset the API Token using the provided reset key Button.
-
-
Additional Notes
- Ensure all existing datasources are reauthenticated to prevent disruptions.
- Refer to the updated documentation for any additional information or troubleshooting steps related to authentication changes.
We appreciate your understanding and cooperation during this transition. If you encounter any issues or have questions, please reach out to our support team.
Thank you for using instana-grafana-datasource!
When troubleshooting, please open a ticket at https://www.ibm.com/mysupport to get your issues/questions resolved the fastest way possible.
Searching for answers and best pratices? Check our IBM Instana Community.
This datasource uses the Instana REST API to query the metric values. First of all you will need to generate an API token. Use this token along with the URL for your Instana account e.g. https://prod-acme.instana.io
To use the Grafana server as a proxy for querying Instana REST API please check Use proxy
.
To enable metrics for offline snapshots please check Enable offline snapshots
. For On-premise customers Instana Release 260 is required.
The configuration allows the setting of a limit for the different categories that this plugin offers. Numeric values can be entered in order to make sure that queries do not exceed a certain amount of window size that they query. This can be useful when experiencing Grafana performance issues.
To start, enter the Dynamic Focus query. This is exactly the same as used in the Instana dashboard; you can test your queries in Instana and then copy and paste them into Grafana. NOTE Saved filters are not currently supported by the Grafana datasource plugin.
Once you filled in the query the available types dropdown will be automatically populated, select the type you want.
As you select the type, the available metrics dropdown will be automatically populated, select the metric you want.
If your Dynamic Focus query matches multiple instances then, the returned dataset will include metrics from all those matching instances, providing graphs with multiple plots like the example below.
To choose custom metrics matching your query you need to select "Infrastructure custom metrics" from the category dropdown, which will automatically populate the available types dropdown.
As you select the type, the available metrics dropdown will be automatically populated, select the metric you want. As there might be a huge amount of custom metrics, you can specify an optional filter to reduce to a corresponding subset.
If your Dynamic Focus query matches, the returned dataset will include metrics providing graphs like the example below.
For self-hosted installations, BeeInstana is required for this endpoint group. See this documentation for enabling BeeInstana.
To choose infrastructure analyze metrics, you need to select "Infrastructure Analyze" from the category dropdown. This will populate the other dropdown lists.
The "Entity types" dropdown will contain a list of all entity types sorted by entity name. Once you select the entity type, the available metrics dropdown will be automatically populated.
You should provide the appropriate group-by tag in the "Group by" text box. You can easily find the "Group by tag" option within the Instana dashboards. Then select the metric you want.
Most metrics will have more than one aggregation type (SUM, MEAN,etc...) from which appropriate one can be chosen.
We currently fully support filtering in Infrastructure Analyze. To use this feature, you must fill the "TagFilterExpression" text box with a tagFilterExpression which contains an array of desired filter objects. You can easily get the tagFilterExpression from the JSON tree under API query session of the Instana Infrastructure Analytics dashboard. If your selection matches, the returned dataset will include metrics providing graphs like the example below.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $host - the corresponding host
- $pid - the corresponding PID
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $type - the entity type
- $service - the service label (for endpoints only)
- $name - a label alternative
- $index - index in the list
A simple version of getting metrics related to one or multiple applications. Once an application and a metric are selected, the graphs will be drawn (see example below). The icon next to the application indicates whether the displayed information is based on calls that are performed by the consumers of the application (INBOUND) or based on all calls that are performed within this application, by both consumers as well as internally (ALL). These options are only enabled once an application is selected.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $application - application label
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $key - metric key with aggregation and rollup
- $index - index in the list
If no custom format is provided the default label '$label ($application) $metric' will be shown.
Allows to show metrics related to a service. Services can either be selected as standalone or in combination with an Application Perspective to show more detailed metric data. As soon as an application is selected the dropdown menu of possible services reloads and only shows services that are actually being used by the selected application. Together with an application it is possible to indicate whether the displayed information is based on calls that are performed by the consumers of the application (INBOUND) or based on all calls that are performed within this application, by both consumers as well as internally (ALL). These options are only enabled once an application is selected. In case only a service is selected (without any application) the displayed information will be based on all calls that are performed within this application, by both consumers as well as internally.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $service - service label
- $application - application label (if selected)
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $key - metric key with aggregation and rollup
- $index - index in the list
If no custom format is provided the default label '$label ($service) $metric' will be shown.
Allows to show metrics related to an endpoint. Endpoints can either be selected as standalone or in combination with an Application Perspective and service to show more detailed metric data. Since multiple endpoints can have the same name, it is recommended to select an application, then a service, and finally an endpoint in order to be sure to select the correct endpoint. Possible selectable items are reloaded and cached each time a service and an application is changed. Together with an application it is possible to indicate whether the displayed information is based on calls that are performed by the consumers of the application (INBOUND) or based on all calls that are performed within this application, by both consumers as well as internally (ALL). These options are only enabled once an application is selected. In case only an endpoint is selected (without any application) the displayed information will be based on all calls that are performed within this application, by both consumers as well as internally. This is independent on a selected service.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $application - application label (if selected)
- $service - service label (if selected)
- $endpoint - endpoint label
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $key - metric key with aggregation and rollup
- $index - index in the list
If no custom format is provided the default label '$label ($endpoint) $metric' will be shown.
To choose application metrics you need to select "Analyze application calls" from the category dropdown. This will populate the other dropdown lists.
The "Application" dropdown will contain a list of all applications sorted by their name.
Most metrics will have more than one aggregation type (SUM, MEAN, ...) and you can choose which one to use.
It's also possible to add additional filters via "add Filter". Multiple filters are concatenated using "AND".
If your selection matches, the returned dataset will include metrics providing graphs like the example below.
If more then 20 metics are fetched, a warning appears that not all results are shown. Add Filter to narrow down the data.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $application - application label
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $key - metric key with aggregation and rollup
- $index - index in the list
If no custom format is provided the default label '$label ($application) $metric' will be shown.
To choose EUM website metrics you need to select "Analyze websites" from the category dropdown. This will populate the other dropdown lists.
The "Website" dropdown will contain a list of all websites sorted by their pageloads.
Most metrics will have more than one aggregation type (SUM, MEAN, ...) and you can choose which one to use.
It's also possible to add additional filters via "add Filter". Multiple filters are concatenated using "AND".
If your selection matches, the returned dataset will include metrics providing graphs like the example below.
A default label '$label ($website) $metric' will be shown.
To choose EUM mobile app metrics you need to select "Analyze mobile app" from the category dropdown. This will populate the other dropdown lists.
The "Mobile-app" dropdown will contain a list of all mobile apps sorted by their session starts.
Most metrics will have more than one aggregation type (SUM, MEAN, ...) and you can choose which one to use.
It's also possible to add additional filters via "add Filter". Multiple filters are concatenated using "AND".
If your selection matches, the returned dataset will include metrics providing graphs like the example below.
To adjust the legend display you can provide an own "Legend format". Supported values for replacement are:
- $label - the entity label
- $website - website label
- $type - entity type
- $timeShift - corresponding timeShift
- $metric - the displayed metric
- $key - metric key with aggregation and rollup
- $index - index in the list
If no custom format is provided the default label '$label ($website) $metric' will be shown.
Instana brings two collections Service levels information into Grafana.
-
Service levels objectives (beta), by the predefined SLO target from configurations, including:
- Service level status (single number)
- Predefined service level target (single number)
- Total error budget (single number)
- Remain error budget (single number)
- Spent error budget (single number)
- Error chart/Error budget consumption (timeseries)
- Error budget accumulation chart (timeseries)
- Error budget remain chart (timeseries)
- Voilation chart (timeseries)
-
Service level objectives widgets, by the given SLO target from parameters, including:
- SLI (single number)
- Remain error budget (single number)
- Timeseries (voilation in timeseries)
Both of them can be selected from the metric category drop-down list. Accordingly, SLO/SLI configuration and value types can be selected for display.
Difference between them is that SLO target is not defined for the SLI configuration from Service level objectives widgets
. If Service level objectives widgets
is chosen, SLO(target) is required as a parameter. On the other side, SLO target has already predefined by the SLO configuration from Service levels objectives (beta)
, no additional step is required to define the SLO target for calculation. Also, Service levels objectives (beta)
provides more metrics and charts than Service level objectives widgets
.
The image below shows how a dashboard looks like with metrics from Service levels objectives (beta)
category
The image below shows a dashboard looks like when choosing metrics from Service level objectives widgets
category
While using the "Singlestat" visualization an additional metric aggregation is selectable. For showing a correct SUM metric, configuration on two different places is needed:
- on metric selection: "SUM" to adjust our mean calculated rollup values
- on Singlestat configuation: "Total" to tell the panel to aggregate all given values
While using the "Table" visualization an additional metric aggregation is selectable.
The time shift option allows going back in different points of time for each query.
This new feature can be used to compare two identical queries while one shows the query's outcome of a day earlier.
This plugin also supports the ability to select different granularity values to provide a even deeper look into metrics.
Aggregate graphs on query level and choose to show everything or only the aggregated graph.