您的位置:首页 > 数据库 > MySQL

j2EE 利用Quartz任务调度 进行 mysql 数据库自动备份

2011-10-30 23:02 761 查看
我们的网站,每次数据库备份都得手动备份,有的时候还会忘记,没出问题还好,要是有问题那就麻烦啦,所以干脆自己写个备份程序吧

使用的quartz的任务调度功能,当然也顺便把它整到spring里面去了,把源码拿来与大家分享:

1. DataBackupImp.java

package cn.hunqiu.data;

import java.io.IOException;
import java.util.Date;

public class DataBackupImp
{
private StringBuffer copyString = new StringBuffer("mysqldump ");//利用mysql的mysqldump 工具,前提是你要吧mysql 的bin目录加入你的系统path
private String lastStr = null;
private String user = "-u****";//***为用户名
private String pwd = "-p***";//***为密码
private String db = "****";//要备份的数据库
private String path = System.getProperty("testhunqiu.root");//你的网站程序的映射地址
private String sqlFileName = null;
@SuppressWarnings("deprecation")
public DataBackupImp()
{
copyString.append(user).append(" ").append(pwd).append(" ").append(db).append(" >");
sqlFileName = path + "WEB-INF\\datacopy\\"+db +"_"+new Date().toLocaleString().replaceAll(":","-")+".sql";
lastStr = copyString + sqlFileName;
}
@SuppressWarnings("deprecation")
public DataBackupImp(String user,String pwd,String db)
{
copyString.append(user).append(" ").append(pwd).append(" ").append(db).append(" >");
sqlFileName = path + "WEB-INF\\datacopy\\"+db +"_"+new Date().toLocaleString().replaceAll(":","-")+".sql";
lastStr = copyString + sqlFileName;
}
@SuppressWarnings("deprecation")
public void dataCopy() throws IOException
{
String temp = ("cmd /c "+lastStr).replaceAll("//","\"\\\\\"").replaceAll("\\\\","\"\\\\\"");//把\换成windows的地址分隔符/
temp=temp.replaceFirst("\"","");
Runtime.getRuntime().exec(temp);
System.out.println("已经完成计算 数据库文件备份----------");
System.out.println("文件路径:"+sqlFileName+" 备份时间"+new Date().toLocaleString());
}
}


2.applicationContextQuartz.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/context/mvc" xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd http://www.springframework.org/schema/context/mvc http://www.springframework.org/schema/context/mvc/spring-mvc-3.0.xsd"> 
<!-- Quartz任务调度 -->

<!--
数据库备份
-->
<bean id ="datacopyQuartz" class="cn.hunqiu.data.DataBackupImp"/>

<bean id="hqDatacopyQuartz" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="datacopyQuartz"/>
</property>
<property name="targetMethod">
<value>dataCopy</value>
</property>
</bean>

<bean id="datacopyQuartzTime" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail">
<ref bean="hqDatacopyQuartz"/>
</property>
<property name="cronExpression">
<!-- <value>0 0 23 * * ?</value> --><!-- 每天23点 -->
<value>0 0 * * * ?</value><!-- 每小时 -->
</property>
</bean>

<bean id="startQuartz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="datacopyQuartzTime"/>
</list>
</property>
</bean>

</beans>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: