[开源项目]可观测、易使用的SpringBoot线程池,2024年最新面试完怎么问面试官结果

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

为了解决上述的问题,我开发了一个Spring Boot Starter(开源项目地址:https://gitee.com/hanxt/zimug-monitor-threadpool ),方便集成到Spring Boot项目里面去。目标是:在不改变SpringBoot线程池的核心实现的基础上,使其可视化、易观测、易配置、易使用

需要说明的是:zimug-monitor-threadpool并未改变SpringBoot线程池的实现,只是在其基础上添加了初始化阶段的配置自动化加载,运行时的状态监控。所以任何有关Spring Boot线程池运行时性能的讨论,都与本文及其实现无关。

一、易集成、易配置


通过上文的项目地址获取源码,然后maven编译install本地m2仓库。然后通过下面的maven坐标引入

com.zimug

zimug-monitor-threadpool

1.0

如下配置spring boot YAML(application.yml)所示,配置了两个线程池,分别是test、test2。当thread-pool.enable=true的时候线程池配置生效。

thread-pool:

enable: true

poolLists:

  • poolId: test #线程池唯一标识

poolName: 测试1 #线程池的中文描述,比如线程池给谁用?

coreSize: 5 #线程池初始化核心线程数量

maxSize: 10 #线程池最大线程容量

queueCapacity: 10 #线程池等待队列的容量

  • poolId: test2

poolName: 测试2

coreSize: 5

maxSize: 10

queueCapacity: 10

通过下面的这张图理解上面的配置信息

在这里插入图片描述

  • 当线程任务数量core_size被活跃任务线程占满之后,线程任务会被放入等待队列(queueCapacity=10)

  • 当等待队列queueCapacity也被占满之后,才会扩大线程池的容量

  • 线程池的容量最大扩展到maxSize。如果maxSize和queueCapacity都满了,任务就阻塞了。

二、易使用


使用方式和SpringBoot 代码方式自定义线程池的使用方式是一样的。使用@Async注解的值是test,调用该注解标识的函数就会放入上文中配置的test线程池里面去执行。

@Component

public class TestTask {

@Async(“test”) //注意这里,test是线程池配置的poolId

public Future test() throws Exception {

System.out.println(“当前线程:” + Thread.currentThread().getName());

return new AsyncResult<>(“测试任务”);

}

}

三、可视化易观测


在项目中引入zimug-monitor-threadpool之后,进行线程池配置,使用线程池。访问服务的/pool.html即可获取当前SpringBoot服务的线程池配置信息,以及运行时状态信息。

在这里插入图片描述

  • 线程池ID、描述、初始化线程数、最大线程数、任务等待队列的容量是上文中yaml静态配置

  • 当前线程池的容量,即:线程池当前的线程数量(活跃+非活跃线程数总和)

  • 当前活跃线程数,即:正在运行程序任务的线程数量

  • 线程池活跃线程的最大峰值,如果该值等于初始化线程数,说明曾经出现了任务等待,即:任务放入等待队列,效率较低。如果该值大于初始化线程数,说明任务等待队列曾经满载,需要扩容。如果该值接近等于最大线程数,就需要扩大最大线程数的值。

  • 当前任务等待队列剩余的容量,剩的越少,说明正在等待执行的任务就越多。

四、实现原理

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

更多笔记分享

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-juy00wH5-1713657308888)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 8
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值