JAva postgresqlデータベースのバックアップ、リストア
いくつかの面に設計されています.
1、javaはlinuxまたはwindowsコマンドを実行する
2、データベースバックアップリストアコマンド
3、postgresqlバックアップリストアコマンドにはパスワードパラメータがなく、現在はプログラムとデータベースだけが同じサーバーで実行されている.
1、javaはlinuxまたはwindowsコマンドを実行する
2、データベースバックアップリストアコマンド
3、postgresqlバックアップリストアコマンドにはパスワードパラメータがなく、現在はプログラムとデータベースだけが同じサーバーで実行されている.
import java.text.SimpleDateFormat;
import java.util.Date;
public class Test {
public static void main(String[] args) {
Date d = new Date(); //
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
String filename = sdf.format(d) + ".tar";
String dbname = "ipam";
String username = "postgres";
String dbpath = "d:\\Program Files\\PostgreSQL\\9.1\\bin\\";
String backuppath = "d:\\" + filename;
// new Test().backupDB(dbname, username, backuppath, dbpath);
backuppath = "d:\\20120826095554.tar";
new Test().restoreDB(dbname, username, backuppath, dbpath);
}
public boolean backupDB(String dbname, String username, String backuppath,
String dbpath) {
//
// username = "postgres";
// String dbpath = "d:\\Program Files\\PostgreSQL\\9.1\\bin\\";
boolean flag = true;//
Runtime rt = Runtime.getRuntime();// jvm
Process process;
StringBuffer cmdbuf = new StringBuffer();
cmdbuf.append(dbpath);
cmdbuf.append("pg_dump -U ");//
cmdbuf.append(username);
cmdbuf.append(" -f ");
cmdbuf.append(backuppath);
cmdbuf.append(" -E utf8 ");//
cmdbuf.append(" -Ft ");
cmdbuf.append(dbname);
try {
// cmd:
System.out.println(cmdbuf);
process = rt.exec(cmdbuf.toString());
} catch (Exception e) {
flag = false;
e.printStackTrace();
}
return flag;
}
public boolean restoreDB(String dbname, String username, String backuppath,
String dbpath) {
boolean flag = true;//
Runtime rt = Runtime.getRuntime();// jvm
Process process;
StringBuffer cmdTemp = new StringBuffer();//
cmdTemp.append(dbpath);
cmdTemp.append("pg_restore -U ");
cmdTemp.append(username);
cmdTemp.append(" -c -d ");
cmdTemp.append(" " + dbname + " ");
cmdTemp.append(backuppath);
try {
process = rt.exec(cmdTemp.toString());//
} catch (Exception e) {
flag = false;
e.printStackTrace();
}
return flag;
}
}