马哥教育网络班21期-第五周课程练习

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

# grep -E "^[[::space]]\+.*" /boot/grub/grub.conf

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

# grep -E "^#[[:space:]]\+[^[:space:]]\+.*" /etc/rc/d/rc.sysinit

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

# netstat -tan | grep -E "LISTEN[[:space:]]\+$"

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

#!/bin/bash
if [ `id -u` -ne 0 ];then
   echo "noly root can add user."
   exit 3
fi
for user in {bash,testbash,basher,nologin};do
    if id $user &> /dev/null;then
       echo "$user exits. "
    elif [ "$user" == "nologin" ];then
       useradd $user -s /sbin/nologin 
    else useradd $user 
    fi
done
grep -E --color "^([[:alnum:]]+)\>.*\1$"  /etc/passwd

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

#!/bin/bash
for i in (root,fedora,user1);do
    grep "^$i\>" /etc/passwd | cut -d: -f1,7
done

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

# grep -E "\b.*\b\(\)" /etc/rc.d/init.d/functions

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

#!/bin/bash
read -p "enter a path." pathfile
   [ -z "$pathfile" ] && echo "please enter a path." && exit 1
echo $pathfile > /tmp/pathfile
echo  basename is `grep -o "/[^/]\+/\?$" /tmp/pathfile`
echo  dirname is `grep -o "^/.*/" /tmp/pathfile`

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

# ifconfig | grep -E "\b[1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5]\b"

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

# grep  -Eo "\b(inet |addr:)([0-9]{1,3}.){3}[0-9]{1,3}\b"

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

# grep -Eo "[[:alnum:]]+[[:punct:]]*[[:alnum:]]*@[[:alnum:]]+.[[:alnum:]]*.?[[:alnum:]]*"

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

# find /var -user root -group mail

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

# find / -nouser -nogroup -atime -3

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

# find /etc -perm /222

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

 # find /etc -size +1M -type f

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

# find /etc/init.d -prem -113

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

# find /usr -not (-user root -a -user bin -a hadoop)

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

# find /etc -not -perm -222

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

# find /etc -mtime -7 -not (-user root -a -user hadoop)

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

(0)
哎哟喂哎哟喂
上一篇 2016-08-08 16:16
下一篇 2016-08-08 16:16

相关推荐

  • 第六周作业

    请详细总结vim编辑器的使用并完成以下练习题 光标跳转 字符间跳转 h或向左箭头键 光标向左移动一个字符 j或向下箭头键 光标向下移动一个字符 k或向上箭头键 光标向上移动一个字符 l或向右箭头键 光标向右移动一个字符 翻屏 Ctrl+f 屏幕向下移动一页 Ctrl+b 屏幕向上移动一页 Ctrl+d 屏幕向下移动半页 Ctrl+u 屏幕向上移动半页 Ent…

    Linux干货 2017-01-22
  • Windows与linux分区的区别:

        对于我们普通人来讲,分区就是我们看到的“我的电脑”下面的C盘、D盘、E盘······,每个分区都有自己的区域,无法使用别的分区的空间,这样可以起到保护分区中文件的作用。其实,这样很容易理解。可是,对于linux初学者来讲,因为使用习惯了windows,到了linux下面,一下子很难转换过来。  &nb…

    2017-07-16
  • 磁盘管理和高级文件系统管理-习题

    高级文件系统管理-习题 1、 创建一个可用空间为40G 的RAID1 设备,要求其chunk大小为128k ,文件系统为ext4 ,有一个空闲盘,开机可自动挂载至/backup目录 [root@centos7 ~]# mdadm -C /dev/md0 -c 128 -a yes -l 1 -n 2 -x 1 /dev/sdb /dev/sdc /dev/s…

    Linux干货 2016-09-01
  • 制作引导分区

      使用虚拟机制作一个可以引导启动的简单系统。方法如下:   一、制作两个分区     1、添加一块新的硬盘,新建两个分区,格式化并挂载到/mnt/boot和/mnt/sysroot目录中;虚拟机添加硬盘的操作很简单就不做演示了,要注意的是添加的硬盘最好选择成“将虚拟磁盘存储为单个个文件”,并为将文件名修改为容易识别的…

    Linux干货 2016-01-18
  • N22+北京+张zhangzhang+第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 who | cut -d" " -f1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 id `who | cut -d" " -f1 | tail -1` 3、取出当前系统上被用户当作其默认shell的最多的…

    Linux干货 2016-09-05
  • bash特性

    2018-03-11

    2018-03-11

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 14:38

    写的很好,排版也很棒,加油,匹配ip地址的不对