• 实际工程Quartz与Spring设计与实现一体化的热部署



    1.需求说明


    主要负责项目任务调度。使用Quartz。以Spring为辅助。

    如今有这样一个需求:我们不知道管理员想设定过多厂时间运行主任务,须要在配置文件定义。在配置好后须要马上运行。实现热部署。



    2.设计


    在主调度加一个方法,此方法先检測配置文件是否更改。若更改则将调度时间又一次设置,又一次启用调度任务


    3.实现


    在PropertiesUtil定义一一个初始时间,改时间在这个类初始化之前运行。也就是在静态代码块运行,代码例如以下:
    private static long curModifiedTime;
    	static {
    		try {
    			curModifiedTime = new File(filePath).lastModified();
    			System.out.println("当前文件改动时间为 " +curModifiedTime);
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    	
    	}

    此时获取到文件本来的时间

    写一个方法来推断配置文件是否改动:
    public static boolean isModifiedValue()
      {
      	boolean flag = false;
      	long lastModifiedTime = new File(filePath).lastModified();
      	if(lastModifiedTime > curModifiedTime) {
      		curModifiedTime= lastModifiedTime;
      		flag = true;
      	}
      	return flag;
      }

    读取文件最后改动地址。若大于初始时间。则将最后改动时间赋给初始时间
    public boolean reSetTaskSchedulerzIntervalTime(){
    		boolean flag = false;
    		//监听到配置文件改动
    		if(PropertiesUtil.isModifiedValue()) {
    			long time = 0L;
    			try {
    				time = Integer.parseInt(PropertiesUtil.readValue(TaskSchedulerzIntervalTime));
    				simpleTrigger.setRepeatInterval(time);
    				Scheduler scheduler = quartzScheduler.getScheduler();
    				String jobName = simpleTrigger.getName();
    				String group = simpleTrigger.getGroup();
    				try {
    					scheduler.pauseJob(jobName, group);
    					scheduler.unscheduleJob(jobName,group);
    					scheduler.scheduleJob(simpleTrigger);
    					scheduler.resumeJob(jobName, group);
    					flag = true;
    				} catch (SchedulerException e1) {
    					e1.printStackTrace();
    				}
    			} catch (NumberFormatException e) {
    				System.out.println("定时任务非数字!

    "); e.printStackTrace(); } } return flag; }


    当中,quartzScheduler和simpleTrigger是注入进去的,在Spring中整合Quartz时已经定义好,配置文件例如以下
    <bean name="quartzScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
    		<property name="triggers">
    			<list>
    				<ref bean="simpleTrigger" />
    			</list>
    		</property>
    		<property name="configLocation" value="classpath:quartz.properties" />
    	</bean>
    	<bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
    		<property name="jobDetail">
    			<ref bean="jobDetail" />
    		</property>
    		<property name="startDelay">
    			<value>0</value>
    		</property>
    		<property name="repeatInterval" value="${taskSchedulerzIntervalTime}" />
    	</bean>
    
    
    	<bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    		<property name="targetObject" ref="taskScheduler" />
    		<property name="targetMethod" value="run" />
    	</bean>

    之前的调度时间是在里面写死的。如今是通过配置文件来读取。例如以下

    <context:property-placeholder location="classpath:config.properties,classpath:jdbc.properties" />

    測试例如以下



  • 相关阅读:
    微信公众号接口配置
    OFBIZ:启动之ContainerLoader
    OFBIZ:启动之StartupLoader
    Capture a Screen Shot
    在 Windows 上安装Rabbit MQ 指南
    Quartz.NET管理周期性任务
    使用Topshelf创建Windows服务
    Redirecting Console.WriteLine() to Textbox
    Greenplum 备忘
    CockroachDB 备忘
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/5046414.html
Copyright © 2020-2023  润新知