使用linux命令定时备份还原数据库

简介: 使用linux命令定时备份还原数据库

一、定时备份

1、找到合适位置创建文件夹,放置脚本文件和备份数据

创建备份数据库的脚本路径

mkdir -p /usr/local/msyql/mysql_backup

创建存放备份数据的路径

mkdir -p /usr/local/mysql/database_bak/

进入备份数据库的脚本路径

cd /usr/local/mysql/mysql_backup

创建脚本并填写内容

vi mysql_backup.sh

2、填充mysql_backup.sh脚本的内容

#!/bin/bash
#================基础参数===============
#这里的用户名输入自己的用户名
user="root"
#这里的密码输入自己的密码
password="123456"
port="3306"
#备份库名列表,括号内多个数据库空格隔开,这个也是自己的数据库名称
db_name_array=("test")
#备份位置(若不存在,会自动创建)
datafile_path="/usr/local/mysql/database_bak"
#mysqlDump的绝对位置,基本为mysql安装路径
mysqlDump_path="/usr/bin/mysqldump"
#是否删除.sql文件(包含子目录): ON开启,其他字符不开启
rf_switch="ON"
#备份数据保留天数(按文件修改时间计算)
expire_day=10
#================非开发人员勿改================
#备份最终路径,db_name是自己的数据库名称
bak_path="${datafile_path}/${db_name}"
#错误日志文件名称
error_log="${bak_path}/${db_name}_error.log"
#================备份执行指令================
#判断文件夹,不存在则创建
if [ ! -d "$bak_path" ]
then
 mkdir -p  ${bak_path}
 echo "已创建文件夹${bak_path}"
#这个是和if对着的
fi
#判断mysql是否开启 
# lsof要root权限启动
checkPort=`lsof -i:${port} | wc -l`
if [ "$checkPort" -gt "0" ]
then
 echo "mysql 已启动"
else
 echo "mysql 未启动无法进行备份"
 echo "mysql 未启动无法进行备份" > $error_log
fi
#执行备份,
for db_name in ${db_name_array[*]}
do
${mysqlDump_path} --defaults-extra-file=/etc/my.cnf --databases $db_name | gzip > ${bak_path}"/"$db_name$'_'$(date +%Y%m%d).sql.gz 2>>${error_log}
done
#删除过期文件
if [ $rf_switch == "ON" ]
then
 find ${bak_path} -name "*.sql" -mtime +${expire_day} | xargs rm -f
fi

3、脚本增加权限

chmod +x ./mysql_backup.sh

4、安装lsof

yum install -y lsof

6、修改mysql配置文件

vi /etc/my.cnf

在文件末尾加入下面内容(密码是数据库的密码):

[mysqldump]

user=root

password=你的密码

5、测试脚本运行

./mysql_backup.sh

6、设置定时自动执行备份脚本

打开脚本

crontab -e

编辑脚本

#每天下午4点半执行脚本

30 16 * * * sudo /usr/local/mysql/mysql_backup/mysql_backup.sh

二、接收方自动接收数据库备份

在接收方上操作:

1.安装sshpass

yum install sshpass

2.设置定时传输备份

打开脚本

crontab -e

编辑脚本

#定时拷贝生产库的备份

30 16 * * * sshpass -p ‘admin’ scp -r admin@192.168.60.204:/usr/local/mysql/database_bak/* /usr/local/mysql/database_bak

创建存放备份数据的路径

mkdir -p /usr/local/mysql/database_bak/

三、数据库定时还原脚本

1、首先在接受方服务器上创建一个定时还原的脚本

vi /usr/local/mysql/mysql_backup/Reduction.sh

然后可以打开脚本

#这里写自己发送方的数据库名称,也是将数据库名称封装在变量中

db_name=‘test’

#将定时时间封装在变量中

DATE=date +%Y%m%d

#备份所在的文件路径

DIR=/usr/local/mysql/database_bak

echo $DIR

#解压备份文件

gunzip D I R / DIR/DIR/db_nameKaTeX parse error: Expected group after '_' at position 2: '_̲'DATE.sql.gz

#前边都是为了最后这一步

mysql --defaults-extra-file=/etc/my.cnf $db_name < D I R / DIR/DIR/db_nameKaTeX parse error: Expected group after '_' at position 2: '_̲'DATE.sql

2、切换到路径下,给脚本增加权限

cd /usr/local/mysql/mysql_backup

chmod 755 ./ Reduction.sh

3、修改mysql配置文件vi /etc/my.cnf

在文件末尾加入下面内容:

[mysql]

user=root

password=你的密码

4、设定定时

打开脚本

crontab -e

在脚本最后一行添加

#固定时间执行执行还原脚本

30 16 * * * sudo /usr/local/mysql/mysql_backup/Reduction.sh

i

相关实践学习
CentOS 7迁移Anolis OS 7
龙蜥操作系统Anolis OS的体验。Anolis OS 7生态上和依赖管理上保持跟CentOS 7.x兼容,一键式迁移脚本centos2anolis.py。本文为您介绍如何通过AOMS迁移工具实现CentOS 7.x到Anolis OS 7的迁移。
相关文章
|
5天前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
36 8
|
2月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
2月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
135 3
|
2月前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
58 3
|
2月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
137 3
|
3月前
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
3月前
|
NoSQL MongoDB 数据库
MongoDB是一个NoSQL数据库,有着多种不同的命令和操作。以下是一些常见的MongoDB命令:
一些常用的MongoDB命令,如数据库和集合的管理、数据的插入、查询、更新、删除以及聚合操作等。
37 1
|
4月前
|
关系型数据库 MySQL 数据库
6-2|测试连接数据库的命令
6-2|测试连接数据库的命令
|
3月前
|
SQL Shell 数据库
在TDengine容器中创建初始化数据库的Shell命令实例
以上就是在Docker容器环境中部署并初始化TDengine数据库的全过程,希望对你有所帮助。
99 0
|
4月前
|
Unix Linux Python
Cron定时设置在linux和mac中的使用
文章详细说明了如何在Linux和Mac操作系统中使用Cron进行定时任务的设置,并提供了多个Cron表达式的实例。
48 0

热门文章

最新文章