当前位置: 首页 > news >正文

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 executed0 4 * * * root /home/backup/mysql/backup.sh

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

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

http://www.lryc.cn/news/405115.html

相关文章:

  • 极速删除 node_modules 仅3 秒()
  • vue this.$refs 动态拼接
  • 一次搞定!中级软件设计师备考通关秘籍
  • 第十六讲 python中的序列-列表简介-特点-常用方法-创建-添加-删除-访问-切片-排序-复制-反转
  • 大模型日报 2024-07-22
  • Electron 的open-file事件
  • 前端面试 vue 接口权限控制
  • 【DevOps系列】构建Devops系统
  • ABAP打印WORD的解决方案
  • emr部署hive并适配达梦数据库
  • 王春城:怎么用精益思维重塑企业战略规划格局?
  • git reset
  • E17.【C语言】练习:sizeof和strlen的辨析
  • 便携气象站:科技助力气象观测
  • php 存储复杂的json格式查询(如:经纬度)
  • UDP网口(1)概述
  • Linux - 进程的概念、状态、僵尸进程、孤儿进程及进程优先级
  • Gradle依赖报告:项目依赖树的X光机
  • 开源XDR-SIEM一体化平台 Wazuh (1)基础架构
  • 从零开始:构建基于深度学习的实时跌倒检测系统(UI界面+YOLO代码+数据集)
  • 【策略模式在项目中的实际应用】
  • 昇思25天学习打卡营第14天|计算机视觉
  • 将json数组格式转成数组
  • 接口测试之测试原则、测试用例、测试流程详解
  • 证书上的服务器名错误解决方法
  • 前端:上传2进制图片
  • web前端 React 框架面试200题(三)
  • 交流负载箱:电力系统的节能利器
  • 【思科】链路聚合实验配置和背景
  • 使用 vue-element-plus-admin 框架遇到的问题记录