【一】springboot整合swagger(超详细
【二】springboot整合swagger(自定义)(超详细)
【三】springboot整合token(超详细)
【四】springboot整合mybatis-plus(超详细)(上)
【五】springboot整合mybatis-plus(超详细)(下)
【六】springboot整合自定义全局异常处理
【七】springboot整合redis(超详细)
【八】springboot整合AOP实现日志操作(超详细)
【九】springboot整合定时任务(超详细)
【十】springboot整合redis实现启动服务即将热点数据保存在全局以及redis(超详细)
【十一】springboot整合quartz实现定时任务优化(超详细)
【十二】springboot整合线程池解决高并发(超详细,保你理解)
【十三】springboot整合异步调用并获取返回值(超详细)
【十四】springboot整合WebService(超详细)
【十五】springboot整合WebService(关于传参数)(超详细)
【十六】springboot整合WebSocket(超详细)
【十七】springboot整合WebSocket实现聊天室(超详细)
【十八】springboot实现自定义全局异常处理
【十九】springboot整合ElasticSearch实战(万字篇)
【二十】springboot整合过滤器实战
【二十一】springboot整合拦截器实战并对比过滤器
【二十二】springboot整合activiti7(1) 实战演示篇
【二十三】springboot整合spring事务详解以及实战
【二十四】springboot使用EasyExcel和线程池实现多线程导入Excel数据
【二十五】springboot整合jedis和redisson布隆过滤器处理缓存穿透
上一章进行了AOP的整合,实现了日志的操作(请求接口后新增日志)。本章 将对其进行改进,整合定时任务,在某一时间再进行新增操作(会更优化,若每次请求接口时切面都去进行一个新增日志操作会对服务器造成很大压力)。
qq交流群导航——>231378628
首先还是展示目录结构:
本章主要采用队列,定时任务,定时任务插入数据,队列存储每次需要插入的数据,每次插入后就清空队列。
ps:注意加上component注解,将该队列以组件形式注入spring容器,让他来管理。
volatile是Java提供的一种轻量级的同步机制。多个线程访问该变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值。
1、注入刚才创建的队列。2、在after里面,将符合要求的log加入队列。
@Slf4j
@Component
public class LogTask {
@Resource
LogQueue logQueue;
@Resource
ISyslogService sysLogService;
private volatile List operLogs = Collections.synchronizedList(new ArrayList<>());
// @Scheduled(cron = "0/5 * * * * ?")
@Scheduled(cron = "0 */1 * * * ?")//每隔一分钟执行一次
public void logFixDelay(){
System.out.println("进入");
//获取日志信息
while (true){
SysLog operLog = logQueue.poll();
if(null==operLog){
break;
}
operLogs.add(operLog);
}
if(operLogs.size()>0){
try{
log.info("######################批量添加系统日志"+operLogs.size());
sysLogService.insertAll(operLogs);
}catch (Exception e){
log.error("批量添加系统日志异常:",e);
operLogs.clear();
}
operLogs.clear();
}
}
}
解读:
ps:poll() 获取并移除此队列的头,如果此队列为空,则返回 null,否则返回头数据。
若获取并移除队列的头为空,则跳出,否则将该数据加入到集合operLogs,再调用insertAll方法批量插入日志的集合,插入完成则清空该集合。
Scheduled的写法有很多,最常用的还是cron写法,自行搜索,此处附在线生成器:在线Cron表达式生成器
ps:insertAll方法如下:
ps:此处insert方法是mybatis-plus的方法。
在启动类新增EnableScheduling注解
接口请求前
请求多次接口,等待一分钟
已经新增成功。
本期整合到此完毕,接下来会继续更新加强整合,尽情期待。
访问地址:http://localhost:8087/swagger-ui.html或者http://localhost:8087/doc.html
demo地址:studydemo/整合swagger at main · zrc11/studydemo · GitHub