前言
前端新技术层次不穷,翻看最近前端网站,看到大部分都是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
这篇文章就算是对之前我博客的内容备份方法做一下记录吧!