springboot线程池和CompletableFuture配合使用

1.线程池配置文件(依个人、环境而定)

package com.rk.iam.sys.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
import java.util.concurrent.ThreadPoolExecutor;

/**
 * @author wdy
 * @version 1.0
 * @date 2022/3/3 10:51
 */
@Configuration
public class ThreadPoolConfig {
    //参数初始化
    private static final int CPU_COUNT = Runtime.getRuntime().availableProcessors();
    //核心线程数量大小
    private static final int corePoolSize = Math.max(2, Math.min(CPU_COUNT - 1, 4));
    //线程池最大容纳线程数
    private static final int maxPoolSize = CPU_COUNT * 2 + 1;
    //阻塞队列
    private static final int workQueue = 20;
    //线程空闲后的存活时长
    private static final int keepAliveTime = 30;

    @Bean("asyncTaskExecutor")
    public Executor getAsyncExecutor() {
        ThreadPoolTaskExecutor threadPoolTaskExecutor = new ThreadPoolTaskExecutor();
        //核心线程数
        threadPoolTaskExecutor.setCorePoolSize(corePoolSize);
        //最大线程数
        threadPoolTaskExecutor.setMaxPoolSize(maxPoolSize);
        //等待队列
        threadPoolTaskExecutor.setQueueCapacity(workQueue);
        //线程前缀
        threadPoolTaskExecutor.setThreadNamePrefix("taskExecutor-");
        //线程池维护线程所允许的空闲时间,单位为秒
        threadPoolTaskExecutor.setKeepAliveSeconds(keepAliveTime);
        // 线程池对拒绝任务(无线程可用)的处理策略
        threadPoolTaskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        threadPoolTaskExecutor.initialize();
        return threadPoolTaskExecutor;
    }

}

2.

注意@Bean的参数asyncTaskExecutor,下面会用到。

 2.CompletableFuture(就相当于一个Service一样)

package com.rk.iam.sys.service;

import com.alibaba.fastjson.JSONObject;
import com.rk.iam.idp.entity.GitQuerycapComIdpSrvIdpPkgAccountmgrAccountWithAccountIdentities;
import com.rk.iam.idp.entity.GitQuerycapComIdpSrvIdpPkgAccountmgrAccountWithAccountIdentitySetDataList;
import com.rk.iam.idp.entity.GitQuerycapComIdpSrvIdpPkgAccountmgrUserAccountIDWithPassword;
import com.rk.iam.idp.entity.Param_listAccount;
import com.rk.iam.idp.feign.AccountFeignClient;
import com.rk.iam.sys.common.enums.StatusEnums;
import com.rk.iam.sys.common.vo.SysUserVO;
import com.rk.iam.sys.config.SysConfigurationProperties;
import com.rk.iam.sys.entity.SysConsumer;
import com.rk.iam.sys.entity.SysUser;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executor;

/**
 * @author wdy
 * @version 1.0
 * @date 2022/3/3 10:53
 */
@Component
@Slf4j
public class AsyncTask {
    @Autowired
    private SysConsumerService sysConsumerService;

    @Autowired
    private AccountFeignClient accountFeignClient;

    @Autowired
    private SysConfigurationProperties sysConfigurationProperties;
    @Autowired
    private SysUserService sysUserService;

    @Autowired
    private Executor asyncTaskExecutor;    //注入线程池的bean

    public CompletableFuture<String> BatchRegIdp(List<SysUserVO> list, Long cid) {

        return CompletableFuture.supplyAsync(() -> {
            //具体要执行的逻辑
            try {
                for (SysUserVO sysUserVO : list) {
                    SysUser sysUser1 = sysUserService.convertToEntity(sysUserVO);
                    try {
                        SysUser sysUser = registerIDP(sysUser1, cid);
                        if (sysUser == null) {
                            continue;
                        }
                    } catch (Exception e) {
                        e.printStackTrace();
                    }

                }

            } catch (Exception e) {
                log.error(e.getMessage(), e);
                e.printStackTrace();
            }
            return "注册idp用户成功";
        }, asyncTaskExecutor);  //这个参数就是上面提到的线程池的bean
    }

    public SysUser registerIDP(SysUser sysUser, Long cid) {
        if (StringUtils.isBlank(sysUser.getIdpId())) {
            SysConsumer consumer = sysConsumerService.getById(cid);
            //当前客户开启同步IDP用户功能
            if (StatusEnums.Status.VALID.getCode() == consumer.getIsidp()) {

                Param_listAccount param = new Param_listAccount();
                param.setIdentity(Arrays.asList(sysUser.getLoginName()));
                param.setAccountType(Arrays.asList("USER"));
                param.setIdentityType(Arrays.asList("MOBILE"));
                GitQuerycapComIdpSrvIdpPkgAccountmgrAccountWithAccountIdentitySetDataList userList = accountFeignClient.listAccount(sysConfigurationProperties.getIdp().getToken(), param);
                if (userList.getTotal() == 0) {
                    JSONObject obj = new JSONObject();
                    obj.put("mobile", sysUser.getLoginName());
                    obj.put("nickname", sysUser.getUserName());
                    GitQuerycapComIdpSrvIdpPkgAccountmgrUserAccountIDWithPassword user = accountFeignClient.createUser(sysConfigurationProperties.getIdp().getToken(), obj);
                    sysUser.setIdpId(user.getAccountID());
                } else {
                    List<GitQuerycapComIdpSrvIdpPkgAccountmgrAccountWithAccountIdentities> data = userList.getData();
                    for (GitQuerycapComIdpSrvIdpPkgAccountmgrAccountWithAccountIdentities datum : data) {
                        sysUser.setIdpId(datum.getAccountID());
                    }
                }
            }
        }
        return sysUser;
    }

}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值