【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抛弃最老的,然后执行该任务

相关推荐
我想起个名字3 小时前
sqlserver2008导入excel表数据遇到的问题
sqlserver·excel
Metaphor6923 小时前
Java 如何在 Excel 中添加超链接?使用 Spire.XLS for Java 轻松实现
java·经验分享·excel
David爱编程3 小时前
锁升级机制全解析:偏向锁、轻量级锁、重量级锁的秘密
java·后端
技术小泽3 小时前
深度解析Netty架构工作原理
java·后端·性能优化·架构·系统架构
神云瑟瑟4 小时前
Spring Boot大文件分块上传(代码篇)
java·spring boot·大文件上传·分块上传
川石课堂软件测试4 小时前
Oracle 数据库使用事务确保数据的安全
数据库·python·功能测试·docker·oracle·单元测试·prometheus
guslegend4 小时前
数据库小册(1)
数据库
皆过客,揽星河4 小时前
mysql初学者练习题(从基础到进阶,相关数据sql脚本在最后)
数据库·sql·mysql·oracle·mysql基础练习·mysql基础语法·数据库练习题
努力也学不会java4 小时前
【设计模式】代理模式
java·设计模式·代理模式