马哥教育网络班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

相关推荐

  • HA Cluster:keepalived

    HA Cluster 集群类型:LB(lvs/nginx(http/upstream, stream/upstream))、HA、HP 系统可用性的公式:A=MTBF/(MTBF+MTTR) 系统故障: 硬件故障:设计缺陷、wear out、自然灾害 软件故障:设计缺陷 提升系统高用性的解决方案之降低MTTR: 解决方案:冗余(redundant) acti…

    Linux干货 2017-06-26
  • HA高可用集群学习笔记

    前言   什么是HA?HA做什么用的?   HA(High Available)是高可用集群,是保证业务不中断性的有效解决方案;通常HA集群部署在多个节点,正在提供服务的节点成为活动节点,没有提供服务的是非活动节点;当活动节点发生故障,非活动节点会转为活动节点,向外提供服务,以保证业务的连续性;这就是HA。 一、HA(High Avail…

    Linux干货 2015-06-30
  • 加密解密基础、OpenSSL通信 及 搭建私有CA (Blog 11)

    加密解密技术基础、PKI及创建私有CA

    2017-11-29
  • Linux系统网络属性管理

        每台计算机主机连入internet都必须给主机设定以个合法的IP地址。这些IP参数大概包括IP地址、子网掩码、网关、路由、DNS等。在Linux中,大多数命令配置网络配置都是临时生效,想要网络服务永久有效就必须写入配置文件中,所以有时候更改配置重启主机是为了让内核重读配置文件到内核中,因为配置文件属于用户空间的文件。大多数网络配置…

    Linux干货 2016-09-18
  • N25-Week9

    1. 写一个脚本,判断当前系统上所有用户的shell是否为可登陆shell(即用户的shell不是/sbin/nologin);分别统计这两类用户的个数,通过字符串比较来实现 #! /bin/bash#写一个脚本,判断当前系统上所有用户的shell是否为可登陆shell(即用户的shell不是/sbin/nologin);#分别统计这两类用户的个数#通过字符…

    Linux干货 2017-03-10
  • Linux文件管理

    Linux文件管理 Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cd cd命令用来切换工作目录至dirname。 其中dirName表示法可为绝对路径或相对路径。若目录名称省略,则变换至使用者的home directory(也就是刚login时所在的目录)。另外,~也表示为home directory的意思,.则是表示目前所在的…

    2017-10-01

评论列表(1条)

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

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