Spring整合Quartz定时备份数据库

Quartz调度器为调度工作提供了更很好的支持。和Java定时器一样,可以使用Quartz每隔一段时间或在特定的时间点来执行一个任务,Spring作为一个优秀的框架,也提供了对Quartz的整合,下面以我以前做过的项目为例,使用spring的Quartz来定时备份数据库。

数据库的相关信息配置在confin.properties文件中,配置如下:
user=root
password=111
databasePath=D:/upload/backDatabase/
database=erp


使用spring写了一个简单读取properties文件的工具类:
部分核心代码如下:
/**
* 读取properties文件的工具类
* @since 2011-10-5
* @author Jenhui
*
*/
public class PropertiesReader {

private String fileName;

public PropertiesReader(String fileName){
this.fileName=fileName;
}

public String readProperty(String name){
Resource res=new ClassPathResource(fileName);
Properties p=new Properties();
try{
p.load(res.getInputStream());
//System.out.println(p.getProperty(name));
}catch(Exception e){
e.printStackTrace();
}

return p.getProperty(name);

}

}


备份mysql数据库的java代码:
package com.lrh.utils;

import java.io.*;
import java.text.DateFormat;
import java.util.Calendar;
import java.util.Date;

public class BackMySql {

public static void exportDataBase(){

Date now = new Date();
DateFormat df= DateFormat.getDateTimeInstance();
String dbName = df.format(now)+".sql";
dbName=dbName.replaceAll(":", "_");

PropertiesReader pr=new PropertiesReader("config.properties");
String user = pr.readProperty("user");
String password = pr.readProperty("password");
String database = pr.readProperty("database");
String filepath = pr.readProperty("databasePath")+dbName;
//System.out.println(filepath);

String stmt1 = "mysqldump -u "+user+" -p"+password+" --set-charset=utf8 "+database;
try{
Process process = Runtime.getRuntime().exec(stmt1);
InputStream in = process.getInputStream();
InputStreamReader xx = new InputStreamReader(in, "utf8");
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
BufferedReader br = new BufferedReader(xx);
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
FileOutputStream fout = new FileOutputStream(filepath);
OutputStreamWriter writer = new OutputStreamWriter(fout, "utf8");
writer.write(outStr);
writer.flush();
in.close();
xx.close();
br.close();
writer.close();
fout.close();
}catch(IOException e){
e.printStackTrace();
}

}

}

定时调度类的核心代码:
public class TriggerImpl {

public void BackMySQL(){
BackMySql.exportDataBase();
}
}

Spring的配置:
 <bean id="trigger" class="com.lrh.trigger.TriggerImpl">
</bean>
<!-- 定义调用对象和调用对象的方法 -->
<bean id="projobtask2" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="trigger"/>
</property>
<property name="targetMethod">
<value>BackMySQL</value>
</property>
</bean>

<!--定义触发时间 -->
<bean id="timecard2" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail">
<ref bean="projobtask2"/>
</property>
<!-- cron表达式 -->
<property name="cronExpression">
<!-- 每隔30分钟备份一次-->
<value>0 0/30 * * * ?</value>
</property>
</bean>

<!-- 总管理类 如果将lazy-init='false'那么容器启动就会执行调度程序 -->
<bean id="startQuertz2" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="timecard2"/>
</list>
</property>
</bean>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值