1.背景
在实际开发中,经常会遇到支付需求,当然就会有支付对账的需求….
2.项目结构
3.代码
线程池配置对象
@Configuration@EnableAsyncpublic class ExecutorConfig {/*** @return*/@Beanpublic Executor asyncServiceExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();//配置核心线程数executor.setCorePoolSize(30);//配置最大线程数executor.setMaxPoolSize(40);//配置队列大小executor.setQueueCapacity(99999);//配置线程池中的线程的名称前缀executor.setThreadNamePrefix("async-service-");// rejection-policy:当pool已经达到max size的时候,如何处理新任务// CALLER_RUNS:不在新线程中执行任务,而是有调用者所在的线程来执行executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());//执行初始化executor.initialize();return executor;}}
controller代码
@RestControllerpublic class BillController {@Autowiredprivate IBillService billService;/*** 下载对账单** @return*/@RequestMapping("/api/downBill")public Object downBill() {Object result = billService.billDown();return "ok::" + result;}}
业务层代码-下载
/*** @author 姿势帝-博客园* @address https://www.cnblogs.com/newAndHui/* @WeChat 851298348* @create 10/30 11:27* @description <p>* 以下载支付宝对账单为案例进行演示* 接口文档:https://opendocs.alipay.com/open/02ivbw* 关于支付支付课程可以查看:https://www.cnblogs.com/newAndHui/p/14258491.html* </p>*/@Service@Slf4jpublic class BillServiceImpl implements IBillService {@Autowiredprivate IOrderService orderService;@Overridepublic Object billDown() {// 以下载支付宝对账单为案例进行演示// 这里模拟一个对账文件ExcelReader reader = ExcelUtil.getReader(FileUtil.file("F:\\test\\t1.xlsx"));// 分页取值,每页10条boolean flag = true;int pageIndex = 1;int pageSize = 10;int sum = 0;while (flag) {int startIndex = pageSize * (pageIndex - 1) + 1;int endIndex = startIndex + pageSize - 1;List<Map<String, Object>> list = reader.read(0, startIndex, endIndex);int size = list.size();if (size > 0) {sum += size;// 异步保存数据orderService.saveBillOrder(list);}if (list.size() < pageSize) {flag = false;} else {pageIndex++;}}return "共:" + sum + "交易记录";}}
业务层代码-保存
@Service@Slf4jpublic class IOrderServiceImpl implements IOrderService {@Override@Async("asyncServiceExecutor")public void saveBillOrder(List<Map<String, Object>> list) {int size = list.size();log.info("保存数据:" + size);int i = 1;for (Map<String, Object> bIllOrder : list) {log.info("保存第:" + i + "/" + size + ",bIllOrder=" + bIllOrder);// 模拟保存耗时(0到5秒)ThreadUtil.sleepRandom();i++;log.info("数据保存完成");}}}
对账文件模板
4.测试
@Testvoid downBill() {String url = "http://localhost:8001/api/downBill";HttpRequest request = HttpUtil.createGet(url);String response = request.execute().body();System.out.println(response);}
