【一台服务器备份mysql到另外一台服务器】

一、配置服务器 ssh

从一台服务器同步文件到另一台服务器,需要使两台服务器之间建立 ssh 连接

ssh-keygen -t rsa

运行这句,这里的这个命令是两条服务器都需要执行的,不然没有/root/下面不会生成.ssh文件夹,一直敲击回车,会在 /root/.ssh 目录下生成两个文件,我使用的是 xftp 查看的文件,这个 .ssh 文件夹是隐藏文件夹,所以 xftp 下面看不到,你要手动输入地址 /root/.ssh 就可以进去了,把 id_rsa.pub 里的内容全选复制

来到目标服务器,也是进入 /root/.ssh 文件夹,把刚刚复制的内容粘贴进 authorized_keys 的尾部(authorized_keys 可能没有,自己新建,里面可以有多个 key,互不影响,换一行粘贴就行了)

保存,两台服务器的 ssh 连接就建立好。

二、编写自动备份 sh 文件
在数据库所在的服务器新建一个 sh 文件,放在哪里、怎样命名都随意(此处注意!!!不要使用 xftp 右键新建文件来编写 sh 文件,那样编码会出问题,比如新建的文件名后面会多出一个问号“?”,使用命令行vim或vi来新建)

mkdir mysqlFileBak
cd mysqlFileBak
mkdir bak
vim bakShell.sh

BACKUP=/root/mysqlFileBak/bak
#当前时间,用来命名sql文件
DATETIME=$(date +%Y-%m-%d)
echo "===备份开始==="
echo "备份文件存放于${BACKUP}/$DATABASE-$DATETIME.sql"
#生成sql文件,命名
DATABASE=bakdb
echo $DATABASE-$DATETIME
/home/mysql-8.0.25/bin/mysqldump -uroot -proot mysql > ${BACKUP}/$DATABASE-$DATETIME.sql
echo "===导出成功,开始传输==="
#将sql文件从服务器129备份到服务器130自己建立的文件夹/root/data下面
scp -P 22 /root/mysqlFileBak/bak/$DATABASE-$DATETIME.sql root@192.168.199.130:/root/data
#删除备份目录
#rm -rf ${BACKUP}/$DATETIME
#删除7天前备份的数据,自行更改
#find $BACKUP -mtime +7 -name "*.sql" -exec rm -rf {} \;
echo "===数据库备份到服务器成功==="

/home/mysql-8.0.25/bin/mysqldump  安装mysql的bin目录下,注意是绝对路径下mysqldump,不然定时任务执行时导出的.sql文件则为空的。

scp -P 22 是指定 ssh 端口,不指定默认为 22,root 是目标服务器130的用户名

下面我们运行一下这个 sh 看看效果,cd 到你的 sh 存放的文件夹 sh bakShell.sh,首次进行 ssh 连接要输入一个 yes 回车,然后去目标服务器 130 查看,sql 文件已经同步过去。

三、设置定时自动执行

给脚本文件开放权限

chmod 777 /root/mysqlFileBak/bakShell.sh

输入下面语句,vim 会打开一个文件

crontab -e 或者 vim /etc/crontab

里面这样写,保存,前面的 */5 * * * * 是 crontab 表达式,代表每五分钟执行 /root/mysqlFileBak/bakShell.sh

 注意!这里是crontab表达式,与cron表达式是有区别的,这里用不了6位的cron表达式

*/5 * * * * sh /data/mysqlFileBak/bakShell.sh


再刷新一下配置

service crond reload

四、在目标服务器定时删除多余的文件

        /root/data/下新建jobrmbak.sh

        

vim jobrmbak.sh

 脚本代码

BACKUP=/root/data
#保留7天内备份的数据
find $BACKUP -mtime +7 -name "*.sql" -exec rm -rf {} \;
echo "===删除成功==="

 脚本开放权限

chmod 777 /root/data/jobrmbak.sh

设置定时

crontab -e 或者 vim /etc/crontab

 注意!这里是crontab表达式,与cron表达式是有区别的,这里用不了6位的cron表达式

*/5 * * * * sh /root/data/jobrmbak.sh

刷新配置

service crond reload

搞定!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值