51ak.blogs

误删 /user/bin目录后的补救

当危险的动作发生, 误删 /user/bin目录后的补救

 

以下是昨天晚上真实的误操作现场,模拟记录一下

(这是测试环境,所以操作得很随意,有些执行动作很不规范)

 

在上面编译一个软件Dboop,完事以后想把它做个软链到 /usr/bin

sudo - su

cd /usr/local/dboop/bin/

cp  Dboop   dboop

ln -s /usr/bin /usr/local/dboop/bin/dboop   (这句写错了)

ln --help

ln -s /usr/bin/ /usr/local/dboop/bin/dboop -f  (这句继续 错)

ll  ( WHAT?怎么出来个这玩意,心想,操,ln又写反了啊!!!)

rm -rf dboop

....

然后瞬间一激灵,觉得不对,/usr/bin目录下的所有文件都凉了。

啥也执行不了,yum wget  sudo ...全没了

 

恢复过程从其他机器 scp拷贝 /user/bin/目录过来

这里要注意的点:

别动机器上的其他服务(我这台测试机上当时还跑着nginx,uwsgis,celry,redis,mysql.....等服务) 一直能正常服务

别退出当前SHELL ,其他SHEELL登进来,会发现没有SUDO 了

从其他机器SCP过来时,可能会提示没有SCP文件,需要变通一下

 

拷过来的文件权限可能不对了

重要的是sudo权限乱了。

sudo -su 会报错:

sudo:有效用户 ID 不是 0,sudo 属于 root 并设置了 setuid 位吗?

 

这时候试了很多方法都不行,只能找系统部同事

chmod u+s /usr/bin/sudo

ln -s /usr/bin/sudo /usr/bin/sudoedit

 

就可以了,误删/user/bin目录 已经修复了

 

教训就是:

ln命令的源地址在前,目的地址在后

ln命令的源地址在前,目的地址在后

ln命令的源地址在前,目的地址在后

 

posted on 2017-12-12 11:30  51ak  阅读(853)  评论(0编辑  收藏  举报

导航