Centos7中MySQL数据库使用mysqldump进行每日自动备份的编写
作者:yanlaile 发布时间:2024-01-17 11:52:41
一、需求说明:
数据库的备份,对于生产环境来说尤为重要,数据库的备份分为物理备份和逻辑备份。
物理备份:使用相关的复制命令直接将数据库的数据目录中的数据复制一份货多分副本,常使用工具:XtraBackup。
逻辑备份:使用mysql自带的mysqldump命令把需要备份的数据以sql语句的形式存储起来。
下边我们将使用mysqldump命令进行数据备份。使用自动任务进行每日备份。
二、执行文件编写:
1、创建文件夹,执行的sh文件和数据库的备份文件都存在这个文件夹下
mkdir /usr/local/mysqlDataBackup
cd /usr/local/mysqlDataBackup
2、创建sh文件并编写shell脚本:
backup.sh
单数据库脚本:
#!/bin/bash
#This scripts is for auto backup databases
#create by weijb at 2021-07-28
#delete data from 7 day before
DATAdelete=‘date +%F -d "-7 day"‘
rm -rf /usr/local/mysqlDataBackup/*_${DATAdelete}.sql.gz
MYSQL_CMD=/usr/bin/mysqldump
MYSQL_USER=账号
MYSQL_PWD=密码
DATA=‘date +%F‘
DBname=test_db
${MYSQL_CMD} -u${MYSQL_USER} -p${MYSQL_PWD} --compact -B ${DBname} | gzip >/usr/local/mysqlDataBackup/${DBname}_${DATA}.sql.gz
解析:
(1)删除7天前的备份数据,节省空间:
DATAdelete=‘date +%F -d "-7 day"‘ 当前时间前7天的日期
rm -rf /usr/local/mysqlDataBackup/*_${DATAdelete}.sql.gz 删除前7天的备份数据,节省空间,只保留最新的7天数据
(2)定义变量:
MYSQL_CMD=/usr/bin/mysqldump mysql自带的mysqldump命令所在的位置
MYSQL_USER=账号 mysql连接的账号
MYSQL_PWD=密码 mysql连接的密码
DATA=‘date +%F‘ 获取当前日期,%F 表示格式:%Y-%m-%d 例如:2021-07-28
DBname=test_db 需要备份的数据库名,当前的数据库名为:test_db
(3)执行备份命令:
${MYSQL_CMD} -u${MYSQL_USER} -p${MYSQL_PWD} --compact -B ${DBname} | gzip >/usr/local/mysqlDataBackup/${DBname}_${DATA}.sql.gz
--compact 优化输出信息
-B 包含建库的语句
gzip 压缩备份,减少备份的文件大小
usr/local/mysqlDataBackup/${DBname}_${DATA}.sql.gz 备份文件保存的路径以及名字
多数据库备份:
#!/bin/bash
#This scripts is for auto backup databases
#create by weijb at 2021-07-28
#delete data from 7 day before
DATAdelete=‘date +%F -d "-7 day"‘
rm -rf /usr/local/mysqlDataBackup/*_${DATAdelete}.sql.gz
MYSQL_CMD=/usr/bin/mysqldump
MYSQL_USER=账号
MYSQL_PWD=密码
DATA=‘date +%F‘
DBname=‘ mysql -u${MYSQL_USER} -p${MYSQL_PWD} -e "show databases;" | sed '1,5d'‘
for DBname in ${DBname}
do
${MYSQL_CMD} -u${MYSQL_USER} -p${MYSQL_PWD} --compact -B ${DBname} | gzip >/usr/local/mysqlDataBackup/${DBname}_${DATA}.sql.gz
done
解析:
(1) 截取需要备份的数据库
-e "show databases;" | sed '1,5d'‘ 显示所有的数据库,并截取mysql自带的information_schema、mysql、performance_schema、sys意外的所有数据库。
(2) 其他的和单库备份相同
3、验证脚本是否编写成功:
(1)脚本文件授权:
cd /usr/local/mysqlDataBackupchmod +x backup.sh
(2) 执行脚本:
sh backup.sh
/usr/local/mysqlDataBackup 下生成文件说明编写成功。
4、编写自动任务:
每天凌晨1点对数据库进行备份:
crontab -e
输入i进行编辑:
00 01 * * * /usr/local/mysqlDataBackup/backup.sh
使用esc退出文件编辑,输入 :wq 保存并退出。
查询任务是否设置成功:
crontab -l
重启crontab服务:
service crond restart
至此,mysql的自动任务脚本备份数据库到此完成。
来源:https://www.cnblogs.com/yanlaile/archive/2021/07/28/15070558.html
猜你喜欢
- 下面就是使用Python爬虫库BeautifulSoup对文档树进行遍历并对标签进行操作的实例,都是最基础的内容html_doc = &qu
- step1:在file中找到default settingsstep2:找到Project Interpreterstep3:按照如图步骤搜
- 引子Linux下不支持QQ等功能丰富的IM,虽然可以通过wine运行QQ2012,但是还是喜欢在gtalk群中聊天,gtalk群不支持图片方
- Sklearn简介Scikit-learn(sklearn)是机器学习中常用的第三方模块,对常用的机器学习方法进行了封装,包括回归(Regr
- 分享一下 IntelliJ IDEA 2021.1 的激活破解教程,相当于永久激活了,亲测有效,下面是详细文档哦~申明:本教程 Intell
- 在使用python对网页进行多次快速爬取的时候,访问次数过于频繁,服务器不会考虑User-Agent的信息,会直接把你视为爬虫,从而过滤掉,
- WEB程序员的技能要求: Web程序员不光要对 后端程序(如 php,jsp,asp.net)语言知识,对程序设计架构知识,数据库
- 本文实例讲述了Python实现二维数组按照某行或列排序的方法。分享给大家供大家参考,具体如下:lexsort支持对数组按指定行或列的顺序排序
- 实验目的:验证主动释放内存变量是否有价值. 实验原始代码: <script language=vbscript runat=serve
- 见过很多获取服务器本地IP的代码,个人觉得都不是很好,例如以下这些不推荐:靠猜测去获取本地IP方法#!/usr/bin/env python
- 本文将介绍如何在 web 框架 Django 中使用可视化工具 Pyecharts, 看完本教程你将掌握几种动态展示可视化数据的方法!Dja
- pandas中常用的一件事情就是对特定条件进行搜索,那么这里介绍使用pandas搜索方式,本案例使用的pandas是anaconda中的,可
- 创建一个NNimport tensorflow as tfimport numpy as np#fake datax = np.linspa
- DFA 算法是通过提前构造出一个 树状查找结构,之后根据输入在该树状结构中就可以进行非常高效的查找。设我们有一个敏感词库,词酷中的词汇为:我
- 一、测试常用规则一个测试单元必须关注一个很小的功能函数,证明它是正确的;每个测试单元必须是完全独立的,必须能单独运行。这样意味着每一个测试方
- 在开始课程之前,我要求学生们填写一份调查表,这个调查表反映了它们对Python中一些概念的理解情况。一些话题("if/
- seed() 设置生成随机数用的整数起始值。调用任何其他random模块函数之前调用这个函数。语法以下是seed()方法的语法:
- 在windows+iis服务器上运行asp程序可能会出现数据库无法更新的情况,具体错误信息可能为: 1、Microsoft JET Data
- 如何显示最后十名来访者?代码和说明见下:<%Application.LockIF NOT isArray(&nbs
- python读取和保存图片5种方法对比python中对象之间的赋值是按引用传递的,如果需要拷贝对象,需要用到标准库中的copy模块方法一:利