AMS Prometheus
Amazon Managed Service for Prometheus (or AMS Prometheus) is a monitoring and alerting service that ensures easy-to-use monitoring of containerized applications and infrastructure. It's scalable, and you don't have to worry about hosting it yourself.
Amazon Prometheus parameters and supported features in Nobl9
- General support:
- Release channel: Stable, Beta
- Connection method: Agent
- Replay and SLI Analyzer: Historical data limit 30 days
- Event logs: Not supported
- Query checker: Not supported
- Query parameters retrieval: Supported
- Timestamp cache persistence: Supported
- Query parameters:
- Query interval: 1 min
- Query delay: 0 sec
- Jitter: 15 sec
- Timeout: 30 sec
- Agent details and minimum required versions for supported features:
- Plugin name: n9prometheus
- Query delay environment variable: PROM_QUERY_DELAY
- Replay and SLI Analyzer: 0.65.0
- Query parameters retrieval: 0.73.2
- Timestamp cache persistence: 0.65.0
- Custom HTTP headers: 0.88.0 / 0.83.0-beta
- Additional notes:
- Support for Prometheus metrics
- No support for IAM roles for bare EC2 instances
- Learn more  
Authentication
For more details, refer to Authentication for AMS Prometheus.
To set up the connection, AMS Prometheus requires users to enter the URL. To get the URL:
- 
Sign in to your AWS account. 
- 
Click the AMS Prometheus in the Management & Governance panel:  Image 1: Configuring authentication for AMS Prometheus (1) 
- 
Click All workspaces.  Image 2: Configuring authentication for AMS Prometheus (2) 
- 
Choose a relevant workspace:  Image 3: Configuring authentication for AMS Prometheus (3) 
- 
In the Summary screen, copy the Endpoint - query URL Image 4: Configuring authentication for AMS Prometheus (4) 
The url that you need is the Endpoint - query URL without the /api/v1/query string at the end of the URL.
Adding Amazon Managed Service for Prometheus as a data source
To ensure data transmission between Nobl9 and Amazon Prometheus, it may be necessary to list Nobl9 IP addresses as trusted.
app.nobl9.com instance:- 18.159.114.21
- 18.158.132.186
- 3.64.154.26
us1.nobl9.com instance:- 34.121.54.120
- 34.123.193.191
- 34.134.71.10
- 35.192.105.150
- 35.225.248.37
- 35.226.78.175
- 104.198.44.161
You can add the AMS Prometheus data source using the agent connection method.
Nobl9 Web
Follow the instructions below to create your AMS Prometheus agent connection:
- Navigate to Integrations > Sources.
- Click. 
- Click the required Source button.
- Choose Agent.
- 
Select one of the following Release Channels:- The stablechannel is fully tested by the Nobl9 team. It represents the final product; however, this channel does not contain all the new features of abetarelease. Use it to avoid crashes and other limitations.
- The betachannel is under active development. Here, you can check out new features and improvements without the risk of affecting any viable SLOs. Remember that features in this channel can change.
 
- The 
- 
Add the URL to connect to your data source (mandatory). 
 Refer to Authentication for AMS Prometheus for detailed instructions on how to get the URL.
- 
Enter a Region (mandatory). 
 The list of supported Regions for AMS Prometheus is here.
- 
Set Step to define the metric resolution (mandatory, default:60seconds).
 The Step value must be a positive integer. It controls how many data points Nobl9 retrieves in a single query.- For optimal operation, consider the following recommendations for its value:
- Aim for 15 seconds or more
- It should be equal to or less than your AMS Prometheus query interval
 Minimum agent version requirementThe Step parameter is supported starting from Nobl9 agent version0.105.0-betaand later versions.
- Select a Project (mandatory).
 Project is a way to organize your Nobl9 resources and manage access to them.
 When Project is skipped, Nobl9 uses thedefaultproject.
- Enter a Display Name (optional).
 Spaces are allowed.
- Enter a Name (mandatory).
 The name is mandatory and can only contain lowercase, alphanumeric characters, and dashes (for example,my-project-1). Nobl9 duplicates the display name here, transforming it into the supported format, but you can edit the result.
- Enter a Description (optional).
 Provide extra details about it, its purpose, responsible persons, etc.
 Up to 1050 characters.
- Specify the Query delay to set a customized delay for queries when pulling the data from the data source.- The default value in AMS Prometheus integration for Query delay is 0 seconds.
 Changing the query delayChanging the query delay can affect your SLI data.
 Learn more about query delay and its impact.
- The default value in AMS Prometheus integration for Query delay is 
- Enter a Maximum Period for Historical Data Retrieval.- This value defines how far back in the past your data will be retrieved when replaying your SLO based on this data source.
- The maximum period value depends on the data source.
 Find the maximum value for your data source.
- A greater period can extend the loading time when creating an SLO.
- The value must be a positive integer.
 
- Enter a Default Period for Historical Data Retrieval.- It is used by SLOs connected to this data source.
- The value must be a positive integer or 0.
- By default, this value is set to 0. When you set it to >0, you will create SLOs with Replay.
 
- Click Add Data Source
- Deploy your agent in a Kubernetes cluster or Docker container.
YAML
- Create a YAML definition to set up an agent connection with AMS Prometheus. For this, refer to the following example:
apiVersion: n9/v1alpha
kind: Agent
metadata:
  name: amazon-prometheus
  displayName: Amazon Prometheus Agent
  project: default
  annotations:
    area: latency
    env: prod
    region: us
    team: sales
spec:
  description: Example Amazon Prometheus Agent
  releaseChannel: stable
  amazonPrometheus:
    url: https://aps-workspaces.us-east-1.amazonaws.com/workspaces/ws-f49ecf99-6dfa-4b00-9f94-a50b10a3010b
    region: us-east-1
    step: 60
  historicalDataRetrieval:
    maxDuration:
      value: 30
      unit: Day
    defaultDuration:
      value: 15
      unit: Day
  queryDelay:
    value: 1
    unit: Second
| Field | Type | Description | 
|---|---|---|
| queryDelay.unitmandatory | enum | Specifies the unit for the query delay. Possible values: Second|Minute.• Check query delay documentation for default unit of query delay for each source. | 
| queryDelay.valuemandatory | numeric | Specifies the value for the query delay. • Must be a number less than 1440 minutes (24 hours). • Check query delay documentation for default unit of query delay for each source. | 
| releaseChannelmandatory | enum | Specifies the release channel. Accepted values: beta|stable. | 
| Source-specific fields | ||
| amazonPrometheus.urlmandatory | string | is the `Endpoint - query URL` in AMS Prometheus. Check Authentication for AMS Prometheus for detailed instructions on how to get it | 
| amazonPrometheus.regionmandatory | string | Check the list of supported regions for AMS Prometheus. | 
| amazonPrometheus.stepmandatory | integer | Defines metrics resolution in seconds. Must be a positive integer, 60 seconds by default. Recommendations: Use a value of at least 15 seconds and less than or equal to your AMS Prometheus query interval. | 
| Replay-related fields | ||
| historicalDataRetrievaloptional | n/a | Optional structure related to configuration related to Replay. ❗ Use only with supported sources. • If omitted, Nobl9 uses the default values of value: 0andunit: DayformaxDurationanddefaultDuration. | 
| maxDuration.valueoptional | numeric | Specifies the maximum duration for historical data retrieval. Must be integer ≥ 0. See Replay documentation for values of max duration per data source. | 
| maxDuration.unitoptional | enum | Specifies the unit for the maximum duration of historical data retrieval. Accepted values: Minute|Hour|Day. | 
| defaultDuration.valueoptional | numeric | Specifies the default duration for historical data retrieval. Must be integer ≥ 0and≤maxDuration. | 
| defaultDuration.unitoptional | enum | Specifies the unit for the default duration of historical data retrieval. Accepted values: Minute|Hour|Day. | 
- Apply your YAML definition using the sloctl applycommand.
- Deploy your agent in a Kubernetes cluster or Docker container.