加载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. 判断是否发生url跳转

    url="https://www.baidu.com/" url='http://www.freebuf.com/fevents/133225.html' # 方法一:禁止跳转:a ...

  2. Android笔记(四十一) Android中的数据存储——SQLite(三)select

    SQLite 通过query实现查询,它通过一系列参数来定义查询条件. 各参数说明: query()方法参数 对应sql部分 描述 table from table_name 表名称 colums s ...

  3. keepalived实现nginx反向代理的高可用

    实现keepalived调用脚本进行资源监控 keepalived调用外部的辅助脚本进行资源监控,并根据监控的结果状态能实现优先动态调整 vrrp_script:自定义资源监控脚本,vrrp实例根据脚 ...

  4. PAT1125

    总体思路 这道题就是一道贪心题. 对我来说,这道题的关键在于他在说什么(黑人问号???),一开始读了几遍都不知道在讲什么,怎么一根绳子对折后就和另一根套上了? 描述上面确实让人比较迷糊,配图也不是很明 ...

  5. Java8 Stream 流使用场景和常用操作

    JAVA8内置的函数式编程接口应用场景和方式 pojo类对象和默认创建list的方法 import lombok.AllArgsConstructor; import lombok.Data; imp ...

  6. linux一些配置

    ifconfig 查询.设置网卡和ip参数 ifup ens33 启动网卡 ifdown 关闭网卡 systemctl restart/start/stop network 重启.开始.关闭 网络服务 ...

  7. 3.XPath

    使用XPath可以在不遍历xml文档的情况下选择具体节点. 转自https://www.cnblogs.com/vaevvaev/p/6928201.html XPath可以快速定位到Xml中的节点或 ...

  8. ArcMap 制图出图

    在这里用的数据是:台湾2018年6月人口统计数据来做展示数据. ArcMap 里面主要用到的是:符号系统使用.布局视图等 一.属性中设置元素符号 ArcMap 初次加载数据,默认的是“单一符号”,就是 ...

  9. 《BUG创造队》作业9:【Beta】冲刺 Scrum meeting 1

    项目 内容 这个作业属于哪个课程 2016级软件工程 这个作业的要求在哪里 实验十三 团队作业9:Beta冲刺与团队项目验收 团队名称 BUG创造队 作业学习目标 (1)掌握软件黑盒测试技术:(2)学 ...

  10. zentaopms - 禅道项目管理系统部署

    概述 禅道是开源免费的项目管理软件 使用步骤 管理员 添加组织 添加用户 用户权限管理(通过分组确定权限) 产品经理 添加产品 添加模块(隶属于产品) 添加需求(隶属于模块) 添加计划(计划形成“路线 ...