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

前言

前端新技术层次不穷,翻看最近前端网站,看到大部分都是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 其他快捷键

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

清空屏幕快捷键:

ctrl + L

清空当前输入快捷键:

ctrl + u

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值