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

相关推荐

  • Redis应用场景

    1.  MySql+Memcached架构的问题   实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加,和访问量的持续增长,我们遇到了很多问题:   1.MySQL需要不断进行拆库拆表,Memcached也需不断跟着扩容,扩容和维护工作占据…

    Linux干货 2016-03-22
  • 在马哥学习linux第一天的感受

         来马哥教育好几天了,昨天算是正式开始,在昨天早上,举行了开班典礼,各位老师助教为我们介绍了在马哥教育进行培训的相关注意事项,下午进行了两场测试,首先有一个摸底测试,不得不说我真的是太菜了,除了一些比较简单的题目我还有些把握,相当一部分我都是似曾相识,但是也不是很确定,还有很大一部分我根本听都没听说过,看到别人都写的满满…

    Linux干货 2017-07-11
  • shell练习

    1 、编写脚本/root/bin/systeminfo.sh, 显示当前主机系统信息, 包括主机名,IPv4 地址,操作系统版本,内核版本,CPU 型 号,内存大小,硬盘大小。 运行后结果是: 2 、编写脚本/root/bin/backup.sh ,可实现每日将/etc/ 目录备 份到/root/etcYYYY-mm-dd中 运行结果是: 3 、编写脚本/r…

    Linux干货 2016-08-15
  • lamp部署及编译安装

    lamp 资源类型: 静态资源:原始形式与响应给客户端的结果一致; 动态资源:原始形式通常为程序文件(为某种编程语言开发),需要运行后将生成的结果展示给客户端;如果请求的资源不存在那么结果就会重定向至指定的文件中 客户端技术:javascript 服务端技术:php, jsp, … CGI:Common Gateway Interfa…

    Linux干货 2016-10-19
  • keepalived的实验:主主模型

    修改配置文件 [root@proxy1 ~]# vim /etc/keepalived/keepalived.conf ! Configuration File for keepalived   global_defs { notification_email { root@localhost } notification_email_from k…

    2018-03-11
  • LAMP基于rsyslog+loganalyzer实现日志集中管理及分析

    前言 作为一名运维工程师,查看分析系统日志是每天必做的功课,但每次查看日志都得一台服务器一台服务器的看,几台服务器还可以这么对付,但如果管理成百上千台线上服务器,这种方法就捉襟见肘了。于是我们就需要用到日志服务器了,但是如何能让它更直观的显示呢?loganalyzer是一个不错的选择,本文将讲解如何使用rsyslog+loganalyze实现日志统一管理及分…

    Linux干货 2015-04-27