远程登陆命令
#命令主体 服务器地址
Mysql -h124.xxx.xxx.xxx -P24801 --protocol=tcp --skip-ssl -u root -p
备份脚本
#!/bin/bash
. /etc/profile
. ~/.bash_profile
set -x
mysql_user="root" #MySQL备份用户
mysql_password="xxxx" #MySQL备份用户的密码
mysql_host="124.xxx.xxx.xxx"
mysql_port="xxxx"
mysql_charset="utf8" #MySQL编码
backup_db_arr=("xxxx") #要备份的数据库名称,多个用空格分开隔开 如("db1" "db2" "db3")
backup_location=/usr/local/data/app/xxxx/backup #备份数据存放位置,末尾请不要带"/",此项可以保持默认,程序会自动创建文件夹
expire_backup_delete="ON" #是否开启过期备份删除 ON为开启 OFF为关闭
expire_days=15 #过期时间天数 默认为三天,此项只有在expire_backup_delete开启时有效
ssl_client_sa=/usr/local/mysql/data/cert/ca.pem
ssl_client_key=/usr/local/mysql/data/cert/client-key.pem
ssl_client_cert=/usr/local/mysql/data/cert/client-cert.pem
#ssl_server_pem=
#ssl_server_cert=
#ssl_server_key=
# 本行开始以下不需要修改
backup_time=`date +%Y%m%d%H%M` #定义备份详细时间
backup_Ymd=`date +%Y-%m-%d` #定义备份目录中的年月日时间
backup_3ago=`date -d '3 days ago' +%Y-%m-%d` #3天之前的日期
backup_dir=$backup_location/$backup_Ymd #备份文件夹全路径
welcome_msg="Welcome to use MySQL backup tools!" #欢迎语
# 判断MYSQL是否启动,mysql没有启动则备份退出
mysql_ps=`ps -ef |grep mysql |wc -l`
mysql_listen=`netstat -an |grep LISTEN |grep $mysql_port|wc -l`
if [ [$mysql_ps == 0] -o [$mysql_listen == 0] ]; then
echo "ERROR:MySQL is not running! backup stop!"
exit
else
echo $welcome_msg
fi
# 连接到mysql数据库,无法连接则备份退出
#mysql -h$mysql_host -P$mysql_port --ssl-ca=$ssl_client_sa --ssl-cert=$ssl_client_cert --ssl-key=$ssl_client_key -u$mysql_user -p$mysql_password <<end
mysql -h$mysql_host -P$mysql_port --protocol=tcp --skip-ssl -u$mysql_user -p$mysql_password < $backup_dir/$dbname-$backup_time.sql.gz`
#scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。
# `scp $backup_dir/$dbname-$backup_time.sql.gz [email protected]:/home/bak/`
#需要跳过
`mysqldump -h$mysql_host -P$mysql_port --protocol=tcp --skip-ssl -u$mysql_user -p$mysql_password $dbname --default-character-set=$mysql_charset | gzip > $backup_dir/$dbname-$backup_time.sql.gz`
flag=`echo $?`
if [ $flag == "0" ];then
echo "database $dbname success backup to $backup_dir/$dbname-$backup_time.sql.gz"
else
echo "database $dbname backup fail!"
fi
done
else
echo "ERROR:No database to backup! backup stop"
exit
fi
# 如果开启了删除过期备份,则进行删除操作
if [ "$expire_backup_delete" == "ON" -a "$backup_location" != "" ];then
#`find $backup_location/ -type d -o -type f -ctime +$expire_days -exec rm -rf {} \;`
`find $backup_location/ -type d -mtime +$expire_days | xargs rm -rf`
echo "Expired backup data delete complete!"
fi
echo "All database backup success! Thank you!"
exit
fi
NOTE1: 此处不要用windows编辑后传入到linux中,需要我们直接用vim编辑器在linux中编写脚本,若不按照推荐的方式去做,可能会引发其他的报错事项
NOTE2: 如果开启了ssl连接,此处会报错。有知道解决方案的大佬请指教!
修改权限
执行下面的命令
chmod a+x autobackup.sh
运行
运行下面脚本
./autobackup.sh
添加定时服务
crontab -e
附上摘抄的crontab简单介绍:
crontab文件概要:
用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:
minute hour day month week command
分 时 日 月 周 命令
其中:
minute: 表示分钟,可以是从0到59之间的任何整数。(每分钟可用*或者*/1表示)
hour:表示小时,可以是从0到23之间的任何整数。(0表示0点)
day:表示日期,可以是从1到31之间的任何整数。
month:表示月份,可以是从1到12之间的任何整数。
week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。
command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
在以上各个字段中,还可以使用以下特殊字符:
星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。
添加规则
#minute hour day month week command 顺序:分 时 日 月 周 命令
00 02 * * * /usr/local/backup/autobackup.sh
还原数据库
#mysql -h[地址] -P[端口] -u[用户名] -p[密码] [数据库名] <[备份文件]
mysql -h124.xxx.xxx.xxx -Pxxx --protocol=tcp -uroot -pxxx dbname < /xxx/xxx/backup/xxx.sql
参考网址
centos7 自动备份远程数据库
Centos7下Mysql定时远程全量备份
远程MySQL数据库的备份与恢复