php chmod -r 777,centos7下误执行chmod -R 777 /后的权限修复方法

今天由于权限问题zz一般把/usr/bin和/usr/lib两个目录用chmod -R 777执行了一遍,结果各种问题出现,su root就报su:鉴定故障的错误。然后上网找教程很多都要求在root权限下操作来修复,真是悔不当初,哭都哭不出来,只想剁手。幸好最好予以解决了,不然就真得重装系统了(那估计又是摸鱼几天来恢复系统),在此把解决方案记录下来,希望能给踩到坑的朋友抢救一下。

step1

新建一个.c文件,在这里我命名为chmodfix.c,把如下内容写到这个.c文件中

#include #include

#include

#include

#include

int list(const char *name, const struct stat *status, int type)

{

if(type == FTW_NS)

return 0;

printf("%s 0%3o\n", name, status->st_mode & 07777);

return 0;

}

int main(int argc, char *argv[])

{

if(argc == 1)

ftw(".", list, 1);

else

ftw(argv[1], list, 2);

exit(0);

}

然后在终端命令行下使用gcc编译得到可执行文件chmodfix.com

gcc chmodfix.c -o chmodfix.com

step2

新建一个.sh文件,在这里我命名为chmodfix.sh,把如下内容写到这个.sh文件中

#!/bin/sh if [ $# != 1 ]

then

echo Usage : $0 \

exit

fi

PERMFILE=$1

cat $PERMFILE | while read LINE

do

FILE=`echo $LINE | awk '{print $1}'`

PERM=`echo $LINE | awk '{print $2}'`

chmod $PERM $FILE

#echo "chmod $PERM $FILE"

done

echo "change perm finished! "

step3

找到另一台装有centos7并且系统权限正常的电脑,利用step1中得到的chmodfix.com从这台电脑上获取被你损坏的目录下所有文件的正常权限

# 假设原电脑上权限损坏的目录为/usr/bin

./chmodfix.com /usr/bin >> chmodfix.txt

输出文件chmodfix.txt的内容形式如下

/usr/bin 0755 /usr/bin/cp 0755 /usr/bin/lua 0755 /usr/bin/captoinfo 0755 /usr/bin/csplit 0755 /usr/bin/clear 0755 /usr/bin/cut 0755

将得到的权限文件chmodfix.txt复制到权限受损的电脑上

step4

这时候由于电脑权限损坏无法切换到root用户从而无法直接修改根目录下被损坏文件的权限,需要切换到centos的emergency mode(ubuntu的用户对应进入到recovery mode)。那么如何进入到emergency mode呢?开机启动的grub界面处对对应系统按下e键,就进入到如下画面

emergency%20mode.png

然后将上图中红圈标示的ro替换成rw init=/sysroot/bin/sh,然后根据底下提示按下ctrl+x启动系统则进入到emergency mode,首先执行命令chroot /sysroot以获取直接访问真实系统文件的权限,然后进入到chmodfix.sh和chmodfix.txt所存放的文件夹下,执行chmodfix.sh以根据chmodfix.txt恢复受损文件的正确权限

bash chmodfix.sh chmodfix.txt

由于涉及的文件可能很多,这个过程可能比较长,耐心等待一下,执行结束后在命令行下输入以下命令来重启系统

exit

reboot

结束

重启之后在终端下执行su root若能成功切换到root用户而没有提示su:鉴定故障的错误则表明文件修复成功,也可以通过ls -l file来查看文件权限

>ls -l /usr/bin/python

lrwxrwxrwx. 1 root root 7 2月 22 11:25 /usr/bin/python -> python2

血淋淋的教训(一怒之下险些要重装系统了),通过这篇日志把此次重大事故记录下来,希望能帮助到同我一样踩到雷的朋友顺利解决。同时,吃一堑长一智以后可不能再随便使用chmod -R 777修改大批量系统文件的权限,也望各位引以为鉴。

chmod -R 777是一个Linux命令,用来改变一个目录下所有文件的权限。其中-R参数表示递归遍历子目录,将权限改变应用于所有文件和子目录。而777权限的一种表示方式,表示所有用户都具有读、写、执行权限。这个命令的作用是将当前目录下的所有文件都赋予最高权限。需要注意的是,在服务器上使用这个命令需要谨慎,因为有些进程的运行需要指定特定的权限,如果随意更改权限可能会导致一些问题发生。此外,在根目录下进行此命令的操作也是不被推荐的,因为根目录下的文件和目录通常有特定的权限要求。所以在使用chmod -R 777命令时需要谨慎操作,确保了解对系统和文件的影响。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Linux下权限问题:chmod -R 777 /usr](https://blog.csdn.net/wangliqiang1014/article/details/78076714)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Linux:chmod -R 777 *含义](https://blog.csdn.net/weixin_44760073/article/details/127175407)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值