springmvc配线程池Executor做多线程并发操作

时间:2022-10-29 18:34:24

加载xml文件

在ApplicationContext.xml文件里面添加
xmlns:task="http://www.springframework.org/schema/task"
xmlns文件并且xsi:schemaLocation中添加
http://www.springframework.org/schema/task 
http://www.springframework.org/schema/task/spring-task.xsd



在spring中配置Executor

在ApplicationContext.xml文件里面添加
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
        <!-- 核心线程数 -->     
        <property name="corePoolSize" value="${task.core_pool_size}" />
        <!-- 最大线程数 -->  
        <property name="maxPoolSize" value="${task.max_pool_size}" />
        <!-- 队列最大长度 -->
        <property name="queueCapacity" value="${task.queue_capacity}" />
        <!-- 线程池维护线程所允许的空闲时间,默认为60s -->
        <property name="keepAliveSeconds" value="${task.keep_alive_seconds}" />
    </bean>
    <!-- 注解式 -->
    <task:annotation-driven />
在dbconfig.properties添加
maxOpenPreparedStatements=20
removeAbandoned=true
removeAbandonedTimeout=1800
logAbandoned=true
这是分别对线程池做配置

添加依赖注入

在所需要的service或者controller类里面添加
@Resource(name = "taskExecutor")
private TaskExecutor taskExecutor;

使用线程池进行并发操作

代码如下
			taskExecutor.execute(new Runnable() {

				@Override
				public void run() {
					// TODO Auto-generated method stub
					try {
                                          //要进行的并发操作
					} catch (Exception e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
				}
			});
			




提示

注意在线程中操作变量时候变量的作用域范围。需要在这个controller或者sevice中声明变量如下

@Controller
public class IndexController {
int studentscount = 0;
@RequestMapping(value = "/index.html")
	public ModelAndView goIndex() {
		logBefore(logger, "列表Center");
		ModelAndView mv = this.getModelAndView();
                taskExecutor.execute(new Runnable() {

				@Override
				public void run() {
					// TODO Auto-generated method stub
					// 得到所有学生人数
					try {
                                          studentscount = coursesService.getStudentCount(pd);
					} catch (Exception e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}

				}
			});
                  mv.addObject("studentscount", studentscount);
                  mv.setViewName("common/index");
                  return mv;
}