MySQL数据库备份脚本

MySQL数据库备份脚本概述远程或者本地备份mysql数据库,并且保存最新7天的备份内容。#!/bin/sh#definevariables#thelogininformationofyourmysqldb.login_user=""login_passwd="&a

大家好,又见面了,我是你们的朋友全栈君。

概述

每天定时远程或者本地备份mysql数据库,并且保存最新7天的备份内容。

脚本内容

[root@myhost ~]# cat  /home/script/mysqlbackup.sh
#!/bin/sh 
source /etc/profile
#define variables
#the login information of your mysql db.
login_user=""
login_passwd=""       #数据库密码最好不要含有$符号,因为避免被当成变量,这是个大坑,被坑惨了
db_host=""   
db_port=""
#the real databases which you want to backup.
db_array=("db_name0" "db_name1" "db_name2")
#the dir for saving your backup file.
backup_dir="/home/backup/mysql_bak/$db_host-backup"
if [ ! -d  $backup_dir ];then
	mkdir -p $backup_dir
fi 
#date format for the backup file (yyyy-mm-dd) 
time=`date +"%Y-%m-%d"`
#the mysql,mysqldump and other bin's path
MYSQL_COMMDAND=""   			#根据自己的数据库安装路径决定
MYSQLDUMP_COMMAND=""			#根据自己的数据库安装路径决定
MKDIR_COMMAND="/bin/mkdir"
RM_COMMAND="/bin/rm"
MV_COMMAND="/bin/mv"
GZIP_COMMAND="/bin/gzip"

# check the dir for saving backup file is writeable or not.
if [ ! -w  $backup_dir ];then

	echo "Error: $backup_dir is un-writeable." && exit 0 

fi

#check if the dir for saving the backup file exists or not.
if [ ! -d  ${backup_dir}/backup.0 ];then

	$MKDIR_COMMAND  -p "$backup_dir/backup.0"

fi

#starting to backup.

for db_name in ${db_array[*]}
do
	$MYSQLDUMP_COMMAND -P$db_port -u$login_user -h$db_host  --set-gtid-purged=off -p$login_passwd -B  $db_name | $GZIP_COMMAND -9 > "$backup_dir/backup.0/$time.$db_name.gz" 
done

# delete the oldest backup 
if [ -d "$backup_dir/backup.7" ];then

	$RM_COMMAND -rf "$backup_dir/backup.7" 

fi


# rotate backup directory 

#for int in 6 5 4 3 2 1 0 
for int in {6..0}
do 
	if [ -d "$backup_dir"/backup."$int" ];then
		next_int=`expr  $int  + 1` 
		$MV_COMMAND "$backup_dir"/backup."$int" "$backup_dir"/backup."$next_int" 
	fi
done 
	
exit 0; 

定时任务

数据库备份的定时任务尽量避开数据库访问的高峰期,可以选择在半夜执行。

[root@myhost ~]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name command to be executed
30 3  *  *  * root /home/script/mysqlbackup.sh

数据库恢复

[root@myhost ~]#  cd $backup_dir  && ll
##假设备份文件名为:2019-09-29.dbname.gz
[root@myhost ~]#  gzip -d 2019-09-29.dbname.gz && ll    #解压备份文件之后文件名: 2019-09-29.dbname
[root@myhost ~]#  cat  2019-09-29.dbname > 2019-09-29_dbname.sql 或者 mv  2019-09-29.dbname  2019-09-29_dbname.sql 
[root@myhost ~]# mysql -uroot -proot123456 -B  dbname <   2019-09-29_dbname.sql   #恢复数据库
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130902.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • [分享]在线的代码片段测试工具 jsbin[通俗易懂]

    [分享]在线的代码片段测试工具 jsbin[通俗易懂]有些时候,我们往往有这样的需求:临时测试一个代码片段,不想打开编辑器来新建一个文件,测试完毕又删除想给别人分享一个代码,html文件,css文件,js文件,打个包?向别人展个某个效果,发个文件过去?把代码部署到自己服务器上面?针对这些需求,我们使用在线的代码片段测试工具,也许来得更加简单和方便了。针对前端的在线代码片段工具很多,比较常见的有jsbin和jsfiddle以及codepen.而我最喜欢的就是jsbin了,它有着更多的特性给我带来了极大的方便:任意控制要展示的窗口点击这些标

    2025年7月31日
    3
  • pycharm和python idle区别_python新手入门使用自带的IDLE、用pycharm还是visual studio ?…[通俗易懂]

    pycharm和python idle区别_python新手入门使用自带的IDLE、用pycharm还是visual studio ?…[通俗易懂]绝对是VisualStudioCode不信?看图呗输入关键字立马知道用法导入库时有库名提示使用函数的时候有参数提示各种快捷键让你如虎添翼主题随心换更有丰富的扩展以文件夹为单位的项目管理时间线让你清楚地了解代码的变动结合git工具完美地进行项目管理你说,我不用VisualStudioCode用谁呢?什么?你说Pycharm?Pycharm有我VisualStudioCode好看吗?什么…

    2022年8月26日
    5
  • 如何实现 请在微信客户端打开链接

    如何实现 请在微信客户端打开链接那就是判断useragentf(navigator.userAgent.match(/MicroMessenger/i)!=’MicroMessenger’){window.location.href=’wxerror.jsp’;}

    2022年6月7日
    41
  • centOS缺少libcrypto.so.10文件

    centOS缺少libcrypto.so.10文件步骤一点击此链接步骤二,命令安装dnfinstallcompat-openssl10

    2022年6月22日
    58
  • java中怎么输入数组_java中如何从键盘输入数组

    java中怎么输入数组_java中如何从键盘输入数组相关知识说明:java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户的输入。nextLine()函数:1、以Enter为结束符,也就是说nextLine()方法返回的是输入回车之前的所有字符。2、可以获得空白。在线视频教程分享:java在线学习示例如下:publicclassexchangeNum{publicstaticvoidma…

    2022年6月26日
    34
  • 支付宝功能结构图_阿里双十一晚会

    支付宝功能结构图_阿里双十一晚会转自:https://blog.csdn.net/itfly8/article/details/111027014简介:汤波(甘盘),男,1989/02/21,硕士学历。高中开始编程,热爱技术,深信技术让世界更美好。对前沿技术一直保持饥饿感,热衷于创新和革新,让系统体制更为高效和人性化,也深知一个人强走的快,一个团体强才能走的远。在技术团队建设(团队招聘和组建、梯队梯度建设)、技术栈管理(包含技术选型、技术规范建设、软件体系规划)和项目研发管理(软件工程管理、开发效能和质量管理)方面有着较为丰富的实..

    2022年10月19日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号