很早之前(当时还dc4.1的时候)就听mlsx说在用户那边碰到用户chmod 777 -r /;chown root.root -r /之后系统无法启动,然后通过写脚本从另一台正常的机器上获得所有文件的权限和属主组,并在救援模式下将出问题的机器上所有文件设置正常。后来很长时间我都想:如何写这个脚本呢?如何将rwxrwxrwx转换成777或者交给chmod用呢?因为没有真实遇到这个问题,所以一直没有动手写这个脚本,也没有跟mlsx要这个脚本。
这两天终于遇到了,一模一样的操作。解决起来却很简单,如果不想看之前相关技术,可以直接跳到文章末尾。 上周和琦文去上地那边解决一个ha,周五让他们chmod 777 -r /;chown root.root -r /给搞瘫痪了。本来我感觉系统都启动不了,不过现场是系统能启动(看来ax3已经比dc4.1健壮很多了),只是ha启动不了了。日志中有一些权限不够的提示,让他们将提示的一些文件对着正常的机器修改过来,不过还是不正常。
今天早上看到邮件是drbd有问题,日志已经不报权限不足了。我想到之前mlsx说过在中组部遇到过类似的情况,他当时从另一台机器获得所有文件的属主组和权限,在这边设置上去就可以了。先在网上搜索了一下,发现有一个人提供了一个简单将rwxrwxrwx换算成777的脚本:
- fan3838@fan3838-hp-425:~$ cat aa.sh
- #!/bin/ksh
- typeset aa=`ls -dl e1000*|awk '{print substr($1, 2)}'|sed 's/-/0/g'|sed 's/r/1/g'|sed 's/w/1/g'|sed 's/x/1/g'`
- typeset bb=$(echo "obase=8;ibase=2;$aa"|bc)
- echo $bb
然后我修改了一下,基本可以实现,不过当有suid位的时候就会发生错误,取不出来。修改结果如下:
- fan3838@fan3838-hp-425:~$ cat getmod.sh
- #!/bin/sh
- #by dffan@redflag-linux.com
- find /etc -ls |awk '{print $11"_g_"$3"_g_"$5"_g_"$6}'>/tmp/list.txt
- for i in `cat /tmp/list.txt`
- do
- file_name=`echo $i|awk -f_g_ '{print $1}'`
- mod8=`echo $i|awk -f_g_ '{print substr($2, 2)}'|sed 's/-/0/g'|sed 's/r/1/g'|sed 's/w/1/g'|sed 's/x/1/g'`
- mod=$(echo "obase=8;ibase=2;$mod8"|bc)
- own=`echo $i|awk -f_g_ '{print $3":"$4}'`
- echo "chmod $mod $file_name" >>changemod.sh
- echo "chown $own $file_name" >>changemod.sh
- chmod x changemod.sh
- done
再在网上一搜索,发现有人提供一个c脚本能正确实现获取权限位,suid都能正确获取:
- fan3838@fan3838-hp-425:~$ cat get.c
- #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, 1);
- exit(0);
- }
不过呢,光获取权限之外,还有属主组信息呢,这些信息还需要通过shell取出来,比较麻烦。
再后来发现可以用getfacl和setfacl设置用户的属主组和权限,简单很多,只不过suid需要单独处理一下:
- 在ha1正常机上执行
- getfacl / -r >/root/facl.txt
- find / -type f -perm -04000 >/root/file400.txt
- find / -type f -perm -02000 >/root/file200.txt
- 将ha1上/root下的 facl.txt, file400.txt, file200.txt三个文件拷贝到ha2的/root目录下
- 在ha2上执行
- cd /
- setfacl --restore=/root/facl.txt
- 在ha2上下载附件changemod.sh脚本到/root目录下
- cd /root
- dos2unix changemod.sh
- chmod x changemod.sh
- ./changemod.sh
- 所有操作执行完毕之后,ha2将与ha1中文件的权限属主组完全相同。
- fan3838@fan3838-hp-425:~$ cat /tmp/changemod.sh
- #!/bin/bash
- for i in `cat /root/file400.txt`
- do
- chmod u s $i
- done
- for j in `cat /root/file200.txt`
- do
- chmod g s $i
- done
- chmod o t /tmp /var/tmp
阅读(6324) | 评论(0) | 转发(1) |