0

0

Linux MySQL 定时备份并上传到 git 仓库

藏色散人

藏色散人

发布时间:2019-12-24 14:29:29

|

2703人浏览过

|

来源于ruoxiaozh

转载

简介

我们在部署我们的中小型项目时, 在数据存储, 我们通常选择 mysql 作为我们的存储工具. 那么对于一个大的项目来说, 每天的数据量是十分大的. 对于每天产生的数据, 如果哪一天我们的网站或者服务器受到攻击, 我们的数据丢失是个很爆炸的事情, 所以说自然这设计到数据库的备份. 那么怎样的备份是我们想要的呢? 

对于备份的数据文件我们可能会存放在服务器目录, 备份周期的话当然是按照数据量来说的, 这里我们一般都是每天的凌晨备份一次. 备份后的文件存放在我们的服务器的目录下面, 但是万一有一天服务器也崩溃了, 那么备份的文件也就没了, 所以我们设想一个好的方案就是数据库每天备份 每次备份自动提交到远程仓库, 这里我以码云为例.

推荐学习:《linux教程

码云

首先建立好远程仓库, 在这里我选择了 码云

新建一个私有仓库, 当然为了每次可以免密码提交文件, 在服务器里可以生成 ssh key

服务器新建备份

在服务器为了存储备份后的文件, 新建一个备份目录

$ mkdir /bak

进入该目录后, 继续新建两个文件夹 mysqlBak 和 shDir, 一个是放脚本文件, 一个是放具体备份后的文件.

下面我们可以去新建脚本了, 进入 shDir 目录后执行

$ vim mysqlBak.sh

具体的代码如下:

#!bin/sh
################### 数据库配置信息 #######################
createAt=`date +%Y-%m-%d-%H:%M:%S`
user=root
passwd=ghc1996
dbname=ispace
mysql_back_path=/bak/mysqlBak
################### 执行命令 #######################
mysqldump -u $user -p$passwd $dbname > $mysql_back_path/$createAt.sql
cd /bak/mysqlBak
/usr/local/git/bin/git add .
/usr/local/git/bin/git commit -m $createAt
/usr/local/git/bin/git push

这里只是一个简单的脚本, 我想了解 linux 的很容易看的懂, 执行的就是备份数据库并 push 到远程仓库.

那么既然是脚本, 我们需要指明什么时候执行这个脚本, 指定脚本执行.

$ crontab -e

我们希望是每天的凌晨执行一次备份, 并添加到远程仓库, 那么添加

故事AI绘图神器
故事AI绘图神器

文本生成图文视频的AI工具,无需配音,无需剪辑,快速成片,角色固定。

下载
$ 0 0 * * * /bin/sh /bak/shDir/mysqlbak.sh

对 linux 的 crontab 指定的时间只有五个部分

ccd07c12bef1e83d033c0ae6e8a0d80.png

使用命令 crontab -e 然后直接编辑定时脚本。 时间 + 具体的名字

举个列子来说就是:

0 0,3,7,9,12,15,18,21,23 * * * /bin/sh /bak/shell/mysqlBak.sh

这样的话就是我每天 0,,3,7,9,12,15,18,21,23 点时会去执行这个脚本文件, 那么这就实现了基本的数据库的备份

执行定时任务:

$ crontab -l

如果服务没有启动 那么重新启动定时任务

$ systemctl restart crond

那么现在这个定时任务就已经启动了, 对于提交远程仓库前提是在服务器生成 ssh key并添加到码云, 这在上面也提到过.

对于需要提交文件的目录初始化 git 目录就可以了, 这样局可以构成了我们需要的本分任务.

当然过程中可能会遇到一些问题, 我在下面的相关链接都已经罗列出来了.

这样一来我们就可以实现了每天的凌晨备份我们的数据库, 并同时提交到我们的码云这个远程仓库, 这也是我们想要的效果.

我也说过备份的周期视我们的项目的数据量的大小而定.

对于每个框架都有自己的备份机制 我这里所写的是我们自己实现的一个通用的备份机制

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

0

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

20

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

62

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

160

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号