要说spring的提供的执行器那就先说说JDK1.5为我们提供的一个类接口吧
java.util.concurrent.Executor
此接口提供一种将任务提交与每个任务将如何运行的机制(包括线程使用的细节、调度等)分离开来的方法。
常见的是,任务是在某个不是调用方线程的线程中执行的。以下执行程序将为每个任务生成一个新线程。
class ThreadPerTaskExecutor implements Executor {
public void execute(Runnable r) {
new Thread(r).start();
}
}
现在来说说spring提供的执行器吧
org.springframework.core.task.TaskExecutor
这个接口基本和java.util.concurrent.Executor拥有一样的execute(Runnable task)方法
TaskExecutor的子类很多
SimpleAsyncTaskExecutor类
这个实现不重用任何线程,或者说它每次调用都启动一个新线程。但是,它还是支持对并发总数设限,当超过线程并发总数限制时,阻塞新的调用,直到有位置被释放。如果你需要真正的池,请继续往下看。
SyncTaskExecutor类
这个实现不会异步执行。相反,每次调用都在发起调用的线程中执行。它的主要用处是在不需要多线程的时候,比如简单的test case。
ConcurrentTaskExecutor类
这个实现是对Java 5 java.util.concurrent.Executor类的包装。有另一个备选, ThreadPoolTaskExecutor类,它暴露了Executor的配置参数作为bean属性。很少需要使用ConcurrentTaskExecutor, 但是如果ThreadPoolTaskExecutor不敷所需,ConcurrentTaskExecutor是另外一个备选。
SimpleThreadPoolTaskExecutor类
这个实现实际上是Quartz的SimpleThreadPool类的子类,它会监听Spring的生命周期回调。当你有线程池,需要在Quartz和非Quartz组件中共用时,这是它的典型用处。
ThreadPoolTaskExecutor类
这个实现只能在Java 5环境中使用,但是却是这个环境中最常用的。它暴露的bean properties可以用来配置一个java.util.concurrent.ThreadPoolExecutor,把它包装到一个TaskExecutor中。如果你需要更加先进的类,比如ScheduledThreadPoolExecutor,我们建议你使用ConcurrentTaskExecutor来替代。
TimerTaskExecutor类
这个实现使用一个TimerTask作为其背后的实现。它和SyncTaskExecutor的不同在于,方法调用是在一个独立的线程中进行的,虽然在那个线程中是同步的。
WorkManagerTaskExecutor类
这个实现使用了CommonJ WorkManager作为其底层实现,是在Spring context中配置CommonJ WorkManager应用的最重要的类。和SimpleThreadPoolTaskExecutor类似,这个类实现了WorkManager接口,因此可以直接作为WorkManager使用。
一个例子:在注册后需要通过javaMail发一封邮件进行确认,发邮件属于重量级操作,如果将其和注册的业务逻辑在一个线程中执行,那么注册这个service就过去庞大,尤其是当使用Hibernate的OpenSessionInView模式时,那么这个connection就太浪费了。于是我们想到通过一个异步的线程池去完成这个发邮件的任务
public class Service{
public void reg(){
doReg();
taskExecutor.execute(new Runnable(){
public void run(){
sendMail();
}
});
}
}
<bean id="taskExecutor" class="org.springframework.scheduing.concuttent.ThreadPoolTaskExecutor"
<property name="corePoolSize" value="10"/>
<property name="maxPoolSize" value="30"/>
</bean>
分享到:
相关推荐
在Spring框架中,自定义命令执行器是一种设计模式,它允许开发者通过一种抽象的方式来调用具体的方法,从而达到业务解耦的目的。这种模式通常应用于希望将业务逻辑与具体实现细节隔离开来,或者在调用实际方法时存在...
Spring提供了TaskExecution和TaskScheduling两个接口,它们分别用于执行一次性任务和定时任务。这两个接口是Spring Task模块的核心,可以帮助我们构建异步和定时任务。 2. **@Scheduled Annotation** 在Java中,...
它提供了模型-视图-控制器架构,分离了业务逻辑、数据处理和用户界面,提高了代码的可测试性和可维护性。 6. **Spring Boot** Spring Boot是为了简化Spring应用的初始搭建以及开发过程而诞生的。它默认配置了许多...
在Java Web开发中,Spring框架提供了强大的定时任务支持,这些定时任务可以被用来执行周期性的操作,例如数据清理、报表生成、系统监控等。本文将详细介绍Spring中的定时器功能,包括基本概念、实现方式以及常见应用...
Spring框架作为一个广泛使用的Java应用开发框架,提供了许多强大的功能,其中之一就是定时任务的支持。在Spring中,我们可以使用Spring的`TaskExecution`和`TaskScheduling`模块来实现定时任务,这些功能可以帮助...
### Spring MVC 执行流程详解 #### 一、概述 Spring MVC 是 Spring 框架中的一个重要组成部分,主要用于...以上就是关于“Spring MVC执行流程”的详细介绍。希望这篇文章能帮助读者更好地理解和运用Spring MVC框架。
总的来说,Spring集成Quartz提供了灵活的定时任务解决方案,但同时需要注意避免配置错误和并发问题,以防止任务被执行多次。通过理解Quartz的工作原理和Spring的定时任务API,我们可以有效地管理定时任务,确保它们...
而拦截器则是Spring框架中的一个重要概念,它允许我们在方法执行前后进行一些额外的操作,比如日志记录、性能监控、事务管理等。在本教程中,我们将深入探讨如何使用CGLIB库来模拟Spring的拦截器功能。 CGLIB(Code...
在Spring框架中集成Quartz库...当Spring应用启动时,Quartz调度器会自动启动并按照预定的计划执行任务。在实际开发中,你可以根据需求调整定时任务的执行周期、并发控制和数据持久化策略,以满足复杂的定时任务需求。
在Spring框架中,线程池的...同步执行器如`SyncTaskExecutor`适用于简单同步任务,而异步执行器如`ThreadPoolTaskExecutor`则适用于需要并行处理任务的情况。通过配置,我们可以调整线程池的参数以优化性能和资源利用。
关于标签“源码”,这可能意味着要深入理解Spring MVC的源代码,以了解其内部如何处理拦截器和JSON响应。而“工具”可能指的是使用一些辅助工具,如IDE的调试功能、HTTP客户端工具(如Postman)等,来帮助开发和测试...
10. **Spring Cloud**:在微服务架构中,Spring Cloud提供了服务发现、配置中心、负载均衡、熔断器等一系列工具,帮助开发者构建云原生应用。 这个"spring类库"的压缩包很可能包含了Spring框架的核心jar文件,以及...
Spring Boot以其简洁的配置和快速的启动能力深受开发者喜爱,而Spring Batch作为Spring框架的一部分,专注于批量处理任务,提供了强大的数据处理能力和事务管理功能。下面我们将深入探讨这个主题。 首先,**Spring ...
总的来说,Spring的AOP拦截器为开发者提供了强大的功能,能够帮助我们编写更加整洁、解耦的代码。无论是简单的日志记录还是复杂的业务逻辑控制,拦截器都能发挥重要作用。在实际开发中,根据项目需求选择合适的拦截...
2. **配置文件**:在Spring的XML配置文件中,需要添加Spring Security的相关配置,例如定义安全拦截器、认证提供者、访问决策策略等。 3. **代码集成**:在业务代码中,可以通过`@Secured`注解来标记需要权限控制的...
在Spring Boot应用中,只需要在主配置类上添加`@EnableScheduling`注解,就能启动定时任务的调度器。例如: ```java import org.springframework.boot.SpringApplication; import org.springframework.boot....
此外,Spring还提供了AOP(面向切面编程)支持,允许开发者定义和执行横切关注点,如日志、事务管理等,从而实现了代码的模块化和职责分离。 在Spring MVC中,Spring提供了一种用于构建Web应用的模型-视图-控制器...
在Spring框架中,拦截器是基于AOP的概念,它提供了在方法执行前后插入自定义逻辑的能力。AOP允许开发者定义“切面”,这些切面可以包含业务逻辑之外的关注点,如日志、事务处理和安全性。Spring AOP通过代理模式实现...
开发者可以利用Spring Batch提供的执行器(JobLauncher)来启动和控制批处理作业的运行。此外,作业的执行策略可以配置为同步执行或是异步执行,以及配置执行监听器来获取作业执行过程中的状态和事件。 知识点四:...
Spring Boot Actuator 执行器运行原理详解 Spring Boot Actuator 执行器是 Spring Boot 框架中的一种功能强大且实用的模块,用于监视和管理 Spring Boot 应用程序。在本文中,我们将详细介绍 Spring Boot Actuator ...