`
ufopw
  • 浏览: 163051 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

spring 任务

    博客分类:
  • Java
阅读更多
<!-- 任务从此处开始加载 -->     
<bean id="notifySpringScheduledExecutorFactoryBean" class="org.springframework.scheduling.concurrent.ScheduledExecutorFactoryBean">     
    <property name="scheduledExecutorTasks">     
        <list>     
            <ref bean="notifySpringScheduledExecutorTask" />     
        </list>     
    </property>     
</bean>     
<!-- 待加入Spring Schedual进行调度的task列表 -->     
<bean id="notifySpringScheduledExecutorTask" class="org.springframework.scheduling.concurrent.ScheduledExecutorTask">     
    <property name="runnable" ref="notifyScheduledMainExecutor" />     
    <!-- 初次执行任务delay时间,单位为ms,默认值为0,代表首次加载任务时立即执行;比如1min -->     
    <property name="delay" value="60000" />     
    <!-- 间隔时间,单位为ms,默认值为0,代表任务只执行一次;比如2min -->     
    <property name="period" value="120000" />     
    <!-- 是否采用fixedRate方式进行任务调度,默认为false,即采用fixedDelay方式 -->     
    <!-- fixedRate:定时间隔执行,不管上次任务是否已执行完毕;fixedDelay:每次任务执行完毕之后delay固定的时间 -->     
    <property name="fixedRate" value="true" />     
</bean>     
<!-- 任务调度主线程 -->     
<bean id="notifyScheduledMainExecutor" class="com.alisoft.aep.notify.schedual.NotifyScheduledMainExecutor">     
    <!-- 针对Notify服务端的Service,用于更新Notify重试信息等 -->     
    <property name="notifyServerService" ref="notifyServerService" />     
    <!-- notify.notifyId缓存策略实现类,可自行扩展 -->     
    <property name="notifyIdCacheStrategy" ref="defaultNotifyIdCacheStrategy" />     
    <!-- notify.load_balance_num字段值生成、以及调度时where条件中取值的策略实现类,可自行扩展 -->     
    <!-- 当有多台notify服务器时才有用,用于平衡各台server间的压力;一般不用配置 -->     
    <!-- <property name="loadBalanceNumStrategy" ref="alternateLoadBalanceNumStrategy" /> -->     
    <!-- notify.handler字段值在调度时where条件中取值的策略实现类,可自行扩展 -->     
    <!-- 当有多台notify服务器时才有用,用于表明某台server可执行哪些handler;一般不用配置 -->     
    <!-- <property name="notifyHandlerStrategy" ref="defaultNotifyHandlerStrategy" /> -->     
    <!-- 当有多台notify服务器时才有用,用于设置某台server调度时每次读取的Notify最大数,用于覆盖maxNum;一般不用配置 -->     
    <!-- <property name="notifyMaxNumPerJobStrategy" ref="defaultNotifyMaxNumPerJobStrategy" /> -->     
    <!-- 用于并发的线程池 -->     
    <property name="notifyTaskExecutor" ref="notifyTaskExecutor" />     
    <!-- 每次调度读取的Notify最大记录数,默认为1000 -->     
    <property name="maxNum" value="1000" />     
    <property name="notifyDao" ref="notifyDao" />     
</bean>     
              
<!-- 异步线程池 -->     
<bean id="notifyTaskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">     
    <!-- 核心线程数,默认为1 -->     
    <property name="corePoolSize" value="10" />     
    <!-- 最大线程数,默认为Integer.MAX_VALUE -->     
    <property name="maxPoolSize" value="50" />     
    <!-- 队列最大长度,一般需要设置值>=notifyScheduledMainExecutor.maxNum;默认为Integer.MAX_VALUE -->     
    <property name="queueCapacity" value="1000" />     
    <!-- 线程池维护线程所允许的空闲时间,默认为60s -->     
    <property name="keepAliveSeconds" value="300" />     
    <!-- 线程池对拒绝任务(无线程可用)的处理策略,目前只支持AbortPolicy、CallerRunsPolicy;默认为后者 -->     
    <property name="rejectedExecutionHandler">     
        <!-- AbortPolicy:直接抛出java.util.concurrent.RejectedExecutionException异常 -->     
        <!-- CallerRunsPolicy:主线程直接执行该任务,执行完之后尝试添加下一个任务到线程池中,可以有效降低向线程池内添加任务的速度 -->     
        <!-- DiscardOldestPolicy:抛弃旧的任务、暂不支持;会导致被丢弃的任务无法再次被执行 -->     
        <!-- DiscardPolicy:抛弃当前任务、暂不支持;会导致被丢弃的任务无法再次被执行 -->     
        <bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />     
    </property>     
</bean>     
<bean id="notifyServerService" class="com.alisoft.aep.notify.service.impl.NotifyServerServiceImpl">     
    <!-- 针对任务执行失败后Notify如何重试的策略实现类,可自行扩展 -->     
    <property name="notifyRetryStrategy" ref="defaultNotifyRetryStrategy" />     
    <!-- 针对任务执行失败后异常处理策略实现类,可自行扩展 -->     
    <!-- 默认不对异常进行补救,具体handler实现类中若返回NULL或抛出异常,则均按异常处理,直接将Notify记录迁移到历史表中,不进行重试; -->     
    <!-- <property name="notifyHandlerExceptionStrategy" ref="defaultNotifyHandlerExceptionStrategy" /> -->     
    <!-- 描述见notifyScheduledMainExecutor -->     
    <property name="notifyIdCacheStrategy" ref="defaultNotifyIdCacheStrategy" />     
    <!-- 事务模板,需保证能够找到对应的bean -->     
    <property name="transactionTemplate" ref="transactionTemplate" />     
    <property name="notifyDao" ref="notifyDao" />     
</bean>     

 
 
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sfdev/archive/2009/04/08/4056114.aspx 
分享到:
评论

相关推荐

    spring 任务调度实现代码例子

    下面将详细解释Spring任务调度的关键概念和实现方法。 1. **Spring Task模块** Spring Task是Spring框架内置的任务调度模块,它提供了简单的定时任务执行能力。通过使用Spring Task,我们可以轻松地在应用中添加...

    spring 任务调度

    通过深入学习Spring任务调度,开发者可以有效地管理和执行各种定时任务,提升系统的自动化水平。在实际项目中,可以根据需求的复杂程度选择使用Spring Task或是集成Quartz。同时,理解源码有助于我们更高效地利用...

    spring任务调度实例

    总的来说,Spring任务调度实例提供了实践Quartz和Timer的机会,这对于学习和掌握Spring框架的高级特性和任务调度机制非常有价值。通过学习这个实例,开发者不仅可以提升自己的技能,还能了解到如何在实际项目中选择...

    Spring任务调度demo

    本篇文章将深入探讨Spring任务调度的实现方法,以及如何利用Quartz库来增强任务管理能力。 首先,让我们理解Spring的任务调度。Spring通过`@Scheduled`注解提供了一种简单而强大的方式来执行定时任务。这个注解可以...

    Spring任务调度配置及说明(spring+quartz)

    《Spring任务调度配置详解:Spring+Quartz的整合应用》 在Java开发中,任务调度是不可或缺的一部分,Spring框架提供了与Quartz集成的能力,使得我们可以方便地管理和执行定时任务。本文将详细介绍如何通过Spring和...

    spring任务定制-总结

    Spring 任务调度是Spring框架中的一个强大特性,它允许开发者定义和管理计划任务,以便在特定的时间点自动执行。在本例中,我们看到的是如何使用Spring与Quartz库集成来实现任务调度。 1. **Quartz库**:Quartz是...

    spring任务调度(Quartz )

    Spring中的任务调度是实现应用程序自动化运行任务的重要工具,而Quartz是Java领域广泛使用的开源任务调度框架。在本文中,我们将深入探讨如何在Spring中集成Quartz进行任务调度,并通过一个简单的示例来理解其工作...

    spring任务调度器

    java spring任务调度器

    Spring 任务调度

    【Spring 任务调度】是Spring框架中用于自动化执行任务的功能,它允许开发者安排任务在特定时间或间隔执行,无需用户交互。任务调度在许多场景下都非常有用,比如定期备份数据库、执行系统统计、检查新邮件等。 1. ...

    20190821_Spring任务定时(任务调度).md

    Spring 定时器 任务调度 怎么在项目中写定时任务 怎么配置一些环境

    Spring实现任务调度

    Spring框架提供了强大的任务调度能力,使得开发者能够轻松地在Java环境中实现这一功能。本篇将深入探讨如何利用Spring进行任务调度,并结合代码演示和Quartz库的使用来丰富这一主题。 首先,Spring提供了两种主要的...

    Spring实现任务调度.rar

    Spring框架提供了强大的任务调度能力,使得开发者能够轻松地集成和管理定时任务。本资料“Spring实现任务调度”将深入探讨如何在Spring中设置和管理定时任务。 首先,我们需要理解Spring中的任务调度机制。Spring...

    maven spring 任务调度实列

    Spring框架提供了一个强大的任务调度模块——Spring Task,也被称为Spring Batch,它支持基于时间的任务调度和基于事件的任务触发。 首先,我们需要在`pom.xml`文件中添加Spring相关的依赖。这通常包括`spring-...

    Spring任务调度

    Spring任务调度ppt,讲的很细和值得看一下。

    spring任务task配置

    springtask配置,大家一起参考学习下,分享下。Java方面

    Spring整合任务调度框架Quartz

    Spring 整合任务调度框架 Quartz 在软件开发中,任务调度框架是非常重要的一部分,它可以帮助开发者更好地管理和执行各种任务。在 Java 领域中,Quartz 是一个非常流行的任务调度框架,而 Spring 是一个非常流行的 ...

    Spring_任务调试源码

    通过分析和学习这些源码,你可以深入了解Spring任务调度的工作原理,掌握如何在实际项目中配置和使用。同时,结合Struts2和Hibernate,可以学习到如何构建一个完整的MVC架构的企业级应用,提高你的开发技能和对整个...

    Spring任务执行和调度

    【Spring任务执行和调度】是Spring框架中处理异步任务和定时任务的核心机制。Spring提供了两种主要的接口:TaskExecutor和TaskScheduler,分别用于异步任务执行和定时任务调度。 **1. TaskExecutor** TaskExecutor...

Global site tag (gtag.js) - Google Analytics