Linux 教你如何预防删库到跑路
学习linux之前,有几个命令是必须记住的
我们最常见的删库命令
rm -rf /**
这个命令可以在你心情不好的时候,对着公司服务器操作一番,保证让你一时爽,
删完库这个时候你就该跑路了,但是你真的能跑的掉吗,恐怕等待你的就是牢狱之灾;
所以我们要在这里提前做好预防。
1.我们可以使用温和的删除命令,每一次删除都会要你进行确认,避免删错
rm -ir directory
2.在每一次删除前,我们先做好备份
touch test #新建文件
cp test test.bak #复制为带后缀bak的备份文件
mv test test.bak #修改为带后缀bak的备份文件
默认是当前路径,你也可以放在其他路径
mkdir backup #创建文件夹backup
mv test /backup/test.bak #将test文件移动到backup文件夹并且重命名为test.bak
3.将rm命令构建为自己的回收站,编辑 /etc/bashrc文件
vi /etc/bashrc
新增内容
### 重定义rm命令 ### # 定义回收站目录
trash_path='~/.trash' # 判断 $trash_path 定义的文件是否存在,如果不存在,那么就创建 $trash_path.
if [ ! -d $trash_path ]; then
mkdir -p $trash_path
fi # 定义别名:使用 rm 就调用 trash
alias rm=trash # 使用 rl 就调用 'ls ~/.trash'
# 如果更改上面的回收站目录这里的目录也需要修改
alias rl='ls ~/.trash' # 使用 unrm 就调用 restorefile,需要在删除目录的父目录下执行
alias unrm=restorefile # 使用 rmtrash 就调用 claearteash
alias rmtrash=cleartrash # 恢复文件的函数
restorefile()
{
mv -i ~/.trash/$@ ./
} # 删除文件的函数
trash()
{
mv $@ ~/.trash/
} # 清空回收站的函数
cleartrash()
{
read -p "确定要清空回收站吗?[y/n]" confirm
[ $confirm == 'y' ] || [ $confirm == 'Y' ] && /bin/rm -rf ~/.trash/*
}
重新加载下文件,使配置生效
source /etc/bashrc
4.创建你刚才在文件中定义的回收站文件夹.trash
mkdir .trash
5.我们来进行测试一下
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# touch chen
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# mkdir bao
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# ls
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# rm -f chen
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# ll /root/.trash/ #查看回收站
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# rl #查看回收站
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# unrm chen #恢复文件
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# rmtrash #清空回收站
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# /bin/rm -r bao #强制删除文件
使用这种方式存在一个缺陷,每次删除同名文件,都会覆盖回收站原有的文件,那么这个时候我们怎么解决呢
编写shell脚本
vi rm.sh
于是乎,写了下面的shell脚本(rm.sh):
#version : 1.0
#author : zzy
# 删除文件
#主要功能,将文件已到指定的目录
#缺陷:当转移的目录中已经存在需要转移的文件时,尚未处理 recycle_dir=~/.recycle
if ! [ -d $recycle_dir ]
then
mkdir $recycle_dir
echo "创建目录$recycle_dir 保存删除得文件" ... ok
chmod 777 $recycle_dir
echo "修改权限" ..ok
fi
#将需要删除得文件移到该目录
file_dir=$(cd `dirname $1`; pwd)
file_name=`basename $1`
rmFiles="$file_dir/$file_name" cur_date=`date +%Y%m%d_%H_%M_%S`
save_dir="$recycle_dir/$cur_date"; if ! [ -e $save_dir ]
then
mkdir $save_dir
chmod 777 $save_dir
fi
save_dir="$save_dir/$file_name" if [ -e $rmFiles ]
then
if [ -e $save_dir ]
then
echo "$save_dir已经存在,可以通过-f选项移除之前的文件"
else
mv $rmFiles $save_dir
if [ $? -eq 0 ]
then
rm -rf $rmFiles
echo "$rmFiles已经成功删除...若想恢复,请到$save_dir中查找"
#添加日志
logTime=`date "+%Y-%m-%d %H:%M:%S"`
curUser=`whoami`
echo "[$curUser] $logTime $rmFiles ====> $save_dir" >> "$recycle_dir/del.log"
else
echo "请使用相对目录删除"
fi
fi
else
echo "你没有权限或是文件不存在哦!!!"
fi
给脚本授权
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# chmod 777 rm.sh
创建回收站目录
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# mkdir .recycle
测试脚本
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# touch index.html
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# ./rm.sh index.html
/root/index.html已经成功删除...若想恢复,请到/root/.recycle/20190708_20_29_12/index.html中查找
如果我嫌这个脚本太长了怎么办,没事,我们可以把他定义为自己的命令
编辑文件.bashrc
vi ~/.bashrc
添加内容
alias del=~/rm.sh

重新加载下文件
source .bashrc
测试下
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# touch hello.txt
[root@iZj6cet3mqlrzqmdk2a20qZ ~]# del hello.txt
/root/hello.txt已经成功删除...若想恢复,请到/root/.recycle/20190708_20_30_12/hello.txt中查找
github有一个完整的脚本,
github项目地址: https://github.com/LaiJingli/rmtrash
Linux安装
wget --no-check-certificate https://raw.githubusercontent.com/LaiJingli/rmtrash/master/rmtrash.sh
mv rmtrash.sh /bin/
chmod +x /bin/rmtrash.sh
单个用户授权
/bin/rmtrash.sh
所有用户授权
echo "alias rm=/bin/rmtrash.sh" >>/etc/bashrc
帮助命令
rm -h
如果有问题,执行以下2条命令排查,或者退出重新登录系统
source ~/.bashrc
alias |grep rm
如果需要彻底删除文件
rm -e 清空回收站
/bin/rm file 直接删除文件而不经过回收站
/bin/rm -r directory 直接目录而不经过回收站
如果你想设置某个目录不被删除,加个elif 条件
vi /bin/rmtrash.sh

测试结果

回收站存放的目录
cd .rmtrash
vi .rmtrash.log
原文地址:http://www.findme.wang/blog/detail/id/238.html
Linux 教你如何预防删库到跑路的更多相关文章
- 怎么避免从删库到跑路 -- 详解 mysql binlog 的配置与使用
1. 引言 使用数据库的时候,我们每个操作都十分小心,尤其是不能直接在数据库上执行 update.delete 等操作,否则万一忘记加全 where 条件,可能就会造成无法挽回的结果. 有一句十分流行 ...
- 理解Linux文档的默认安全机制、隐藏属性、特殊权限,妈妈在也不用担心你从删库到跑路!!!
写在前面 前面的章节 详解Linux文档属性.拥有者.群组.权限.差异,介绍了文档的基本权限,包括读写执行(r,w,x),还有文档若干的属性,包括是否为目录(d).文件(-).链接文件(l).拥有者. ...
- linux下递归删除目录下所有exe文件---从删库到跑路篇
linux下递归删除目录下所有exe文件 find . -name '*.exe' -type f -print -exec rm -rf {} \; (1) "." 表示从当前目 ...
- Redis勒索事件爆发,如何避免从删库到跑路?
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯云数据库 TencentDB发表于云+社区专栏 9月10日下午,又一起规模化利用Redis未授权访问漏洞攻击数据库的事件发生,此次 ...
- MySQL从删库到跑路(三)——SQL语言
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.SQL语言简介 1.SQL语言简介 SQL是结构化查询语言(Structured Query Language) ...
- MySQL从删库到跑路(一)——MySQL数据库简介
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.MySQL简介 1.MySQL简介 MySQL是一个轻量级关系型数据库管理系统,由瑞典MySQL AB公司开发, ...
- mysql数据库从删库到跑路之mysql基础
一 数据库是什么 之前所学,数据要永久保存,比如用户注册的用户信息,都是保存于文件中,而文件只能存在于某一台机器上. 如果我们不考虑从文件中读取数据的效率问题,并且假设我们的程序所有的组件都运行在一台 ...
- mysql数据库从删库到跑路之mysql表操作
表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 内容: 1 创建表 ...
- mysql数据库从删库到跑路之mysql其他
一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据 ...
随机推荐
- [快捷键的使用] IntelliJ IDEA 将数据库里面的表转化为对象
本文讲述IntelliJ IDEA 多行编辑快捷键的使用,希望能帮到新人提高效率. 注意:在笔记本键盘上操作的方法. 数据库连接工具使用SQLyog 第一步: 从数据里面将文本拷贝到User类里面. ...
- QML 缓存(QML Caching)
最近一直在学习QML,在Qt Creator中新建Qt Quick工程后,尝试不断地修改qml文件来进行试验,qml文件需要反反复复的修改. Qt Widget工程,如果修改了cpp代码后,直接构建或 ...
- 微信小程序开发--常用开发实例
一.常用商品列表的换行排布 <view class="box_max"> <view class="box_min">限时秒杀</ ...
- [PAT] 目录
题号 PAT Basic PAT Advaced PAT Top 1001 害死人不偿命的(3n+1)猜想 1002 写出这个数 1003 我要通过! 1004 成绩排名 ...
- Rikka with Travels(2019年杭电多校第九场07题+HDU6686+树形dp)
目录 题目链接 题意 思路 代码 题目链接 传送门 题意 定义\(L(a,b)\)为结点\(a\)到结点\(b\)的路径上的结点数,问有种\(pair(L(a,b),L(c,d))\)取值,其中结点\ ...
- linux后台运行相关命令
1.nohup & 让程序后台运行,nohup 命令 & 2.jobs 查看当前有多少在后台运行的命令 jobs -l选项可显示所有任务的PID,jobs的状态可以是running, ...
- xdvipdfmx:fatal: Unable to open "xxx.pdf". Output file removed. fwrite: Broken pipe xelatex.exe
解决方法: 关闭外部PDF阅读器,重新编译运行下就好了. 参考:https://github.com/James-Yu/Atom-LaTeX/issues/109
- pointnet
无序性:虽然输入的点云是有顺序的,但是显然这个顺序不应当影响结果.点之间的交互:每个点不是独立的,而是与其周围的一些点共同蕴含了一些信息,因而模型应当能够抓住局部的结构和局部之间的交互.变换不变性:比 ...
- .Net反射在项目中的应用
案例1:项目中可能有多个DAL程序集,每个程序集使用不同的持久化技术或对应不同类型的数据库,但是它们使用同一套接口. 可以在配置文件中配置DAL程序集名称,使用反射加载程序集.创建dal对象. 这样做 ...
- MySQL版本问题导致的SQLException
背景 学习使用 SpringCloud 时,使用 消费者 调用 生产者 时抛出 SQLException,持久层框架为 MyBatis,数据库为最新版本的 MySQL 版本如下: Server v ...