List数据分段以后再使用多线程执行

List数据分段以后再使用多线程执行,提高效率

大致业务场景,需要后台刷新产品详情缓存,for循环跑需要1个多小时才能执行完毕。
最后使用多线程处理,伪代码如下

//查询所有商品list ,商品较多几千只,不可能一下起几千线程处理。所以先将list分割
// PAGE_SIZE 可在配置中心设定,动态调整list分割数量
List<String> idList;
	int currentPage = 1;
		int pageSize = Integer.valueOf(PAGE_SIZE);
		int totalPage = idList.size() % pageSize>0?(idList.size() / pageSize)+1:idList.size() / pageSize;
		while (currentPage <= totalPage) {
			//把list分段
			List<String> currentList = pageBySubList(idList, currentPage, pageSize);
			//具体多线程处理逻辑
			executeRefreshDetail(currentList);
			currentPage += 1;
		}

 /**
	 * 这里是每一段list
	 * 然后使用多线程处理,利用CountDownLatch 机制,保证一批次全部处理完成后再进行下一段。防止过多任务,压垮下游服务
	 */
private void executeRefreshDetail(List<String> idList) {
		if (CollectionUtils.isEmpty(idList)) {
			return;
		}
		try {
			CountDownLatch countDownLatch = new CountDownLatch(idList.size());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值