- 测试一下,打开命令行,curl 测试一下(不是非要装逼不用浏览器访问,公司的大佬说程序员要多用shell环境,嗯!从小事开始练);
温馨提示,在 mac 上安装 jq,直接使用 brew install jq 就会自动帮你安装好了。
好了,打完手工,没啥搞头,Spring Boot 永远滴神!
监控和管理应用
=======
我们的应用上线后,那肯定都是要上监控的,不然哪一天神不知鬼不觉死翘翘了,麻烦就大了。这个 Spring Boot 它就天生带了可以替我们监控和管理的 Spring 应用的模块工具:spring-boot-actuator 。
像什么 健康检查、审计、统计和HTTP追踪等该有的它都有。值得一提的是 spring-boot-actuator 它还很 open ,支持与其它外部监控系统做整合。补充了它自身没有一些好看的仪表盘、图表、分析、告警等 酷炫吊炸天的能力。
那怎么玩呢?
确认你的应用添加了对应的模块依赖;
=================
假如你使用的 maven,那看你的 pom.xml 中下面的依赖:
org.springframework.boot
spring-boot-starter-actuator
那如果你使用的 gradle,对应的 build.gradle 文件中有下面的依赖:
dependencies {
compile(“org.springframework.boot:spring-boot-starter-actuator”)
}
Actuator 通过 endpoint 来暴露 HTTP 请求 来监控和管理应用;
==========================================
应用启动后,
http://localhost:8080/actuator 会展示出所有通过 HTTP 暴露的 endpoint。
因为太长了,我这里列出的只是一部分 endpoint,你自己一定要动手试下。
就比如,/health 这个 endpoint,提供了关于应用健康的基础信息。
/metrics endpoint 展示了几个非常有用的度量信息,比如 JVM内存使用情况、系统 CPU 使用情况、打开的文件等等。
/loggers endpoint 展示了应用的日志和可以让你在运行时改变日志等级。
还有好多,下去都自己玩玩,动手就会了。
友情提示,如果你的
http://localhost:8080/actuator 展示的 开放端点很少,那是因为 actuator 的 endpoint 可以显式地被打开和关闭,明白了吧!
默认情况下很多 endpoint 是被关闭掉了,你只需要在 application.properties 配置文件中增加如下配置即可。
management.endpoint.health.show-details=always //显示详细的健康信息
management.endpoints.web.exposure.include=* //粗暴的全部打开,反正自己玩,任性
这里我们就不多说这些 endpoint 每个的作用了, 如果你感兴趣,可以给我留言,我会根据大家需求看下是否在出一期教程详细介绍一下。
当然除了上面默认显示的应用健康信息,我们也可以自定义一个健康指标;
我们可以选择实现 HealthIndicator 接口来实现我们的目标;
@SpringBootApplication
public class Springroad01Application {
// 加上这个Bean就可以了
@Bean
HealthIndicator healthIndicator() {
return () -> Health.up().withDetail(“app”, “i am so good”).
withDetail(“error”,“开什么玩笑,老夫怎么可能有错!”).build();
}
@Bean
RouterFunction routes (UsersDao usersDao) {
return RouterFunctions.route(GET(“/users”),serverRequest -> ok().body(usersDao.findAll(),Users.class));
}
public static void main(String[] args) {
SpringApplication.run(Springroad01Application.class, args);
}
}
一旦你加上我们上面自定义的健康指标,重启应用,就会看到 health 这个 endpoint 将展示出我们增加的这些信息:
安全控制
====
对于应用安全的支持,那就绕不开 Spring Security 了。
它可以轻松完成应用的鉴权、授权功能,同时也提供了对响应式编程的支持。
接下来就展示下如果让你的应用快速带上安全套。
- 加入 Spring-Security 依赖包;
org.springframework.boot
spring-boot-starter-security
- 内存中配置一个用户,设置用户名和密码;
@Bean
// 内存中配置用户名、密码为 admin/admin,用户角色为 USER
MapReactiveUserDetailsService users() {
return new MapReactiveUserDetailsService(User.withUsername(“admin”).password(PasswordEncoderFactories.createDelegatingPasswordEncoder().encode(“admin”)).roles(“USER”).build());
}
- 验证
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(资料价值较高,非无偿)
最后
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
img-community.csdnimg.cn/images/e5c14a7895254671a72faed303032d36.jpg" alt=“img” style=“zoom: 33%;” />
最后
[外链图片转存中…(img-xMIXrH86-1711532395020)]
[外链图片转存中…(img-t3Yk3r4k-1711532395020)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!