I am using springboot as microservice.
I have around 20 microservices in my k8s cluster.
I am using promethues to collect data to show in grafana.
In that application there are some url which uses Path variable like as follow
- /v1/contacts/{id}
- /v1/users/{id}
There are few more urls, If I consider all such URLs in all microservices then that could be around 60 to 70 URLs which uses path variable.
Problem :
Now whenever any url is getting requested i.e like
- /v1/contacts/10
- /v1/contacts/111
- /v1/contacts/51
- /v1/users/91
so on...
Then promethus is collecting metrics for all such url. After some time it has huge metrics, and at the end my response time is increased for collecting data from prometheus.
So basically I want to clear prometheus logs after some interval from my springboot application.
I am not sure whether its possible or not.
Can someone please help me to solve this ?
Thanks
 
                        
Prometheus has several flags that configure local storage.
--storage.tsdb.path: Where Prometheus writes its database. Defaults todata/.--storage.tsdb.retention.time: When to remove old data. Defaults to 15d. Overrides storage.tsdb.retention if this flag is set to anything other than default.--storage.tsdb.retention.size: [EXPERIMENTAL] The maximum number of bytes of storage blocks to retain. The oldest data will be removed first. Defaults to 0 or disabled. This flag is experimental and may change in future releases. Units supported: B, KB, MB, GB, TB, PB, EB. Ex: "512MB"Prometheus storage link
Steps:
Spring Boot application exposure monitoring indicators, add the following dependencies.
<artifactId>spring-boot-starter-actuator</artifactId>or
<groupId>io.prometheus</groupId>artifactId>simpleclient_spring_boot</artifactId>Prometheus collects Spring Boot indicator data. First, get the Docker image of Prometheus:
docker pull prom/prometheusThen, write the configuration file prometheus.yml:
You can add more values to it. Sample here
Next, start Prometheus:
Alternative way, you can use this link Monitoring Spring Boot projects with Prometheus
But make sure when you run the Prometheus server with Docker Compose you have to update the
commandssection with size or time properties.