linux下mysql数据库和mongodb数据库数据自动备份及定期删除

14560次浏览

前言

前端新技术层次不穷,翻看最近前端网站,看到大部分都是vue及react方面的技术。掌握传统技术的基础之上,作为前端开发人员,确实应该每时每刻都要充电!这篇文章,我记录一下我的博客及资源库数据备份及定期清理的linux操作。

关于mongo数据备份

前段时间,我的博客遭到不明人员的攻击,对此,我还专门写了一篇文章。后来了解到,是阿里云内部,对不安全mongodb的一种清理,类似我博客这种mongodb存在安全隐患,因此,把我的博客数据给清理掉了!幸亏我写了自动化备份脚本,每周对数据进行了备份,才幸免保住数据!我之前文章已经记录了mongo数据备份和恢复的方法,感兴趣的可以看一下!

但是,时间久了,我的备份文件夹里面有很多备份文件。你会发现,只有近期的备份文件好用,很久的文件我们根本不会去用,那么如何对自动备份的文件做一个定期的清理呢?我写的方法如下:

find $backupdir -name $db_name"*.rar.gz" -type f -mtime +30 -exec rm -rf {} \; > /dev/null 2>&1

把这个命令添加到自动化备份脚本后面就可以了。其中:

$backupdir //备份目录
$db_name //数据库名字,也是备份前面的名字

有朋友问 > /dev/null 2>&1 是什么意思呢?

这句话表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。

具有解释如下:

/dev/null 代表空设备文件

> 代表重定向到哪里,例如:echo "123" > /home/123.txt

1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"

2 表示stderr标准错误

& 表示等同于的意思,2>&1,表示2的输出重定向等同于1

关于mysql数据库备份

mysql是我们最常见的,网上搜索也会搜到很多,我这里介绍一下我自己的写法:

#!/bin/bash
# 数据库认证
 user=""
 password=""
 host=""
 db_name=""
# 备份目录
 backup_path="/home/haorooms_backup/mysql"
#时间命名
 date=`date+%Y_%m_%d_%H_%M_%S`
# 设置导出文件的缺省权限,可以不用设置
#umask 177
# 备份数据库到SQL文件
mysqldump -u$user  -p$password $db_name | gzip > $backup_path/$db_name$date.sql.gz

这样还是会出现很久了,数据很多,没有定期清理的情况,我们还是用上面的方法,加上一句:

find $backup_path -name $db_name"*.sql.gz" -type f -mtime +30 -exec rm -rf {} \; > /dev/null 2>&1

这样就可以了!

linux 其他快捷键

关于linux快捷键等,我之前文章有提及:http://www.haorooms.com/post/centeros_wj_zj 或者看http://www.haorooms.com/post/linux_path_commond

我之前会使用 clear 命令或 reset 命令清空当前屏幕,最近发现也可以用快捷键!

清空屏幕快捷键:

ctrl + L

清空当前输入快捷键:

ctrl + u

这篇文章就算是对之前我博客的内容备份方法做一下记录吧!

Tags: mysqlmongodb

相关文章: