使用cron和mysqlDump定时备份和恢复mysql数据库,以及ubuntu无密码ssh登录

无密码ssh登录另一台服务器

#1、生成秘钥文件 ssh-keygen -t rsa

#2、复制授权到目标服务器 ssh-copy-id ttx@192.168.xxx.xxx

#3、测试无密码连接服务器 ssh ttx@192.168.xxx.xxx

#4、测试备份脚本 bash bakMysql.sh

#5、生成计划任务,每小时的第一分钟备份一次
echo “1 * * * * nohup bash /home/app/***/bakMysql.sh > /home/app/***//logs.log 2>&1 &” >> /var/spool/cron/crontabs/ttx;
这里可以用crontab -l查看当前用户下的cron任务
编辑的时候遇到了crontab -e编辑命令失效的情况
原来经过大佬指点 先用 find / -name crontab查找这个命令在哪,发现是在/var/spool/cron/crontabs下查看以当前用户名做文件名的普通文件,然后赋权限
sudo chown : ./***
之后就可以使用crontab -e修改cron定时任务了
可以尝试直接vi /etc/crontab,然后给需要的用户加上需要定时执行的任务
在这里插入图片描述

这里还踩了个坑,吃了不熟悉cron时间表达式的亏,在定义时间的时候
1 * * * **/1 * * * *是不一样的,前者代表每小时的第一分钟执行,后者代表每分钟执行一次,前面没定位问题一直很懵逼,以为是哪里出了问题,其实是cron任务压根没执行.

想详细了解cron的时间定义这里一张飞机票

启动:sudo /etc/init.d/cron start

关闭:sudo /etc/init.d/cron stop

重启:sudo /etc/init.d/cron restart

重新载入配置:sudo /etc/init.d/cron reload

可以用ps aux | grep cron命令查看cron是否已启动

开启cron日志

这里再顺便介绍一下ubuntu怎么查看cron日志,第一次使用的话可能没有开启cron的日志

修改rsyslog

sudo vim /etc/rsyslog.d/50-default.conf
cron.*              /var/log/cron.log #将cron前面的注释符去掉
重启rsyslog

sudo  service rsyslog  restart

cron定时任务要执行的脚本

#! /bin/bash
# MySQL用户
user="root"
# MySQL密码
userPWD="***"
# 数据库IP
ip=***.***.***.***
# 数据库端口
prot=30001
# 需要定时备份的数据表列表
dbName=***-***-test
# 每次的备份数据以日期创建文件夹存放,同时删除过期备份
# 此处以保留1个月的备份数据为例
DATE=`date -d "now" +%Y%m%d_%H%M%S`
ODATE=`date -d "-7 days" +%Y%m%d`
newdir=/home/***/app/mysqlBackUp/$DATE
olddir=/home/***/app/mysqlBackUp/$ODATE*
# 删除过期备份数据
if [ -d $olddir* ];
  then
    rm -rf $olddir*
fi
# 创建新备份文件夹
mkdir $newdir
# 对备份数据库列表的所有数据库备份
dumpFile=$dbName-$DATE.sql.gz
#如果是docker部署的mysql这里需要登录进去,不是docker的写全路径
#不知道mysqldump命令在哪里可以使用 find / -name mysqldump查询这个的路径
docker exec -it 67a8b3b71c08 mysqldump -h$ip -P$prot -u$user -p$userPWD $dbName | gzip > $newdir/$dumpFile

# 拷贝文件到另外服务器上
scp /$newdir/$dumpFile  xxx@***.***.***.***:/home/xxx/installer/mysqlBackUp

我的mysql在docker容器中
docker exec -it 37f2a148f55d bash
在这里插入图片描述

从docker容器中cp到宿主机
docker cp 37f2a148f55d:/test.sql.gz ./
在这里插入图片描述

使用demo

导出.sql文件

mysqldump -u root -p -B xxx-xxx-test > ./xxx-xxx-test.sql

使用.sql文件恢复

mysql -u root -p'XXX密码' xxx-数据库名字-test < ./xxx-xxx-test.sql
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值