马哥教育网络20期+第五周课程练习

1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
[root@localhost ~]# grep "^[[:space:]]\+" /boot/grub/grub.conf
2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
[root@localhost ~]# grep "^#[[:space:]]\+[^[:space:]]\+" /etc/rc.d/rc.sysinit
3、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
[root@localhost ~]# netstat -tan |grep "LISTEN[[:space:]]\+"
4、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;
useradd bash
useradd testbash
useradd basher
useradd nologin -s /sbin/nologin
[root@localhost ~]# grep "^\([[:alnum:]]\+\>\).*\1$" /etc/passwd
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
bash:x:506:508::/home/bash:/bin/bash
nologin:x:509:511::/home/nologin:/sbin/nologin
5、显示当前系统上root、fedora或user1用户的默认shell;
[root@localhost ~]# grep "^root:" /etc/passwd|cut -d: -f 7
/bin/bash
6、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello();
[root@localhost ~]# grep "[[:alpha:]]\+()" /etc/rc.d/init.d/functions

blob.png

7、使用echo命令输出一个绝对路径,使用grep取出其基名;
  
正则方式
[root@localhost ~]# echo  /etc/rc.d/init.d/functions |grep -o "[^/]\+/\?$"
functions
[root@localhost ~]# echo  /etc/rc.d/init.d/functions/ |grep -o "[^/]\+/\?$"
functions/

扩展正则方式:
[root@localhost ~]# echo  /etc/rc.d/init.d/functions |grep -E -o "[^/]+/?$"
functions
[root@localhost ~]# echo  /etc/rc.d/init.d/functions/ |grep -E -o "[^/]+/?$"
functions/
  扩展:取出其路径名

8、找出ifconfig命令结果中的1-255之间数字;
[root@localhost ~]# ifconfig | grep -E '\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>' 
eth0      Link encap:Ethernet  HWaddr 00:0C:29:05:CC:1E  
          inet addr:192.168.1.212  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe05:cc1e/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX bytes:1296514 (1.2 MiB)  TX bytes:793749 (775.1 KiB)
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1

blob.png

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

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

11、查找/var目录下属主为root,且属组为mail的所有文件或目录;
[root@localhost mail]# find /var -user root -group mail
/var/spool/mail
/var/spool/mail/root
12、查找当前系统上没有属主或属组的文件;
[root@localhost tmp]# find / -nouser -o -nogroup
     进一步:查找当前系统上没有属主或属组,且最近3天内曾被访问过的文件或目录;
[root@localhost tmp]# find / -nouser -o -nogroup -a -atime -3
13、查找/etc目录下所有用户都有写权限的文件;
[root@localhost ~]# find /etc -perm -222
14、查找/etc目录下大于1M,且类型为普通文件的所有文件;
[root@localhost ~]# find /etc -size +1M -type f
15、查找/etc/init.d/目录下,所有用户都有执行权限,且其它用户有写权限的文件;
[root@localhost init.d]# find /etc/init.d -perm -113
16、查找/usr目录下不属于root、bin或hadoop的文件;
[root@localhost init.d]# find /usr -not -user root -a -not -user bin -not -user hadoop
[root@localhost init.d]# find /usr -not \( -user root -o -user bin -o -user hadoop \)
17、查找/etc/目录下至少有一类用户没有写权限的文件;
[root@localhost init.d]# find /etc -not -perm -222
18、查找/etc目录下最近一周内其内容被修改过,且不属于root或hadoop的文件;
[root@localhost ~]# find /etc  -not \( -user root -o -user hadoop \) -a -ctime -7
/etc/1.txt
[root@localhost ~]# ll /etc/1.txt
-rw-r--r--. 1 ricky root 4 Jul  3 21:42 /etc/1.txt

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

(0)
song0156song0156
上一篇 2016-07-07 10:40
下一篇 2016-07-07 10:41

相关推荐

  • linux基础1

    linux基础

    Linux干货 2018-03-08
  • vim编辑器进阶

    1、vim介绍    vim(Visual Interface Improved)是一款异常强大的文本编辑器,如果大家对它的认识还停留在编辑文件,再退出的阶段的话,那就太对不起vim了,反倒不如用nano来的爽快。不过学习vim刚开始的阶段必然是痛苦的,如果想要一蹴而就,那就是你想多了。所以还需大家结合实际情况,勤加练习,认真揣摩。这里是…

    Linux干货 2016-08-11
  • Linux文件类型及颜色标识

    文件类型(共7种): – :普通文件 d:目录文件 (directory) c:字符设备文件 (char) b:块设备文件 (block) s:本地域套接口 (socket) p:有名管道 (pipeline) l:符号连接 (link) 关于硬链接、软连接、复制之间的区别说明: 上图中,我为photo.png这个图片文件建立了一个拷贝(phot…

    Linux干货 2016-10-16
  • 马哥教育网络班22期+第01周课程练习

    一、描述计算机的组成及其功能:     根据冯·诺依曼体系结构,把计算机划分为五大部件:运算器、控制器、存储器、输入设备、输出设备。 运算器(加法器):cpu的核心部件,也是计算机存在的价值之一,其采用二进制方式进行计算(因为电阻的存在,使得十进制无法精准处理);控制器:控制CPU读指令[立即数和间接数],指令含有运算器需要的数…

    Linux干货 2016-08-12
  • 初学Linux之标准 I/O 和管道

    前面我们已经了解了文件系统的部分内容,我们可以通过 ls 命令让当前目录下的内容都显示在屏幕上,也可以使用 pwd 命令,显示当前的所在的目录路径。但是我们输入的是命令,本身并没有输入“显示”这类命令和要求,但是系统就自动的在屏幕上输出我们命令指定的信息。由此可以想象到,系统自身有默认的一种输出方式,同时,有输出就有输入,当输入的和系统无关,系统也会自动提示错误,以上就是我们接下来要了解的基础内容——标准 I/O。具体的涉及内容包括:三种 I/O 设备,把 I/O 重定向入文件,tr 命令的使用,使用管道链接命令。

    2017-12-02
  • 基于ssl的mysql的主从复制

    实验环境: system:CentOS Linux release 7.2.1511 (Core) mariadb server:mariadb-server-5.5.44-2.el7.centos.x86_64 master server:10.1.51.20/16 slave serv…

    2016-11-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-27 09:21

    写的很好,可以挑战一下挑战题的