MySQL定时备份数据,并上传到oss

1.环境准备

1.安装阿里云的ossutil
2.安装mysql

2.编写脚本

脚本内容如下

#!/bin/bash
# 数据库的配置信息,根据自己的情况进行填写
db_host='localhost'
db_username='root'
db_password='root'
db_name='db_root'
# oss 存贮数据的bucket地址
bucket_name='rbsy-backup-bucket'
name=$(date +%Y%m%d)
# 导出数据并压缩
mysqldump -h $db_host -u$db_username -p$db_password $db_name --single-transaction --quick | gzip > /home/backup/mysql/${db_name}-${name}.sql.gz
# 上传到oss
/home/apps/ossutil/ossutil -c /home/apps/ossutil/config cp /home/backup/mysql/${db_name}-${name}.sql.gz oss://${bucket_name}/mysql/${db_name}-${name}.sql.gz
# 设置权限为私有
/home/apps/ossutil/ossutil -c /home/apps/ossutil/config set-acl oss://${bucket_name}/mysql/${db_name}-${name}.sql.gz private
# 删除备份
rm -f /home/backup/mysql/${db_name}-${name}.sql.gz

其中 /home/apps/ossutil/ossutil 是自己ossutil 的地址
mysqldump 是mysql导出脚本的工具,这里没有用全路径,在定时任务里面则需要指定mysql的环境变量,如果用的全路径,则不需要指定环境变量

3. 添加定时任务

linux 添加定时任务的方式有好几种,采用哪种均可,本次编辑etc下的crontab文件来添加

vim /etc/crontab

下面是一个完整的crontab文件,我们编辑的话只需要在PATH后面加mysql的环境变量和 backup.sh 脚本执行时间即可

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/home/apps/mysql/bin
MAILTO=root

# 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

0 4 * * * root /home/backup/mysql/backup.sh

需要注意的两个地方就是
在这里插入图片描述
path 后面需要加上mysql的环境变量,因为脚本中没有用全路径

在这里插入图片描述
0 4 * * * 是cron 表达式,代表每天4点执行
root 是执行此脚本的用户
/home/backup/mysql/backup.sh 是要执行的脚本

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值