N22-第五周作业-冥界之王

1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;

   [root@CentOS6 ~]# cat /boot/grub/grub.conf | grep -E  "^[[:space:]]{1,}"

2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;

   [root@CentOS6 ~]# cat /etc/rc.d/rc.sysinit | grep -E "^#[[:space:]]{1,}[^[:space:]]"

3、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;

   [root@CentOS6 ~]# netstat -tan | grep "LISTEN[[:space:]]"

4、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

   [root@CentOS6 ~]# useradd bash
   [root@CentOS6 ~]# useradd testbash
   [root@CentOS6 ~]# useradd basher
   [root@CentOS6 ~]# useradd nologin -s /sbin/lologin

    2种方法找出当前系统上其用户名和默认shell相同的用户的信息

   [root@CentOS6 ~]# cat /etc/passwd | grep `echo $SHELL` | awk -F ":" '{printf "%s\n", $1}'
   [root@CentOS6 ~]# cat /etc/passwd | grep `echo $SHELL` | cut -d ":" -f1

5、显示当前系统上root、fedora或user1用户的默认shell;

   [root@CentOS6 ~]# cat /etc/passwd | grep -E "^\<root|^\<fedora|^\<user1" | cut -d ":" -f1,7
   [root@CentOS6 ~]# cat /etc/passwd | grep -E "^\<root|^\<fedora|^\<user1" | awk  -F ":" '{printf "%s:%s\n",$1,$7}'

6、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello();

   [root@CentOS6 ~]# cat /etc/rc.d/init.d/functions | grep  "\<[[:alnum:]].*\>()"

7、使用echo命令输出一个绝对路径,使用grep取出其基名;
    扩展:取出其路径名

   取出目录:  

   [root@CentOS6 yum.repos.d]# echo "/etc/yum.repos.d/CentOS-install.repo" | grep -E "^/.*/" --color -o

    取出文件名:

   [root@CentOS6 etc]# echo "/etc/yum.repos.d/CentOS-install.repo" | grep -E "[^/]+/?$" --color -o

8、找出ifconfig命令结果中的1-255之间数字; 

   [root@CentOS6 yum.repos.d]# ifconfig | grep -E "[1-9]|[1-9][0-9]|1[0-9]{1,2}|2[0-4][0-9]|25[0-5]" --color

9、挑战题:写一个模式,能匹配合理的IP地址;

   [root@CentOS6 ~]# ifconfig | grep -E "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)" --color -o

10、挑战题:写一个模式,能匹配出所有的邮件地址;   

   [root@CentOS6 ~]# echo "lihui@hotmai.com" | grep -E "^([a-zA-Z0-9_\-\.\+]+)@([a-zA-Z0-9_\-\.]+)\.([a-zA-Z]{2,5})$" --color -o

11、查找/var目录下属主为root,且属组为mail的所有文件或目录;
   
   2种方法:

   [root@CentOS6 ~]# ls -l /var | grep "root mail"
   [root@CentOS6 var]# find /var -user root -a -group mail -ls

12、查找当前系统上没有属主或属组的文件;
     进一步:查找当前系统上没有属主或属组,且最近3天内曾被访问过的文件或目录;

   [root@CentOS6 etc]# find / -nouser -o -nogroup -ls
   [root@CentOS6 etc]# find / \( -nouser -o -nogroup \) -atime -3

13、查找/etc目录下所有用户都有写权限的文件;

   [root@CentOS6 var]# find /etc/ -perm -222 -ls

14、查找/etc目录下大于1M,且类型为普通文件的所有文件;

   [root@CentOS6 etc]# ls -lh `find /etc/ -size +1M -a -type f`

15、查找/etc/init.d/目录下,所有用户都有执行权限,且其它用户有写权限的文件;

   [root@CentOS6 etc]# find /etc/init.d -perm 113 -o -type

16、查找/usr目录下不属于root、bin或hadoop的文件;

   [root@CentOS6 etc]# find /usr -not \( -user root -o -user bin -o -user hadoop \) -type f -ls

17、查找/etc/目录下至少有一类用户没有写权限的文件;

  [root@CentOS6 etc]# find /etc -not -perm 222 -type f -ls

18、查找/etc目录下最近一周内其内容被修改过,且不属于root或hadoop的文件;

  [root@CentOS6 etc]# find /etc -mtime -7 -not \( -user root -o -user hadoop \) -type f -ls

原创文章,作者:lihuisjsq,如若转载,请注明出处:http://www.178linux.com/44822

联系我们

400-080-6560

在线咨询

工作时间:周一至周五,9:30-18:30,节假日同时也值班

QR code