
本次实现是使用了MySQL数据库本身提供的备份命令mysqldump和恢复命令mysql,在java代码中通过从命令行调用这两条命令来实现备份和恢复。备份和恢复所使用的文件都是sql文件。
本代码是参照网上某网友提供的源码完成的。
[java] view plaincopy
package xxx.utils
import java.io.BufferedReader
import java.io.File
import java.io.FileInputStream
import java.io.FileNotFoundException
import java.io.FileOutputStream
import java.io.IOException
import java.io.InputStream
import java.io.InputStreamReader
import java.io.OutputStream
import java.io.OutputStreamWriter
import java.io.PrintWriter
import java.io.UnsupportedEncodingException
/**
* MySQL数据库的备份与恢复 缺陷:可能会被杀毒软件拦截
*
* @author xxx
* @version xxx
*/
public class DatabaseBackup {
/** MySQL安装目录的Bin目录的绝对路径 */
private String mysqlBinPath
/** 访问MySQL数据库的用户名 */
private String username
/** 访问MySQL数据库的密码 */
private String password
public String getMysqlBinPath() {
return mysqlBinPath
}
public void setMysqlBinPath(String mysqlBinPath) {
this.mysqlBinPath = mysqlBinPath
}
public String getUsername() {
return username
}
public void setUsername(String username) {
this.username = username
}
public String getPassword() {
return password
}
public void setPassword(String password) {
this.password = password
}
public DatabaseBackup(String mysqlBinPath, String username, String password) {
if (!mysqlBinPath.endsWith(File.separator)) {
mysqlBinPath = mysqlBinPath + File.separator
}
this.mysqlBinPath = mysqlBinPath
this.username = username
this.password = password
}
/**
* 备份数据库
*
* @param output
*输出流
* @param dbname
*要备份的数据库名
*/
public void backup(OutputStream output, String dbname) {
String command = "cmd /c " + mysqlBinPath + "mysqldump -u" + username
+ " -p" + password + " --set-charset=utf8 " + dbname
PrintWriter p = null
BufferedReader reader = null
try {
p = new PrintWriter(new OutputStreamWriter(output, "utf8"))
Process process = Runtime.getRuntime().exec(command)
InputStreamReader inputStreamReader = new InputStreamReader(process
.getInputStream(), "utf8")
reader = new BufferedReader(inputStreamReader)
String line = null
while ((line = reader.readLine()) != null) {
p.println(line)
}
p.flush()
} catch (UnsupportedEncodingException e) {
e.printStackTrace()
} catch (IOException e) {
e.printStackTrace()
} finally {
try {
if (reader != null) {
reader.close()
}
if (p != null) {
p.close()
}
} catch (IOException e) {
e.printStackTrace()
}
}
}
/**
* 备份数据库,如果指定路径的文件不存在会自动生成
*
* @param dest
*备份文件的路径
* @param dbname
*要备份的数据库
*/
public void backup(String dest, String dbname) {
try {
OutputStream out = new FileOutputStream(dest)
backup(out, dbname)
} catch (FileNotFoundException e) {
e.printStackTrace()
}
}
/**
* 恢复数据库
*
* @param input
*输入流
* @param dbname
*数据库名
*/
public void restore(InputStream input, String dbname) {
String command = "cmd /c " + mysqlBinPath + "mysql -u" + username
+ " -p" + password + " " + dbname
try {
Process process = Runtime.getRuntime().exec(command)
OutputStream out = process.getOutputStream()
String line = null
String outStr = null
StringBuffer sb = new StringBuffer("")
BufferedReader br = new BufferedReader(new InputStreamReader(input,
"utf8"))
while ((line = br.readLine()) != null) {
sb.append(line + "/r/n")
}
outStr = sb.toString()
OutputStreamWriter writer = new OutputStreamWriter(out, "utf8")
writer.write(outStr)
writer.flush()
out.close()
br.close()
writer.close()
} catch (UnsupportedEncodingException e) {
e.printStackTrace()
} catch (IOException e) {
e.printStackTrace()
}
}
/**
* 恢复数据库
*
* @param dest
*备份文件的路径
* @param dbname
*数据库名
*/
public void restore(String dest, String dbname) {
try {
InputStream input = new FileInputStream(dest)
restore(input, dbname)
} catch (FileNotFoundException e) {
e.printStackTrace()
}
}
public static void main(String[] args) {
Configuration config = HibernateSessionFactory.getConfiguration()
String binPath = config.getProperty("mysql.binpath")
String userName = config.getProperty("connection.username")
String pwd = config.getProperty("connection.password")
DatabaseBackup bak = new DatabaseBackup(binPath, userName, pwd)
bak.backup("c:/ttt.sql", "ttt")
bak.restore("c:/ttt.sql", "ttt")
}
}
最后的main方法只是一个简单的使用方法的示例代码。
本人所做的项目是使用了hibernate的,而这里需要提供MySQL的bin路径和用户名、密码,而hibernate.cfg.xml中本身就是需要配置数据库的用户名和密码,所以我把MySQL的bin路径也直接配置到了这个文件里面,也不需要创建专门的配置文件,不需要写读取配置文件的接口了。
如果不明白,可以去看hibernate.cfg.xml的说明,里面是可以配置其他的property的
还原不会删除备份数据,再次备份后会覆盖之前的备份数据。
后台有此功能,data/backupdata若有数据会有显示,数据还原即可。
所谓下载到本地应该是别人的建议,非系统的要求,网站系统内的数据备份功能所产生的备份数据依然存在于服务器,当服务器里的备份数据丢失时,可将本地的另一份备份数据上传执行数据还原 *** 作,即多一份保险。
替换即是覆盖,一个意思。
dedecms是自动替换的,始终保持仅一份最新的。
有两种方法,一种方法使用mysql的check table和repair table 的sql语句,另一种方法是使用MySQL提供的多个myisamchk, isamchk数据检测恢复工具。前者使用起来比较简便。推荐使用。1. check table 和 repair table
登陆mysql 终端:
mysql -uxxxxx -p dbname
check table tabTest
如果出现的结果说Status是OK,则不用修复,如果有Error,可以用:
repair table tabTest
进行修复,修复之后可以在用check table命令来进行检查。在新版本的phpMyAdmin里面也可以使用check/repair的功能。
2. myisamchk, isamchk
其中myisamchk适用于MYISAM类型的数据表,而isamchk适用于ISAM类型的数据表。这两条命令的主要参数相同,一般新的系统都使用MYISAM作为缺省的数据表类型,这里以myisamchk为例子进行说明。当发现某个数据表出现问题时可以使用:
myisamchk tablename.MYI
进行检测,如果需要修复的话,可以使用:
myisamchk -of tablename.MYI
关于myisamchk的详细参数说明,可以参见它的使用帮助。需要注意的时在进行修改时必须确保MySQL服务器没有访问这个数据表,保险的情况下是最好在进行检测时把MySQL服务器Shutdown掉。
-----------------------------
另外可以把下面的命令放在你的rc.local里面启动MySQL服务器前:
[ -x /tmp/mysql.sock ] &&/pathtochk/myisamchk -of /DATA_DIR/*/*.MYI
其中的/tmp/mysql.sock是MySQL监听的Sock文件位置,对于使用RPM安装的用户应该是/var/lib/mysql/mysql.sock,对于使用源码安装则是/tmp/mysql.sock可以根据自己的实际情况进行变更,而pathtochk则是myisamchk所在的位置,DATA_DIR是你的MySQL数据库存放的位置。
需要注意的时,如果你打算把这条命令放在你的rc.local里面,必须确认在执行这条指令时MySQL服务器必须没有启动!检测修复所有数据库(表)
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)