【发布时间】:2019-03-27 08:09:22
【问题描述】:
我将 Spring Boot 与 Shiro 一起使用,但我启动 Application 并导航到 /actuator/metrics 会显示可用仪表名称的列表:
{
names: [
"http.server.requests",
"jdbc.connections.max",
"jdbc.connections.min"
]
}
只有 3 件!!!
然后,我屏蔽 shiro 配置:
//@Configuration
public class ShiroConfig {
...
}
我再次启动应用程序,我得到了所有:
{
names: [
"jvm.memory.max",
"process.files.max",
"jvm.gc.memory.promoted",
"tomcat.cache.hit",
"system.load.average.1m",
"tomcat.cache.access",
"jvm.memory.used",
"jvm.gc.max.data.size",
"jdbc.connections.max",
"jdbc.connections.min",
"jvm.gc.pause",
"jvm.memory.committed",
"system.cpu.count",
"logback.events",
"tomcat.global.sent",
"jvm.buffer.memory.used",
"tomcat.sessions.created",
"jvm.threads.daemon",
"system.cpu.usage",
"jvm.gc.memory.allocated",
"tomcat.global.request.max",
"tomcat.global.request",
"tomcat.sessions.expired",
"jvm.threads.live",
"jvm.threads.peak",
"tomcat.global.received",
"process.uptime",
"tomcat.sessions.rejected",
"process.cpu.usage",
"tomcat.threads.config.max",
"jvm.classes.loaded",
"jvm.classes.unloaded",
"tomcat.global.error",
"tomcat.sessions.active.current",
"tomcat.sessions.alive.max",
"jvm.gc.live.data.size",
"tomcat.servlet.request.max",
"tomcat.threads.current",
"tomcat.servlet.request",
"process.files.open",
"jvm.buffer.count",
"jvm.buffer.total.capacity",
"tomcat.sessions.active.max",
"tomcat.threads.busy",
"process.start.time",
"tomcat.servlet.error"
]
}
我想同时使用 Actuator 和 Shiro。 感谢您的帮助。
【问题讨论】:
-
你能分享你的 Pom.xml 和其他配置吗?
-
我缩小了问题范围:当我使用shiro时,我在我的CustomRealm.java文件中注入了mybatis的xxxMapper,因为我需要通过mybatis从数据库中获取数据。我使用@Autowired注入了mybatis的xxxMapper,我尽量不注入mybatis的xxxMapper,所以我删除了注解,虽然我无法从数据库中获取数据。没想到,我删除注解后/actuator/metrics显示了一个列表可用的仪表名称!!!
-
我认为可能是由于 Beans 的加载顺序。
-
我明天会尝试手动注入[mybatis mapper]。 【mybatis mapper】只需要在加载数据库数据的具体方法中手动注入即可。
标签: java spring spring-boot shiro spring-boot-actuator