熟悉压测工具 jmeter
接口优化 - QPS提升(异步任务+resttemplate池化)
异步任务 - 异步发送
1.适用范围:处理log、发送邮件、短信,或涉及网络IO调用操作。
2.使用方法:springboot启动类上添加@EableAsync,某个需要的异步方法上加上@Async 该类必须是spring容器。
3.@Async失效情况如下:
@Async的方法不是public方法
@Async返回值只能是void或为Futrue
@Async使用static修饰
spring无法扫描到异步类 没加@Async或者@EnableAsync
调用方和被调用方不在同一个类
类中需要@Autowried或者@Resource等注解自动注入,不能自己手动new对象
在Async方法添加@Transactional是没有用的,但是在Async方法调用的方法上标注@Transactional是有效的
4.压测高QPS原因
压测后很快跑完全部任务,是因为在线程池内部的阻塞队列里面
后果: 极容易出现oom(内存用完),或出现消息丢失
5.Async+ThreadPoolTaskExecutor自定义线程池进阶实战
解决方式:Spring会先搜索TaskExecutor类型的bean或者名为taskExecutor的Executor的bean,
所以自定义线程池覆盖ThreadPoolTaskExecutor
package net.xdclass.config;