自动备份MySQL数据库(含远程备份)

本贴最后更新于 3042 天前,其中的信息可能已经天翻地覆

1、每日备份,按日期生成文件名。

2、通过SCP远程备份,并只保留最近7天内的副本。

3、crontab定时任务。

4、SCP远程备份需要配置SSH免密码登录,详见:《SSH免密码登录》

 

一、新建mysql_back.sh脚本,存放在/home/XXX/mysql_backup/目录,具体内容如下:

!/bin/bash

# 当前日期,格式:年月日

date_str=$(date +%Y-%m-%d)

 

# 备份并压缩

echo

echo$(date +%Y-%m-%d\ %H:%M:%S)'备份并压缩MySQL……'

# 设置XXX用户目录下的mysql_backup为工作目录

cd /home/XXX/mysql_backup

# 备份192.168.10.163主机上的某个数据库并用gzip压缩成.gz的文件,用户名、密码、数据库、IP等请自行替换

mysqldump -h192.168.10.163 -u用户名 -p密码 -R -E -e \数据库名 \

  | gzip > /home/XXX/mysql_backup/MySQL_DB_$date_str.sql.gz

echo$(date +%Y-%m-%d\ %H:%M:%S)'备份完成。'

 

# 冗余备份

echo

echo$(date +%Y-%m-%d\ %H:%M:%S)'上传到服务端……'

 

# 通过SCP上传到远程服务器的root用户的mysql_backup文件夹下,远程主机请自行替换为IP或域名

scp MySQL_DB_$date_str.sql.gz root@远程主机:~/mysql_backup/

 

echo$(date +%Y-%m-%d\ %H:%M:%S)'上传完成。'

 

echo

echo$(date +%Y-%m-%d\ %H:%M:%S)'删除过期的备份……'

 

# 删除100天前的本地备份

find /home/XXX/mysql_backup -name"MySQL_DB_*"-type f -mtime+100-execrm{} \;

 

# 删除远程主机上10天前的备份

ssh root@远程主机 "find ~/mysql_backup -name 'MySQL_DB_*' -type f -mtime +10 -exec rm {} \;"

 

echo$(date +%Y-%m-%d\ %H:%M:%S)'删除完成。'

 

echo

echo$(date +%Y-%m-%d\ %H:%M:%S)'备份完成。'

 

二、crontab定时任务

1、sudo crontab -e

2、在最后一行加入:

30 2 * */home/XXX/mysql_backup/mysql_backup.sh >> /home/XXX/mysql_backup/mysql_backup.log

3、此行包含两部分:

a) 30 2 * * *:每天凌晨2点半执行,30分,2时,后面的3个*对应日、月、年;每两小时执行的cron表达式为:0 */2 * * *

b) /home/XXX/mysql_backup/mysql_backup.sh >> /home/XXX/mysql_backup/mysql_backup.log ,执行mysql_backup.sh脚本,并将日志输出到mysql_backup.log

4、启动cron服务

$ sudo service cron restart

 

静等执行……

  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    675 引用 • 535 回帖
  • 备份
    12 引用 • 18 回帖
  • cron
    11 引用 • 3 回帖
  • crontab

    crontab 命令常见于 类 Unix 的操作系统之中,用于设置周期性被执行的指令。该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行。该词来源于希腊语 chronos(χρνο),原意是时间。

    12 引用 • 25 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 其他回帖
  • dongyado 1

    哈,跟我之前写的一个脚本,很相似,也是采用 mysql_dump 和 cron 写的,不过我在脚本加了一个备份文件过期删除的操作,可以自定义过期时间

推荐标签 标签

  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    130 引用 • 793 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 234 关注
  • abitmean

    有点意思就行了

    29 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 2 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 433 关注
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    140 引用 • 441 回帖 • 1 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    60 引用 • 287 回帖
  • 反馈

    Communication channel for makers and users.

    124 引用 • 907 回帖 • 210 关注
  • 电影

    这是一个不能说的秘密。

    120 引用 • 597 回帖
  • danl
    89 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    19 引用 • 23 回帖 • 699 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 336 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 31 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 531 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    163 引用 • 473 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 4 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    45 引用 • 113 回帖 • 284 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 608 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    165 引用 • 407 回帖 • 514 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1425 引用 • 10043 回帖 • 474 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 111 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖