多线程实际应用处理多次Http请求
需求分析
公司里有一个需求就是批量保存用户信息。用一个采集设备,采取用户的身份证信息来做一个门禁信息登记。采集的信息有身份证号码等和一张拍照注册的照片。这张照片要保存到门禁设备中,又要在门禁设备注册人员、添加门禁权限信息,添加注册照片(照片通过Url传递)。这保存一个人员多次Http请求,多次批量70个就需要更长时间。这里用多线程和异步处理结果。
多线程
我多线程有三种实现方式 我这里采用的构建一个类实现Runable,下面几点在实际开发中是需要注意的:
- 使用线程池去处理多线程工作,这样做的好处是避免频繁的创建和销毁线程,避免了资源的损耗。
- 在多线程要注意并发问题,网上挺多工具可以测试并发,设计线程一般要加锁,不然会出现重复插入数据的问题;
线程池的创建
线程池的创建,这里用的是Spring的线程池,方便直接管理,里面的参数分别核心线程数,最大核心数,存活时间:
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit