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

(0)
lihuisjsqlihuisjsq
上一篇 2016-09-19
下一篇 2016-09-19

相关推荐

  • 8.16

    for 循环是相对比较简单的循环,任何一个循环里面都可以嵌套循环,用for可以解决简单逻辑上的任何循环 。 有两种基本格式:for i in " ";do         或者dor((i=0;i<=9;i++))可以嵌套if或者while等循环 if循环。最重要的是判断的条件,if意为如果什…

    Linux干货 2016-08-19
  • 5.程序包管理与内核命令的使用

    1、  显示/boot/grub/grub.conf中以至少一个空白字符开头的行; ~]#  grep -E “^[[:space:]]+” //boot/grub/grub.conf root (hd0,0) kernel /vmlinuz-2.6.32-279.el…

    Linux干货 2017-07-30
  • 硬链接与软链接的联系与区别

    硬链接与软链接的联系与区别     文件都有文件名与数据,这在 Linux 上被分成两个部分:用户数据 (user data) 与元数据 (metadata)。用户数据,即文件数据块 (data block),数据块是记录文件真实内容的地方;而元数据则是文件的附加属性,如文件大小、创建时间、所有者等信息。元数据中的inode才是…

    Linux干货 2016-10-20
  • 命令,Linux的独特魅力

    转眼又学了一个星期,那就来分享一下这个星期所学的知识吧! 这个星期学的都是各种命令,而这些命令就如同windoes里面画面上的各种选项,没有这些命令,那么你对它将无从下手。那下面就来看看这些命令的强大功能 help   man help(内部命令帮助),等同于man(外部命令帮助)。当你对一个命令不熟悉时,这两个命令将是你的救命符 选定一个命令,先…

    2017-07-22
  • 马哥教育网络班22期+第六周课程练习

    1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; ]# cp -v  /etc/rc.d/rc.sysinit /tmp/    `/etc/rc.d/rc.sysinit' -> `/tmp/rc.sysinit&…

    Linux干货 2016-10-17
  • 数据流重导向

    数据流重导向(redirect):就是将某个指令执行后应该要出现在屏幕上的数据,传输到其他的位置。 standard output:标准输出是指指令执行回传正确的讯息。 standard error output : 指令执行失败后,所回传的错误讯息。 1标准输入(stdin):代码为0,使用< <<2标准输出(stdout),代码为1,使…

    Linux干货 2016-08-08