配置文件中的信息
sqlurl=C://Program Files (x86)//MySQL//MySQL Server 5.0//bin//mysqldump -h localhost -uroot -pwjg user
path=F:/test.sql
backuptime=16:34:00
備份數據庫
public class TestMysql {
//讀取配置文件中的信息
//MySql的安裝bin目錄路徑和dump等參數
static String sqlurl=GetProperty.getPropertyByName("property","sqlurl");
//保存備份文件的路徑及名稱
static String path=GetProperty.getPropertyByName("property","path");
public TestMysql(){
backup(); // 備份數據庫
System.out.println("備份數據庫成功!");
}
public static void backup(){
try {
Runtime rt =Runtime.getRuntime(); //返回與當前的Java應用程序的運行時對象
// 調用 調用mysql的安裝目錄的命令
Process child = rt.exec(sqlurl);
// 設置導出編碼為utf-8。這里必須是utf-8
// 把進程執行中的控制台輸出信息寫入.sql文件,即生成了備份文件。注:如果不對控制台信息進行讀出,則會導致進程堵塞無法運行
InputStream in = child.getInputStream();// 控制台的輸出信息作為輸入流
InputStreamReader xx = new InputStreamReader(in, "utf-8");
// 設置輸出流編碼為utf-8。這里必須是utf-8,否則從流中讀入的是亂碼
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();
// 要用來做導入用的sql目標文件:
FileOutputStream fout = new FileOutputStream(path);
OutputStreamWriter writer = new OutputStreamWriter(fout, "utf-8");
writer.write(outStr);
writer.flush();
in.close();
xx.close();
br.close();
writer.close();
fout.close();
System.out.println("");
} catch (Exception e) {
e.printStackTrace();
}
}
}
調用要執行的內容
public class NFDFlightDataTimerTask extends TimerTask {
private static Logger log = Logger.getLogger(NFDFlightDataTimerTask.class);
@Override
public void run() {
try {
//在這里寫你要執行的內容
new TestMysql();
} catch (Exception e) {
log.info("-------------解析信息發生異常--------------");
}
}
}
在 TimerManager 這個類里面,大家一定要注意 時間點的問題。如果你設定在凌晨2點執行任務。但你是在2點以后
發布的程序或是重啟過服務,那這樣的情況下,任務會立即執行,而不是等到第二天的凌晨2點執行。為了,避免這種情況
發生,只能判斷一下,如果發布或重啟服務的時間晚於定時執行任務的時間,就在此基礎上加一天。
public class TimerManager {
//時間間隔 一天時間
private static final long PERIOD_DAY = 24 * 60 * 60 * 1000;
public TimerManager() {
//獲取並處理配置文件中的時間
String backuptime=GetProperty.getPropertyByName("property","backuptime");
String[] time=backuptime.split(":");
int hours=Integer.parseInt(time[0]);
int minute=Integer.parseInt(time[1]);
int second=Integer.parseInt(time[2]);
Calendar calendar = Calendar.getInstance();
/*** 定制每日2:00執行方法 ***/
calendar.set(Calendar.HOUR_OF_DAY,hours);
calendar.set(Calendar.MINUTE, minute);
calendar.set(Calendar.SECOND, second);
Date date=calendar.getTime(); //第一次執行定時任務的時間
//如果第一次執行定時任務的時間 小於 當前的時間
//此時要在 第一次執行定時任務的時間 加一天,以便此任務在下個時間點執行。如果不加一天,任務會立即執行。
if (date.before(new Date())) {
date = this.addDay(date, 1);
}
Timer timer = new Timer();
NFDFlightDataTimerTask task = new NFDFlightDataTimerTask();
//安排指定的任務在指定的時間開始進行重復的固定延遲執行。
timer.schedule(task,date,PERIOD_DAY);
}
// 增加或減少天數
public Date addDay(Date date, int num) {
Calendar startDT = Calendar.getInstance();
startDT.setTime(date);
startDT.add(Calendar.DAY_OF_MONTH, num);
return startDT.getTime();
}
}
創建一個監聽器
public class NFDFlightDataTaskListener implements ServletContextListener {
public void contextInitialized(ServletContextEvent event) {
new TimerManager();
}
public void contextDestroyed(ServletContextEvent event) {
}
}
然后要在web.xml里面配置監聽器
<listener>
<listener-class>
com.zhongren.Test.NFDFlightDataTaskListener
</listener-class>
</listener>