MySQL backup table operation based on Java

MySQL backup table operation based on Java

The core is mysqldump and Runtime
The operation is actually not very difficult. Create a class to perform the backup operation. After receiving the backup call, mark the table as being backed up, and then create a child thread to perform the backup operation. The required configuration information is read from the configuration file, and also pay attention to path issues under Windows and Linux.


The configuration files are as follows:

Java Code Collection Code
# Database address
dbAddress=localhost
# Name of the database to be backed up
databaseName=nms
# Database username
username = root
# Database password
password = root
#mysqldump pathLinux
mysqlpath = /usr/bin/
# Backup file storage location Linux
sqlFilePath = /MySQlBack/
#mysqldump path Windows
#mysqlpath = C\://Program Files//MySQL//MySQL Server 5.5//bin//
# Backup file storage location Windows
#sqlFilePath =C\://MySQl//

The code class that performs the function is as follows:

Java Code Collection Code
package com.nms.common.db;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.ConcurrentHashMap;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* For database backup operations
*/
public class DbBackUpMethod {
private static Log logger = LogFactory.getLog(DbBackUpMethod.class);
private static Properties pros = getPprVue("db.properties");
public static Map<String, String> backUpTableList = new ConcurrentHashMap<String, String>();
private static DbBackUpMethod backObj = new DbBackUpMethod();
public static DbBackUpMethod getDbBackUpMethod(){
return backObj;
}
public void backup(String tableName) {
if(null != backUpTableList.get(tableName)) return;
backUpTableList.put(tableName, tableName); // Mark as already used for backup
new Thread(new DbBackUpThread(tableName)).start();
}
/**
* Used to perform a backup of a table
*/
class DbBackUpThread implements Runnable {
String tableName = null;
public DbBackUpThread(String tableName){
this.tableName = tableName;
}
@Override
public void run() {
try {
String username = pros.getProperty("username");
String password = pros.getProperty("password");
String mysqlpaths = pros.getProperty("mysqlpath");
String address = pros.getProperty("dbAddress");
String databaseName = pros.getProperty("databaseName");
String sqlpath = pros.getProperty("sqlFilePath");
File backupath = new File(sqlpath);
if (!backupath.exists()) {
backupath.mkdir();
}
StringBuffer sb = new StringBuffer();
sb.append(mysqlpaths);
sb.append("mysqldump ");
sb.append("--opt ");
sb.append("-h ");
sb.append(address);
sb.append(" ");
sb.append("--user=");
sb.append(username);
sb.append(" ");
sb.append("--password=");
sb.append(password);
sb.append(" ");
sb.append("--lock-all-tables=true");
sb.append("--result-file=");
sb.append(sqlpath);
sb.append(tableName+".sql");
sb.append(" ");
sb.append("--default-character-set=utf8");
sb.append(databaseName);
sb.append(" ");
sb.append(tableName);
Runtime cmd = Runtime.getRuntime();
Process p = cmd.exec(sb.toString());
p.waitFor(); // This statement is used to mark that if the backup is not completed, the thread will continue to wait
} catch (Exception e) {
logger.error("Problem occurred in the backup operation", e);
}finally{
backUpTableList.remove(tableName); // will be removed eventually
}
}
}
public static Properties getPprVue(String propertyName) {
InputStream inputStream = DbBackUpMethod.class.getClassLoader().getResourceAsStream(properName);
Properties p = new Properties();
try {
p.load(inputStream);
inputStream.close();
} catch (IOException e) {
logger.error("Unable to read the configuration file for backup data", e);
}
return p;
}
}

In Action, you can directly call the backup operation method:

Java Code Collection Code
DbBackUpMethod.getDbBackUpMethod().backup(tableName); // Call backup

At the same time, if the page has an operation to delete the table, you should determine whether the table is being backed up before the operation.

Java Code Collection Code
if(null != DbBackUpMethod.backUpTableList.get(tableName))

Then when the page JSP is called, a response prompt can be given. My judgment is that only one table can be deleted:

function deleteTableByTableName(){
	var pk = table.getSelectedKeys();
	if(""==pk){
		alert("Please select a record!");
		return false;
	}
	if(pk.length > 1){
		alert("Please select a record!");
		return false;
	}
	var rows = table.get(pk);
	var tableName=rows.tableName;
	if(confirm("Are you sure you want to delete this table?")) {
		if(confirm("Do you need to back up the table before deleting it?\n\nAfter selecting backup, the system will perform related operations in the background!\nDuring this period, you cannot delete the table!\nThe backup operation may last for several hours! Please be aware!"")) {
			document.form1.action="backUpTable.action?tableName=" + tableName;
			document.form1.submit();
		}else{
			if(confirm("Are you sure you want to submit? The table will be deleted!")) {
				document.form1.action="del.action?tableName=" + tableName;
				document.form1.submit();
			}
		}
	}
}

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Solution to the error message "java.sql.SQLException: Incorrect string value:'\xF0\x9F\x92\xA9\x0D\x0A...'" when storing emoticons in MySQL
  • An example of how to use Java+MySQL recursion to concatenate tree-shaped JSON lists
  • How to enable Java backend MySQL database to support emoji expressions
  • Comparison table between Java data types and MySql data types
  • Java implements a feasible method to obtain the total number of records of all tables in the MySQL database
  • Implementation code for restoring MySQL database through java backup
  • Detailed tutorial on how to connect to MySQL database using Java (recommended)
  • Detailed explanation of the download process of the mysql-connector-java.jar package
  • Detailed explanation of mysql time zone problem in Java

<<:  Solution to the error problem of Vscode remotely connecting to Ubuntu

>>:  Vue uses element-ui to implement menu navigation

Recommend

Implementation code of short video (douyin) watermark removal tool

Table of contents 1. Get the first link first 2. ...

Detailed example of MySQL subquery

Subquery Classification Classification by returne...

Boundary and range description of between in mysql

mysql between boundary range The range of between...

Detailed explanation of various methods of Vue component communication

Table of contents 1. From father to son 2. From s...

Detailed explanation of uniapp's global variable implementation

Preface This article summarizes some implementati...

Implementation example of react project from new creation to deployment

Start a new project This article mainly records t...

Summary of 50+ Utility Functions in JavaScript

JavaScript can do a lot of great things. This art...

HTML+CSS to achieve cyberpunk style button

First look at the effect: Preface: I came up with...

Vue realizes the function of uploading photos on PC

This article example shares the specific code of ...

A Brief Discussion on the Navigation Window in Iframe Web Pages

A Brief Discussion on the Navigation Window in If...

How does Vue solve the cross-domain problem of axios request front end

Table of contents Preface 1. Why do cross-domain ...

Basic Implementation of AOP Programming in JavaScript

Introduction to AOP The main function of AOP (Asp...

Let's take a look at some powerful operators in JavaScript

Table of contents Preface 1. Null coalescing oper...

Summary of some tips on MySQL index knowledge

Table of contents 1. Basic knowledge of indexing ...