Kong API Gateway
Introduction
Kong Gateway is a lightweight, fast, and flexible cloud-native API gateway. An API gateway is a reverse proxy that lets you manage, configure, and route requests to your APIs.
Getting Started
Compatibility
vuSmartMaps supports the monitoring of the Kong API Gateway metric using prometheus endpoint.
Data Collection Method
vuSmartMaps collects health and performance data for Kong API Gateway using VuNet's Internal Data Collector.
Prerequisites
Inputs for Configuring Data Source
- Kong API Server: The IP Address/FQDN of the Kong API server. This field is the key to identify each server you add here.
- Kong Server's Endpoint: The URL to Kong API Server endpoint. Eg: http://127.0.0.1, https://127.0.0.1, http://127.0.0.1:8080 or https://127.0.0.1:8080
- Period (in seconds): Time interval for polling data from the Kong API Server. Period should be between 60 seconds – 3000 seconds.
Firewall Requirement
To collect data from this O11ySource, ensure the following ports are opened:
Source IP | Destination IP | Destination Port | Protocol | Direction |
---|---|---|---|---|
vuSmartMaps IP | Kong API Gateway | 8101* | TCP | Outbound |
*Before providing the firewall requirements, please update the port based on the customer environment.
Configuring the Target
Health and Performance metrics from prometheus endpoint. Telemetry endpoint must be enabled in the Kong API server so that /metrics endpoint must accessible from the vuSmartMaps Server. Please refer here for more details to enable the end point.
Configuration Steps
Enable
the O11ySource.- Select the sources tab and press the
+
button to add a new instance that has to be monitored. - Provide the required configurations:
- *Kong API Server
- *Kong Server's Endpoint
- *Period (in seconds)
- Click
Save
to close the data source window.
Metrics Collected
Name | Description | Data Type |
---|---|---|
@timestamp | Timestamp at which the data is collected by agent | String |
timestamp | Precise event timestamp with milliseconds | DateTime64(3) |
target | Server from where the data is collected | String |
tags_host | Server from where the data is collected | String |
doc_type | Document type of the entry | String |
tenant_id | Tenant ID for the metrics entry | LowCardinality(String) |
bu_id | Business Unit ID for the entry | LowCardinality(String) |
tags_url | URL endpoint from where the request is being made | String |
tags_service | Service name related to the API | String |
tags_route | Route associated with the API | String |
tags_direction | Direction of the API call (inbound/outbound) | String |
tags_code | HTTP status code | UInt16 |
tags_shared_dict | Shared dictionary in use | String |
tags_subsystem | Subsystem generating the metric | String |
tags_kong_subsystem | Kong subsystem | String |
tags_state | State of the request | String |
tags_node_id | Node ID of the Kong instance | String |
metric_name | Name of the metric being recorded | String |
metric_value | Value of the recorded metric | Float64 |
metric_value_diff | Difference in metric value | Float64 |
tags_pid | Process ID of the Kong instance | UInt32 |
host | Host on which Kong is running | String |
Port | Port of the Kong instance | String |
tags_target | Target of the upstream service | String |
tags_upstream | Upstream service in the request | String |
tags_address | Address of the service or host | String |