定时器-spring的配置文件xml实现方式

1. 在spring配置文件中创建作用类的 bean,因为需要把作用的对象交Spring来管理,class是作用类的路径,id一般为创建的bean的命名,后面步骤也一样

 <bean id="TNJob" class="com.ridge.controller.ticket.TuNiuDataController"></bean>

 

2. 在spring配置文件中创建bean,指定定时器作用在那个类的那个方法,"targetObject" 作用类(这里的作用类是 TNJob 在第一步已经把作用类命名了),"targetMethod" 作用方法(这里的作用类方法是 sendMsg

<bean id="TNJobDetail"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="TNJob"></property>
<property name="targetMethod" value="sendMsg"></property>
</bean>

 

3. 在spring配置文件中创建bean,创建你的triggers,"jobDetail" 指第2步创建的bean(已经命名为TNJobDetail)

<bean id="TNTrigger"
class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
<!-- 注入jobDetail -->
<property name="jobDetail" ref="TNJobDetail">
</property>
<!-- 通过表达式指定配置任务 触发时间:秒 分 时 日 月 年 下面的时间指:每月5号触发定时器 -->
<property name="cronExpression" value="0 0 0 5 * ?" />
</bean>

 

4. 在spring配置文件中创建bean,创建schedule,"TNTrigger" 为第3步创建的bean

<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="TNTrigger" />
</list>
</property>
</bean>

转载于:https://www.cnblogs.com/wisdom-windy/p/10180420.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: <configuration> <springProfile name="cron"> <timestamp key="byCron" datePattern="yyyy-MM-dd HH:mm:ss.SSS"/> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <cronTriggeringPolicy class="ch.qos.logback.core.rolling.CronTriggeringPolicy"> <cronExpression>0 0 */2 * * ?</cronExpression> </cronTriggeringPolicy> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logs/app.%d{yyyy-MM-dd_HHmmss}.%i.log.gz</fileNamePattern> </rollingPolicy> </springProfile> </configuration> ### 回答2: logback-spring.xml是一个用于配置Logback日志框架的Spring Boot配置文件。其中,可以使用cron表达式来配置定时任务。 以下是一个例子,展示了如何在logback-spring.xml配置一个cron定时器: ```xml <?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 定义一个appender,将日志输出到控制台 --> <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>${CONSOLE_LOG_PATTERN}</pattern> </encoder> </appender> <!-- 定义一个logger,将日志记录到指定的文件 --> <logger name="com.example" level="DEBUG" additivity="false"> <appender-ref ref="FILE"/> </logger> <!-- 定义一个定时器,每分钟执行一次 --> <springProperty name="cron.expression" source="cron.expression" defaultValue="0 * * * * ?"/> <!-- 定义一个定时任务 --> <appender name="CRON_JOB" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${LOG_HOME}/cronjob.log</file> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>${LOG_HOME}/cronjob.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <encoder> <pattern>${FILE_LOG_PATTERN}</pattern> </encoder> </appender> <!-- 设置定时器的触发条件 --> <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <MaxFileSize>10MB</MaxFileSize> </triggeringPolicy> <!-- 将定时器应用到指定的logger中 --> <logger name="CRON_JOB_LOGGER" level="INFO" additivity="false"> <appender-ref ref="CRON_JOB"/> </logger> <root level="INFO"> <appender-ref ref="CONSOLE"/> </root> </configuration> ``` 在这个示例中,配置文件定义了一个名为CRON_JOB的定时器,其定时任务将每分钟执行一次。定时任务将日志输出到名为cronjob.log的文件,并根据日期和时间对文件进行滚动和归档。此外,还定义了一个名为CRON_JOB_LOGGER的logger,它将定时任务的日志记录到CRON_JOB appender。 请注意,上述配置文件中使用了一些占位符,如${CONSOLE_LOG_PATTERN}、${FILE_LOG_PATTERN}和${LOG_HOME}。这些占位符的值可以在其他地方进行配置,以便实现更高度的灵活性。 ### 回答3: 在logback-spring.xml配置cron定时器需要使用Spring的扩展配置,具体配置如下: <?xml version="1.0" encoding="UTF-8"?> <configuration xmlns="http://ch.qos.logback/xml/ns/logback" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://ch.qos.logback/xml/ns/logback http://ch.qos.logback/xml/ns/logback/logback.xsd"> <!-- 定义cron表达式 --> <springProperty scope="context" name="cron.expression" source="cron.expression"/> <!-- 定义异步日志appender --> <appender name="ASYNC_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>logs/app.log</file> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> <level>info</level> </filter> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logs/app.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <!-- 触发归档的最小文件大小 --> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> <!-- 保留7天内的日志文件 --> <maxHistory>7</maxHistory> </rollingPolicy> </appender> <!-- 定义定时器 --> <springProperty scope="context" name="cron.task" source="cron.task"/> <appender name="CRON" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>logs/cron.log</file> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> <level>info</level> </filter> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logs/cron.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern> </rollingPolicy> <!-- 定义cron定时任务 --> <triggeringPolicy class="ch.qos.logback.core.rolling.CronTriggeringPolicy"> <cronExpression>${cron.task}</cronExpression> </triggeringPolicy> </appender> <root level="info"> <appender-ref ref="ASYNC_FILE"/> <appender-ref ref="CRON"/> </root> </configuration> 上述配置通过两个appender实现异步写入日志文件和根据cron表达式定时归档日志文件。其中,${cron.expression}和${cron.task}是定义的Spring属性,可以在外部配置文件Spring配置中进行配置,并在logback-spring.xml中引用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值