java 定时备份posgreSQL数据库
来源:互联网 发布:mac 照片 路径 编辑:程序博客网 时间:2024/06/11 22:52
首先我们要先写一个备份类
BackupDb.java
代码如下:
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class BackupDb {
public BackupDb() {
}
public String backup() throws IOException {
BufferedWriter mBufWriter = null;
//建立一个BackupDb.bat文件
FileWriter fileWriter = new FileWriter("BackupDb.bat");
mBufWriter = new BufferedWriter(fileWriter);
/*
* 把数据库备份方法写入BackupDb.bat文件中。
* BackupDbUrl 是数据库备份命令。
* pg_dump.exe -U postgres -E utf8 test 备份数据库命令。
* —U postgres 数据库用户名 -E utf8 设定字符编码格式。test 数据库名
* BackupDbName 备份文件所存目录和名称,我是以备份时间命名。
*/
String BackupDbUrl = "d://PostgreSQL8//bin//pg_dump.exe -U postgres -E utf8 test >";
//取系统时间
Date NowTimes = new Date();
//将时间格式化成yyMMddhhmmss(年月日时分秒),例如200805010043 2008年5月1日0点43分。
SimpleDateFormat sdf = new SimpleDateFormat("yyMMddhhmmss");
String BackupDbName = "d://" + sdf.format(NowTimes) + ".sql";
mBufWriter.write(BackupDbUrl);
mBufWriter.write(BackupDbName);
mBufWriter.newLine();
mBufWriter.flush();
mBufWriter.close();
try {
Runtime.getRuntime().exec("BackupDb.bat"); //执行BackupDb.bat文件进行备份数据库
} catch (Exception e) {
e.printStackTrace();
}
return BackupDbName;
}
}
然后我们在创建一个timer类,用来定时备份时间
TimerUse.java
代码如下:
package yifeng.com.org;
import java.text.SimpleDateFormat;
import java.util.*;
import java.io.*;
public class TimerUse {
public static void main(String[] args) {
PickTask picktask = new PickTask();
picktask .start(1, 60); //每60秒执行一次
}
}
class PickTask {
private Timer timer;
public PickTask() {
timer = new Timer();
}
private TimerTask task = new TimerTask() {
public void run() {
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String beginDate = sdf.format(date);
String beginTime = beginDate.substring(11, 16);
System.out.println(beginDate);
BackupDb bdb=new BackupDb();
PrintLog pl=new PrintLog();
//设定备份时间
if (beginTime.equals("23:22")) {
try {
bdb.backup(); //执行文件备份
String dbName=bdb.backup().toString(); //取出备份的文件名字
String path="d://";
int nameNo=dbName.lastIndexOf("//");
File file=new File(path,dbName.substring(nameNo+1, dbName.length()));
System.out.println(dbName.substring(nameNo+1, dbName.length()));
//查看文件是否存在,以判断是否备份成功,写到备份日志里
//注: 此处有点问题,明明备份成功,但是日志里却是位备份成功。不知道原因出在哪里
// 在debug的时候写到日志里的就是备份文件成功。
// 哪位高手能帮忙解决一下,在下不胜感激。
//提示:其实这里还应该做些处理,如果未备份成功就应该重新备份。
if(file.exists())
pl.WriteLog(dbName+" 备份文件成功");
else
pl.WriteLog(dbName+" 未备份成功");
} catch (FileNotFoundException e) {
System.out.println("can not find the file");
} catch (IOException e) {
e.printStackTrace();
}
}
}
};
public void start(int delay, int internal) {
timer.schedule(task, delay * 1000, internal * 1000);
}
}
最后我们在写一个简单的备份日志类:
PrintLog.java
代码如下:
package yifeng.com.org;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class PrintLog {
public PrintLog(){
}
public void WriteLog(String log) throws IOException{
BufferedWriter mbw = null;
//在D盘创建一个备份日志文件log。txt
FileWriter fileWriter = new FileWriter("D://log.txt",true);
mbw = new BufferedWriter(fileWriter);
Date date=new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String writeTime=sdf.format(date);
mbw.write(writeTime+" "); //写入时间
mbw.write(log); //写入日志内容
mbw.newLine();
mbw.flush();
mbw.close();
}
}
- java 定时备份posgreSQL数据库
- posgresql数据库常用命令
- java Spring调整Quartz定时备份数据库
- Oracle数据库Java备份恢复定时任务
- java 定时备份数据库(未测试)
- 定时远程备份数据库
- 定时备份数据库
- 数据库定时备份
- 定时备份ORACLE数据库
- 数据库定时备份脚本
- 定时备份数据库
- sqlserver2005定时备份数据库
- 定时备份数据库SQL
- SQL数据库定时备份
- sql2008 定时备份数据库
- oracle数据库定时备份
- centos 定时备份数据库
- Linux定时备份数据库
- ASP.NET网站建设之代码分离
- Oracle 分区表(Partition)
- asp.net网页版斗地主(当前版本1.0 未完待续 最后更新时间2010-06-21)
- 分区表概述
- C# 将数据导出到Excel汇总
- java 定时备份posgreSQL数据库
- 中文普通图书著者号码的取号规定
- Oracle表分区学习笔记
- Windows DDK中经典的宏——CONTAINING_RECORD
- 耐住寂寞,享受成功
- 分区表、分区索引和全局索引部分总结
- 谷歌内部逐步淘汰Windows
- 左连接,右连接,全连接,内连接,交叉连接,自连接
- 未公开函数