0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何在Linux下实现MySQL数据库定时自动备份

马哥Linux运维 来源:未知 作者:胡薇 2018-11-26 11:05 次阅读

备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程。而对于一些网站、系统来说,数据库就是一切,所以做好数据库的备份是至关重要的!

备份是什么?

为什么要备份?

容灾方案建设

存储介质

光盘

磁带

硬盘

磁盘阵列

DAS:直接附加存储

NAS网络附加存储

SAN:存储区域网络

云存储

这里主要以本地磁盘为存储介质讲一下计划任务的添加使用,基本的备份脚本,其它存储介质只是介质的访问方式可能不大一样。

1、查看磁盘空间情况:

既然是定时备份,就要选择一个空间充足的磁盘空间,避免出现因空间不足导致备份失败,数据丢失的恶果!

存储到当前磁盘这是最简单,却是最不推荐的;服务器有多块硬盘,最好是把备份存放到另一块硬盘上;有条件就选择更好更安全的存储介质;

2、创建备份目录:

上面我们使用命令看出 / home 下空间比较充足,所以可以考虑在 / home 保存备份文件;

cd /home

mkdir backup

cd backup

3、创建备份 Shell 脚本:

注意把以下命令中的 DatabaseName 换为实际的数据库名称;

当然,你也可以使用其实的命名规则!

vi bkDatabaseName.sh

输入 / 粘贴以下内容:

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql

对备份进行压缩:

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz

注意:

把 username 替换为实际的用户名;

把 password 替换为实际的密码;

把 DatabaseName 替换为实际的数据库名;

4、添加可执行权限:

chmod u+x bkDatabaseName.sh

添加可执行权限之后先执行一下,看看脚本有没有错误,能不能正常使用;

./bkDatabaseName.sh

5、添加计划任务

检测或安装 crontab

确认 crontab 是否安装:

执行 crontab 命令如果报 command not found,就表明没有安装

# crontab

-bash: crontab: command not found

如时没有安装 crontab,需要先安装它,具体步骤请参考:

CentOS 下使用 yum 命令安装计划任务程序 crontab

使用 rpm 命令从 CentOS 系统盘安装计划任务程序 crontab

添加计划任务

执行命令:

crontab -e

这时就像使用 vi 编辑器一样,可以对计划任务进行编辑。

输入以下内容并保存:

*/1 * * * * /home/backup/bkDatabaseName.sh

具体是什么意思呢?

意思是每一分钟执行一次 shell 脚本 “/home/backup/bkDatabaseName.sh”。

例如:

修改 /etc/crontab

#vi /etc/crontab

01 3 * * * root/home/backup/bkDatabaseName.sh

表示每天 3 点钟执行备份

退出编辑页:点击 ESC 推出,然后点击 ":wq"w 写入 write q 推出 quit

例如:在每周一中午 12 点运行一次

vi /etc/crontab 然后: 在最后一行, 0 12 * 1 * root run-parts /home/abckup.sh

6、测试任务是否执行

很简单,我们就执行几次 “ls” 命令,看看一分钟过后文件有没有被创建就可以了!

如果任务执行失败了,可以通过以下命令查看任务日志:

# tail -f /var/log/cron

输出类似如下:

Sep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2503]: starting 0anacron

Sep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2512]: finished 0anacron

Sep 30 15:01:01 bogon CROND[3092]: (root) CMD (run-parts /etc/cron.hourly)

Sep 30 15:01:01 bogon run-parts(/etc/cron.hourly)[3092]: starting 0anacron

Sep 30 15:01:02 bogon run-parts(/etc/cron.hourly)[3101]: finished 0anacron

Sep 30 15:50:44 bogon crontab[3598]: (root) BEGIN EDIT (root)

Sep 30 16:01:01 bogon CROND[3705]: (root) CMD (run-parts /etc/cron.hourly)

Sep 30 16:01:01 bogon run-parts(/etc/cron.hourly)[3705]: starting 0anacron

Sep 30 16:01:01 bogon run-parts(/etc/cron.hourly)[3714]: finished 0anacron

Sep 30 16:15:29 bogon crontab[3598]: (root) END EDIT (root)

Crontab 的格式

第 1 列分钟 1~59

第 2 列小时 1~23(0 表示子夜)

第 3 列日 1~31

第 4 列月 1~12

第 5 列星期 0~6(0 表示星期天)

第 6 列要运行的命令

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    11304

    浏览量

    209523
  • 数据库
    +关注

    关注

    7

    文章

    3799

    浏览量

    64396
  • MySQL
    +关注

    关注

    1

    文章

    809

    浏览量

    26574

原文标题:Linux 下如何实现 MySQL 数据库定时自动备份?

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    何在Rust中连接和使用MySQL数据库

    何在Rust中连接和使用MySQL数据库。 安装 mysql 模块 这里我们假设你已经安装了Rust编程语言工具链,在本教程中,我们将使用 mys
    的头像 发表于 09-30 17:05 1674次阅读

    阿里云数据库备份DBS商业化发布,数据库实时备份到OSS

    防线,经常躲在安全网络保护,而数据备份的明文传输和存储也慢慢变得理所应当,安全部门永远不会承诺凭一己之力保障企业100%安全,多层纵深安全防护理念推行,往往会在这层保护罩被攻破时让数据库
    发表于 05-30 17:49

    基于linuxmysql数据库每天自动备份定时备份实现

    linux如何实现mysql数据库每天自动备份
    发表于 05-10 17:10

    Linux的oracle数据库备份

    今天遇到需要备份oracle数据库Linux环境,以前没有弄过,今天尝试了一次,特此记录。
    发表于 07-22 07:36

    如何用labview对数据库进行备份/如何在MySql中使用命令的方式进行数据库备份(非cmd窗口非手动保存)

    想要使用labview对数据库进行备份,但是不清楚语句,在网上查找的信息中,显示如果要备份数据库有两个方法1:使用命令mysqldump ,但是mysqldump 命令必须在 cmd 窗口
    发表于 07-15 16:48

    MySQL数据库误删后的回复技巧

    在日常运维工作中,对于数据库备份是至关重要的!数据库对于网站的重要性使得我们对 MySQL 数据库的管理不容有失!然而是人总难免会犯错误,
    发表于 05-05 08:02 2352次阅读
    <b class='flag-5'>MySQL</b><b class='flag-5'>数据库</b>误删后的回复技巧

    Linux教程之linux如何备份还原mysql数据库

    本文介绍了linux如何备份与恢复mysql数据库数据库
    发表于 10-19 17:18 4次下载

    PHP的Mysql数据库备份脚本详细资料免费下载

    本文档的主要内容详细介绍的是PHP的Mysql数据库备份脚本详细资料免费下载。
    发表于 06-19 17:15 5次下载

    PHP的Mysql数据库备份脚本的程序免费下载

    本文档的主要内容详细介绍的是PHP的Mysql数据库备份脚本的程序免费下载。
    发表于 06-28 15:37 2次下载

    华为云数据库-RDS for MySQL数据库

    华为云数据库-RDS for MySQL数据库 华为云数据库作为华为云的一款数据库产品,它主要是以MyS
    的头像 发表于 10-27 11:06 1524次阅读

    MySQL数据库管理与应用

    MySQL数据库管理与应用 MySQL是一种广泛使用的关系型数据库管理系统,被认为是最流行和最常见的开源数据库之一。它可以被用于多种不同的应
    的头像 发表于 08-28 17:15 977次阅读

    mysql数据库备份与还原

    MySQL是一种常见的关系型数据库管理系统,用于存储和管理数据备份和还原数据库是非常重要的操作,可以保护
    的头像 发表于 11-23 14:32 1201次阅读

    mysql数据库基础命令

    MySQL是一个流行的关系型数据库管理系统,经常用于存储、管理和操作数据。在本文中,我们将详细介绍MySQL的基础命令,并提供与每个命令相关的详细解释。 登录
    的头像 发表于 12-06 10:56 591次阅读

    数据库数据恢复—未开启binlog的Mysql数据库数据恢复案例

    mysql数据库数据恢复环境: 本地服务器,windows server操作系统 ,部署有mysql单实例,数据库引擎类型为innodb,
    的头像 发表于 12-08 14:18 1139次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—未开启binlog的<b class='flag-5'>Mysql</b><b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复案例

    mysql定时备份任务

    在生产环境上,为了避免数据的丢失,通常情况都会定时的对数据库进行备份。而Linux的cront
    的头像 发表于 10-31 10:07 164次阅读