In my Spring Boot App (2.0.0.M7) application.properties I set
management.endpoint.metrics.enabled=true
However, when i hit
localhost:8080/actuator/metrics
I get 404.
Whats the solution?
In my Spring Boot App (2.0.0.M7) application.properties I set
management.endpoint.metrics.enabled=true
However, when i hit
localhost:8080/actuator/metrics
I get 404.
Whats the solution?
I would like to enhance the OP's answer with more information as I struggled a bit before finally stumbling upon this solution and there seem to be lots of confusion about changes to actuator behavior with Spring Boot 2
What hasn't changed
You need to include a dependency to spring-boot-starter-actuator
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
If you want to access actuator endpoints via HTTP, you also need to add a dependency to spring-boot-starter-web
So your pom dependencies will look like below
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
Changes introduced in Spring Boot 2
Endpoints like /health
, /metrics
etc. are no longer available at the default root context. They are available from now on at
http://{host}:{port}/actuator
.
Also, it doesn't matter whether your application's all other endpoints begin with some other context such as /hello
-- actuator is available at /actuator
and not at /hello/actuator
.
Response from /actuator
endpoint is by default HATEOAS enabled. Prior to Spring Boot 2, this was the case only if HATEOAS is on the classpath and explicitly enabled in application.yml
To make an actuator endpoint available via HTTP, it needs to be both enabled and exposed.
By default:
only the /health
and /info
endpoints are exposed, regardless of Spring Security being present and configured in your application.
all endpoints but /shutdown
are enabled (though only /health
and /info
are exposed)
If you want to expose all of the endpoints (not always a good idea), you may do so by adding management.endpoints.web.exposure.include=*
to application.properties
. Don't forget to quote the wildcard if you're using yml-configurations.
endpoints.xyz
are deprecated in favor of properties starting with management.xyz
For a full documentation, see official doc and also the migration guide
Add the following line to your application.properties
file:
management.endpoints.web.exposure.include=metrics
That's all.
Okay i found the solution. I have added another line in application.properties
management.endpoints.web.expose=*
However, securing the actuator endoints is important
Read here: https://docs.spring.io/spring-boot/docs/current/reference/html/production-ready-monitoring.html
What worked for me is the following (in YAML format) working with spring boot 2 release:
management:
endpoints:
web:
exposure:
include: info, health, metrics
metrics:
export:
atlas:
enabled: false
also specific documentation can be found here
According micrometer docs .Spring Boot 2.0.x supports Micrometer out of the box via Spring Boot Actuator.
The endpoint metric is disabled by default, in line with Spring Boot 2’s litmus test that any endpoint that potentially exposes sensitive data about an application should be disabled by default. It can be enabled by setting:
management.endpoints.web.exposure.include: metrics
Navigating to /actuator/metrics
displays a list of available meter names.
To access them, use something like this: http://localhost:8080/actuator/metrics/jvm.memory.used
You need to add the below props in your application.properties
file. I had the same issue until I added the below props.
management.endpoints.beans.enabled=false
management.endpoints.web.exposure.include=*