:刚在群里面看到小伙伴误操作把服务器上重要的文件给删掉了,于是google了下,找到一篇文章把rm命令改造成mv命令,源博客如下:http://blog.csdn.net/dataspark/article/details/13015351,下面是步骤
1. 在/home目录下新建两个目录,命名为:.trash,tools 2. 在/home/tools/目录下,新建一个shell文件,命名为: remove.sh PARA_CNT=$# TRASH_DIR="/home/.trash" for i in $*; do STAMP=`date +%s` fileName=`basename $i` mv $i $TRASH_DIR/$fileName.$STAMP done 3. 修改~/.bashrc, 增加一行 alias rm="sh /home/tools/remove.sh" 用我们自建的remove.sh替代rm命令 4. 设置crontab,定期清空垃圾箱,如: 0 0 * * * rm -rf /home/.trash/* 每天0点清空垃圾箱 5. source ~/.bashrc 使替换立即生效 经过上面的步骤后,执行rm删除的文件,会被放入垃圾箱。如果误删除,可以从中恢复。 3. 修改~/.bashrc, 增加一行 alias rm="sh /home/tools/remove.sh" 用我们自建的remove.sh替代rm命令 4. 设置crontab,定期清空垃圾箱,如: 0 0 * * * rm -rf /home/.trash/* 每天0点清空垃圾箱 5. source ~/.bashrc 使替换立即生效 经过上面的步骤后,执行rm删除的文件,会被放入垃圾箱。如果误删除,可以从中恢复。
测试如下:
在当前目录下创建了一个del_test目录,然后执行rm del_test后结果如下:
可见被删除的del_test在/home/.trash目录里,这样误删除的文件就能在这里找到。没试过比较大的文件,小文件测试都没问题。
写在后面:防止服务器上文件误操作的办法感觉没有,只能把风险降到最低,比如可以利用sudo限制账号的使用命令权限,把rm命令改造成mv命令,培训相关需要使用服务器人员linux命令操作,root权限最小化,服务器密码只掌握在公司重要的人手上,其他一律不给密码等。