<img height="1" width="1" style="display:none;" alt="" src="https://px.ads.linkedin.com/collect/?pid=1110556&amp;fmt=gif">
Skip to content
    September 4, 2024

    Step-by-Step Guide to Integrating AppNeta with Grafana via API

    Note: This post was co-authored by Sean Whitney

    AppNeta comes pre-loaded with a number of powerful dashboards and reports so you can quickly and easily understand your network performance. 

    But what if your team uses Grafana to visualize its network operation monitoring data?

    Simple—just set up a connection between AppNeta’s API and Grafana. You’ll be able to visualize all your networking data in one place. 

    This article is a step-by-step guide to set up a connection between AppNeta and Grafana using AppNeta’s API. Here are the topics covered:

    • Prerequisites
    • Step 1: Create an API access token in AppNeta
    • Step 2: Install the Infinity plugin on Grafana
    • Step 3: Configure the data source in Grafana
    • Step 4: Create a dashboard to visualize AppNeta data

    Prerequisites

    To set up this integration, you’ll need to start with the following:

    • An active AppNeta account. You’ll need an AppNeta account with users, organizations, and licenses. Ideally, you’ll also have monitoring set up and generating data. If you’re not there yet, check out the Getting Started section of the AppNeta docs.
    • An active Grafana account. You’ll also need to be able to log into Grafana, add plugins, and create new dashboards. See Grafana’s website for details on setting up a Grafana account.

    Step 1: Create an API access token in AppNeta

    The AppNeta API makes data collected and generated by AppNeta available for analysis, reporting, and presentation in third-party systems. Data is delivered in a lightweight JSON format that can be readily consumed by a broad range of third-party applications—including Grafana.

    To use the API with Grafana, start by creating an API access token using the steps below.

    investment300

    Tip: Prefer to access these steps in a video? Watch our step-by-step tutorial for a visual guide.

    1. In AppNeta, navigate to > Manage Access Tokens, and click Create Token.
    2. Enter a token name. This can be a descriptive name that includes spaces.
    3. Specify an expiration date (or check Never). The token is revoked automatically at expiration.
    4. Select a Role for the token. This determines what data can be brought into Grafana. 
      • Important: When creating API tokens, we recommend following these security best practices: create it for a single purpose, and create it with the minimum access and duration needed for the purpose of the token. For retrieving data, we recommend using a View Only token. See API Access Tokens for more on API access token security considerations.
    5. In the Organization Membership section, check Use dynamic membership if you want the token to access any organizations the user has access to now and in the future (as new organizations are added or removed).
    6. In the Select Organizations section, check the organizations you want the token to have access to.
      • Note: The selection of organizations is static. New organizations available to the user will not be accessible by the token.
    7. Click Create Token and then copy the token and save it. 
      • Important: It will not appear again.
    8. Click Finished.

    With the token you have produced, you can give Grafana the authorization it needs to pull monitoring data from AppNeta.

    Step 2: Install the Infinity plugin on Grafana

    ​​Next, you need to download the Infinity plugin on Grafana—we’re going to pull AppNeta monitoring data into it. 

    There are two ways to install the plugin—either with the user interface or with the command line interface.

    User interface method

    To install the Infinity Plugin from the Grafana user interface:

    1. Log into Grafana and navigate to Administration > Plugins.

    2. Click Connections and search for the Infinity plugin.

    3. Select Infinity and click Install.

    Command line method

    ​​To install the Infinity plugin through the command line, use the following commands:

    grafana-cli plugins install yesoreyeram-infinity-datasource
    systemctl restart grafana-server

    Step 3: Configure the data source in Grafana

    The next step is to configure the data source, connecting the AppNeta API to the Infinity plugin within Grafana:

    1. In Grafana, navigate to Administration > Data sources from the dropdown menu.

    2. Click Add new data source.

    3. In the search bar, enter Infinity and select the Infinity plugin.

    4. In the Name field, enter a meaningful name for the data source. Then, navigate to Authentication and select Setup Authentication.

    investment300 Tip: We recommend naming the data source with either the URL for the specific AppNeta application node or a friendly name such as AppNeta. Your AppNeta node is the first part of the URL you access when logged into AppNeta. (For example, if the URL you use to access AppNeta is app-21.pm.appneta.com, the node is app-21.) See AppNeta Service Details for instructions to find your application node.

    5. Select API Key Value Pair, then enter Authorization in the Key field and Token <API token> in the Value field, where <API token> is an AppNeta API access token string that you generated earlier. Token values are case sensitive. 

    6. In the Allowed hosts field, enter the AppNeta API URL in the format ​​https://<application-node>.appneta.com/api/v3/, where <application-node> is the application node for your AppNeta instance. Again, see AppNeta Service Details for instructions to find your application node.

    investment300

    Note: Your entry in the Allowed hosts field may appear purple, as in the image above, or red, as seen below:

    7. Navigate to Headers & URL params and create a new custom HTTP header, entering Accept in the Key field and application/json in the Value field.

    8. Click Save & test. If there are no errors, you will see this message:
     OK. Settings saved.

    investment300

    Tip: In this section, we set the AppNeta API as a data source. You can also configure Grafana to access your database directly by specifying the database target and providing authentication credentials. For more information, see Grafana documentation on connecting data sources.

    Step 4: Create a dashboard to visualize AppNeta data

    You’ve set up the Infinity Plugin in Grafana to pull data from AppNeta. Next, we’ll set up a dashboard in Grafana to visualize that data:

    1. From the main menu in Grafana, click the + symbol, and select Dashboard.

    2. Choose Add a new panel.

    3. Configure your specific data source for the Infinity plugin.

    • In the Data source field, select the Infinity plugin data source that you set up in an earlier step. If you named the data source as we recommended, with the URL for the specific AppNeta application node or a friendly name such as AppNeta <application-node>, you will see that name in the list. In the screenshot example, we named our data source demo.pm.appneta.com.
    • In the Query options field, you can choose to customize the configuration settings. For example, you can modify how frequently you pull data from AppNeta by customizing the Interval field. See Grafana documentation for details on configuring queries.
    • In the Parser list, choose Backend.
    • In the URL field, enter an AppNeta API URL.
      • For example, to pull data from all paths, enter https://<application-node>.pm.appneta.com/api/v3/path/data, where <application-node> is the application node for your AppNeta instance.
      • To specify a single path, enter  https://<application-node>.pm.appneta.com/api/v3/path/<id>/data, where <application-node> is the application node for your AppNeta instance and <id> is the path ID of the path you would like to retrieve data for.
    • See AppNeta Service Details for instructions to find your application node and AppNeta API for instructions to obtain path IDs.

    4. Identify the correct Rows/Root values and Column values for the query. These values specify which rows and columns of data from AppNeta you want to visualize in Grafana. We explain how to do this and provide examples in the next section.

    • We recommend entering Rows/Root value in JSONPath format: $.<first-level>.<second-level>, where $. signals a row variable, <first-level> is the first level of the JSON formatted data you want to include, and <second-level> is the second level. For example, use $.data.latency to visualize latency metrics. See the next section for more examples.
    • For Columns values, enter the values you want to visualize. Enter a metric name in the Selector field, the chart label for the metric in the as field, and the type of data in the formatted as field. Using latency values as an example, you would enter start in the Selector field, Latency in the as field, and Number in the format as field.

    5. Optionally, add paths or metrics by creating an additional query.

    • Click the copy icon in the top right corner of the form to duplicate the setup and create an additional query. Then, update the Rows/Root and Column values for the data you wish to add.
    • Note: Each path or metric added creates an additional API query. See the UQL and JSONata section below for a possible solution to limit API queries.

    6. The data is now shown in a chart in Grafana. Now you can customize the chart further by adding a title, changing design elements, and more.

    Examples: Rows/Root and Column values

    Grafana asks you to enter in Rows/Root and Column values when you are setting up your query. To do that properly, you need to be able to find the Rows/Root and Column values from the AppNeta API output. This section explains how to find the correct Rows/Root and Column values in AppNeta, and provides some examples you can use. 

    How to find Rows/Root and Column values in AppNeta

    To find the values for a path and metric:

    1. In AppNeta, navigate to the gear icon > Explore API.

    2. Navigate to the desired endpoint and click Try it out.

    • Select GET /v3/path/data to retrieve data for all paths in the organization.
    • Select GET /v3/path/{id}/data to retrieve data for a specific path

    3. If you choose to retrieve data for a specific path, enter its path ID number in the id field.

    • Tip: See AppNeta API for instructions to obtain path IDs.

    4. Select the metric of interest from the metric list and click Execute.

    5. Use the API response to identify the Rows/Root values in Grafana. The output will contain the names of the variables for Grafana. Path data are nested variables within the path attributes.

    • Use the format $.<first-level>.<second-level>,  where <first-level> is the first level of the JSON formatted data you want to include, and <second-level> is the second level.

    • For example, in the preceding screenshot, you can see that the variable latency is nested under data. You would therefore input $.data.Latency to Grafana to include latency in your visualization.

    6. Use the API response to identify the Column values in Grafana.

    • For example, to plot latency over time, include two columns: one for time, and one for the value of latency.
    • For time, enter start in the Selector field. Then enter a label, such as Time, and select a data type, such as Time (UNIX ms).
    • For latency, enter value in the Selector field. Then enter a label, such as Latency and select a data type, such as Number.

    Inbound and outbound metrics

    Keep in mind that some AppNeta metrics are collected in both monitoring directions—from the source Monitoring Point to the target, and from the target Monitoring Point to the source. These metrics are recorded as separate values:

    • Source → Target (Outbound)
    • Source ← Target  (Inbound)

    These must be called individually to collect those metrics for visualization. For example, data loss is a metric collected in both monitoring directions. To visualize both outbound and inbound data loss in Grafana, you would have to include both in your dashboard:

    • Outbound:$.dataOutbound.dataLoss
    • Inbound:$.dataInbound.dataLoss

    Example: Inbound voice jitter

    To plot inbound voice jitter over time, we recommend using the following values.

    • Rows/Root value: $.dataInbound.voiceJitter
    • First Column values:
      • Selector: start
      • as: Time
      • formatted as: Time (UNIX ms)
    • Second Column values:
      • Selector: value
      • as: Voice Jitter
      • formatted as: Number

    Example: Outbound voice jitter

    To plot outbound voice jitter over time, we recommend using the following values.

    • Rows/Root value: $.dataOutbound.voiceJitter
    • First Column values:
      • Selector: start
      • as: Time
      • formatted as: Time (UNIX ms)
    • Second Column values:
      • Selector: value
      • as: Voice Jitter
      • formatted as: Number

    UQL and JSONata

    The Infinity plugin may not be the most efficient way to visualize AppNeta data in Grafana because it uses individual API queries for each data set. Instead, you may be able to use a UQL/JSONata enhancement that limits the number of API queries and visualizes your data more efficiently.

    Cloud Observability’s Unified Query Language (UQL) is a language designed to query data from various sources in a universal manner. It is a powerful way to process metric data. JSONata is a lightweight query and transformation language designed specifically for querying and transforming JSON data. It provides a powerful and expressive toolset for navigating and manipulating JSON structures.

    The Grafana Infinity plugin allows you to use either language to transform data. The way data is presented in the /v3/path/{id}/data feed is to separate each data type into its array of key-value pairs. Each pair has a timestamp with millisecond precision. This same timestamp seems to be present for all the different data types. Using these keys, it may be possible to correlate all the data points in the feed to a single table, allowing the presentation of all relevant data with one query.

    AppNeta provides end-to-end visibility into your network performance

    Part of the wider NetOps by Broadcom solution, AppNeta provides teams with the complete visibility they need to track network performance from end to end, no matter which networks user connections rely upon.

    Use AppNeta’s powerful monitoring capability with Grafana to build real-time dashboards, so you can quickly see and understand performance issues on your network.

    Follow these links to learn more about AppNeta’s features or request a demo. If you already have AppNeta, check out our training resources to learn more about using it and setting up integrations.

    Tag(s): NetOps , AppNeta

    Craig Stone

    Craig has spent over 20 years working with Managed Service Providers (MSPs) in multiple roles from technical to management. At Broadcom he is a network performance monitoring specialist. Craig helps large enterprises and solution integrators to leverage our DX NetOps and AppNeta platforms to expand observability,...

    Other posts you might be interested in

    Explore the Catalog
    September 3, 2024

    With AppNeta, ResultsCX Decreases Network Performance Triage Time by 90%

    Read More
    August 22, 2024

    Broadcom Hosts the 2024 Network Observability Virtual Summit

    Read More
    August 12, 2024

    Optimizing VPN Performance and Availability with Network Observability by Broadcom

    Read More
    July 19, 2024

    Microsoft CrowdStrike Outage: Navigating the Top Three Risks of Cloud Dependence

    Read More
    June 20, 2024

    Monitoring and Optimizing the Experience of Remote Customer Care Agents

    Read More
    June 14, 2024

    Lessons From Our Fathers: On Network Operations Tools and Expertise

    Read More
    June 7, 2024

    WAN Management: Optimize User Experience and Maximize Cost Savings

    Read More
    May 20, 2024

    For Fourth Straight Year, GigaOm Names Broadcom Leader in Network Observability

    Read More
    May 13, 2024

    Best Practices for Operating and Monitoring an SD-WAN Network

    Read More