【CouponHub项目开发】EasyExcel解析Excel并使用线程池异步执行和延时队列兜底

文章目录

为什么使用Excel

因为在特定电商场景下,可能会出现比如有的平台会根据用户的喜好从而生成一些用户画像,企业再从画像平台去获取特定喜好的用户,会得到一个Excel表格。

为什么使用线程池进行异步执行

因为如果表格的内容很多,百万级别的数据。那么如果是单线程运行情况下,会导致用户等待大量时间使用线程池异步执行则可以直接返回用户操作成功的响应,而真正的操作是交给后台线程异步执行的

为什么使用延时队列进行兜底

因为如果任务刚提交到线程池当中就宕机了,那么线程池当中的任务就不会执行了,为了解决这种情况,采用延时队列进行兜底。

首先定义EasyExcel中的行数监听器

创建优惠券分发任务,并将其存入数据库当中。

然后通过线程池去异步执行更新数据库当中优惠券分发任务的sendnum字段。

然后创建一个阻塞队列,然后基于这个阻塞队列创建一个延时队列

delayedQueue.offer(delayJsonObject, 20, TimeUnit.SECONDS);作用是:设置延时时间,到时间后将延时队列里的信息传到阻塞队列中,这也是为什么能从阻塞队列中获取delayJsonObject的原因

接着我们定义一个延时队列的消费者。他在项目运行时创建一个线程,去获取Redis当中的阻塞队列。然后不断循环去获取阻塞队列中的delayJSON,然后再根据delayJSON中的id去查询数据库,判断数据库中这个优惠券分发任务的分发数量是否为0.如果为0说明线程池没有去执行 refreshCouponTaskSendNum方法,然后让该线程去执行。

线程池的核心参数

1.核心线程数

2.最大线程数

3.工作队列

4.keepAliveTime

5.keepAliveTime的单位unit

6.ThreadFactory

7.handler拒绝策略

拒绝策略有哪些

1.CallerRunsPolicy使用线程池的调用者所在的线程去执行被拒绝的任务

2.AbortPolicy直接抛出异常

3.DiscardPolicy直接拒绝,不做任何处理

4.DiscardOldestPolicy抛弃最老的,然后执行该任务

相关推荐
龙茶清欢2 分钟前
7、revision 是 Maven 3.5+ 引入的现代版本管理机制
java·elasticsearch·maven
柯南二号3 分钟前
【Java后端】《Spring Boot Starter 原理详解》博客
java·开发语言·spring boot
歪歪10018 分钟前
如何在SQLite中实现事务处理?
java·开发语言·jvm·数据库·sql·sqlite
瑶总迷弟22 分钟前
静默安装 Oracle Database 21c on CentOS 7.6
数据库·oracle·centos
毕设源码-郭学长36 分钟前
【开题答辩全过程】以 J2EE在电信行业的应用研究为例,包含答辩的问题和答案
java·java-ee
Aevget37 分钟前
「Java EE开发指南」如何用MyEclipse开发Java EE企业应用程序?(二)
java·ide·java-ee·开发·myeclipse
不爱编程的小九九1 小时前
小九源码-springboot048-基于spring boot心理健康服务系统
java·spring boot·后端
龙茶清欢1 小时前
Spring Boot 应用启动组件加载顺序与优先级详解
java·spring boot·后端·微服务
青云交1 小时前
Java 大视界 -- Java 大数据在智能公交调度优化与准点率提升中的应用实践(416)
java·动态规划·flink cep·spark mllib·智能公交调度·杭州公交案例·准点率提升
RainbowSea1 小时前
4. ChatClient 的初始,快速使用上手
java·spring·ai编程