加载xml文件

在ApplicationContext.xml文件里面添加
  1. xmlns:task="http://www.springframework.org/schema/task"
xmlns:task="http://www.springframework.org/schema/task"

xmlns文件并且xsi:schemaLocation中添加

  1. http://www.springframework.org/schema/task
http://www.springframework.org/schema/task 
  1. http://www.springframework.org/schema/task/spring-task.xsd
http://www.springframework.org/schema/task/spring-task.xsd

在spring中配置Executor

在ApplicationContext.xml文件里面添加

  1. <bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
  2. <!-- 核心线程数 -->
  3. <property name="corePoolSize" value="${task.core_pool_size}" />
  4. <!-- 最大线程数 -->
  5. <property name="maxPoolSize" value="${task.max_pool_size}" />
  6. <!-- 队列最大长度 -->
  7. <property name="queueCapacity" value="${task.queue_capacity}" />
  8. <!-- 线程池维护线程所允许的空闲时间,默认为60s -->
  9. <property name="keepAliveSeconds" value="${task.keep_alive_seconds}" />
  10. </bean>
  11. <!-- 注解式 -->
  12. <task:annotation-driven />
  1.  
    <bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
  2.  
    <!-- 核心线程数 -->
  3.  
    <property name="corePoolSize" value="${task.core_pool_size}" />
  4.  
    <!-- 最大线程数 -->
  5.  
    <property name="maxPoolSize" value="${task.max_pool_size}" />
  6.  
    <!-- 队列最大长度 -->
  7.  
    <property name="queueCapacity" value="${task.queue_capacity}" />
  8.  
    <!-- 线程池维护线程所允许的空闲时间,默认为60s -->
  9.  
    <property name="keepAliveSeconds" value="${task.keep_alive_seconds}" />
  10.  
    </bean>
  11.  
    <!-- 注解式 -->
  12.  
    <task:annotation-driven />

在dbconfig.properties添加

  1. maxOpenPreparedStatements=20
  2. removeAbandoned=true
  3. removeAbandonedTimeout=1800
  4. logAbandoned=true
  1.  
    maxOpenPreparedStatements=20
  2.  
    removeAbandoned=true
  3.  
    removeAbandonedTimeout=1800
  4.  
    logAbandoned=true

这是分别对线程池做配置

 

添加依赖注入

在所需要的service或者controller类里面添加

  1. @Resource(name = "taskExecutor")
  2. private TaskExecutor taskExecutor;
  1.  
    @Resource(name = "taskExecutor")
  2.  
    private TaskExecutor taskExecutor;

使用线程池进行并发操作

代码如下

  1. taskExecutor.execute(new Runnable() {
  2. @Override
  3. public void run() {
  4. // TODO Auto-generated method stub
  5. try {
  6. //要进行的并发操作
  7. } catch (Exception e) {
  8. // TODO Auto-generated catch block
  9. e.printStackTrace();
  10. }
  11. }
  12. });
  1.  
    taskExecutor.execute(new Runnable() {
  2.  
     
  3.  
    @Override
  4.  
    public void run() {
  5.  
    // TODO Auto-generated method stub
  6.  
    try {
  7.  
    //要进行的并发操作
  8.  
    } catch (Exception e) {
  9.  
    // TODO Auto-generated catch block
  10.  
    e.printStackTrace();
  11.  
    }
  12.  
    }
  13.  
    });

 

提示

注意在线程中操作变量时候变量的作用域范围。需要在这个controller或者sevice中声明变量如下
  1. @Controller
  2. public class IndexController {
  3. int studentscount = 0;
  4. @RequestMapping(value = "/index.html")
  5. public ModelAndView goIndex() {
  6. logBefore(logger, "列表Center");
  7. ModelAndView mv = this.getModelAndView();
  8. taskExecutor.execute(new Runnable() {
  9. @Override
  10. public void run() {
  11. // TODO Auto-generated method stub
  12. // 得到所有学生人数
  13. try {
  14. studentscount = coursesService.getStudentCount(pd);
  15. } catch (Exception e) {
  16. // TODO Auto-generated catch block
  17. e.printStackTrace();
  18. }
  19. }
  20. });
  21. mv.addObject("studentscount", studentscount);
  22. mv.setViewName("common/index");
  23. return mv;
    1.  
      @Controller
    2.  
      public class IndexController {
    3.  
      int studentscount = 0;
    4.  
      @RequestMapping(value = "/index.html")
    5.  
      public ModelAndView goIndex() {
    6.  
      logBefore(logger, "列表Center");
    7.  
      ModelAndView mv = this.getModelAndView();
    8.  
      taskExecutor.execute(new Runnable() {
    9.  
       
    10.  
      @Override
    11.  
      public void run() {
    12.  
      // TODO Auto-generated method stub
    13.  
      // 得到所有学生人数
    14.  
      try {
    15.  
      studentscount = coursesService.getStudentCount(pd);
    16.  
      } catch (Exception e) {
    17.  
      // TODO Auto-generated catch block
    18.  
      e.printStackTrace();
    19.  
      }
    20.  
       
    21.  
      }
    22.  
      });
    23.  
      mv.addObject("studentscount", studentscount);
    24.  
      mv.setViewName("common/index");
    25.  
      return mv;
    26.  

spring线程池的应用的更多相关文章

  1. Spring线程池开发实战

    Spring线程池开发实战 作者:chszs,转载需注明. 作者博客主页:http://blog.csdn.net/chszs 本文提供了三个Spring多线程开发的例子,由浅入深,由于例子一目了然, ...

  2. Spring线程池配置模板设计(基于Springboot)

    目录 线程池配置模板 基础的注解解释 常用配置参数 配置类设计 线程池使用 ThreadPoolTaskExecutor源码 线程池配置模板 springboot给我们提供了一个线程池的实现,它的底层 ...

  3. Spring线程池ThreadPoolTaskExecutor配置及详情

    Spring线程池ThreadPoolTaskExecutor配置及详情 1. ThreadPoolTaskExecutor配置 <!-- spring thread pool executor ...

  4. 分享知识-快乐自己:Spring线程池配置

    Spring通过ThreadPoolTaskExecutor实现线程池技术,它是使用jdk中的Java.util.concurrent.ThreadPoolExecutor进行实现. Spring 配 ...

  5. Spring线程池由浅入深的3个示例

    作者博客主页:http://blog.csdn.net/chszs 本文提供了三个Spring多线程开发的例子,由浅入深,由于例子一目了然,所以并未做过多的解释.诸位一看便知. 前提条件: 1)在Ec ...

  6. 【SSM Spring 线程池 OJ】 使用Spring线程池ThreadPoolTaskExecutor

    最近做的Online Judge项目,在本地判题的实现过程中,遇到了一些问题,包括多线程,http通信等等.现在完整记录如下: OJ有一个业务是: 用户在前端敲好代码,按下提交按钮发送一个判题请求给后 ...

  7. spring线程池的同步和异步(1)

    spring线程池(同步.异步) 一.spring异步线程池类图 二.简单介绍 2.1. TaskExecutor---Spring异步线程池的接口类,其实质是java.util.concurrent ...

  8. 007-多线程-JUC线程池-Spring线程池配置、池子如何配置参数

    一.概述 Spring通过ThreadPoolTaskExecutor实现线程池技术,它是使用jdk中的Java.util.concurrent.ThreadPoolExecutor进行实现. 1.1 ...

  9. JDK线程池和Spring线程池的使用

    JDK线程池和Spring线程池实例,异步调用,可以直接使用 (1)JDK线程池的使用,此处采用单例的方式提供,见示例: public class ThreadPoolUtil { private s ...

  10. spring线程池配置

    源自:http://zjriso.iteye.com/blog/771706 1.了解 TaskExecutor接口 Spring的TaskExecutor接口等同于java.util.concurr ...

随机推荐

  1. (五)react-native开发系列之Android原生交互

    react-native可以做web与原生的交互,这是使用react-native开发项目的主要目的之一,也是主要优势,用rn而不用原生交互则毫无价值,这篇文章用来记录在项目中rn的原生交互使用过程. ...

  2. IP详解

    现在的IP网络使用32位地址,以点分十进制表示,如172.16.0.0.地址格式为:IP地址=网络地址+主机地址 或 IP地址=主机地址+子网地址+主机地址. IP地址类型  最初设计互联网络时,为了 ...

  3. 【转】java.io.Closeable接口

    说到java.io.Closeable接口就避不开java.lang.AutoCloseable接口,因为在java版本7.0时引入了java.lang.AutoCloseable接口,同时java. ...

  4. WebSocket使用中Stomp Client连接报ERROR CODE 200的解决办法

    [转] https://www.cnblogs.com/chrischeng/p/10237523.html 最近在做一个WebSocket项目,后台使用了Stomp协议的WebSocketConfi ...

  5. 云计算/云存储---Ceph和Openstack的cinder模块对接方法

    1.创建存储池 在ceph节点中执行如下语句. #ceph osd pool create volumes 2.配置 OPENSTACK 的 CEPH 客户端 在ceph节点两次执行如下语句,两次{y ...

  6. 《奋斗吧!菜鸟》 第九次作业:Beta冲刺 Scrum meeting 3

    项目 内容 这个作业属于哪个课程 任课教师链接 作业要求 https://www.cnblogs.com/nwnu-daizh/p/11012922.html 团队名称 奋斗吧!菜鸟 作业学习目标 掌 ...

  7. elementUI 控制 DatePicker组件 不能选择 设定的日期

    <el-date-picker v-model="date" type="daterange" range-separator="至" ...

  8. 【贪心】Communication System POJ 1018

    题目链接:http://poj.org/problem?id=1018 题目大意:有n种通讯设备,每种有mi个制造商,bi.pi分别是带宽和价格.在每种设备中选一个制造商让最小带宽B与总价格P的比值B ...

  9. HTML中的标签列表

    1 :基础标签 <!DOCTYPE> :定义文档类型 <title>:定义文档标题 <h1>to<h2>定义HTML标题,其中h1到h6表示字体大小依次 ...

  10. Acwing P288 休息时间 题解

    Analysis 首先假设一天的第N小时与后一天的第一个小时不相连, 这种情况下DP转移比较好想 dp[i][j][0/1]dp[i][j][0/1]表示 考虑一天的前i个小时,已经休息了j小时,且第 ...