RHCE——十七、文本搜索工具-grep、正则表达式

RHCE

一、文本搜索工具--grep

1、作用

  • grep是linux中一种强大的文件搜索过滤工具,可以按照正则表达式检索文件内容,并把匹配的结果显示到屏幕上(匹配的内容会标红)

2、格式

bash 复制代码
grep   -参数   条件  文件名

3、参数

bash 复制代码
-i      忽略大小写
-c      统计匹配的行数
-v      取反,不显示匹配的行
-w		匹配单词
-E		等价于egrep,即启用扩展正则表达式
-n		显示行号
-rl		将指定目录内的文件打印
-A数字   匹配行及以下n行
-B数字   匹配行及以上n行
-C数字   匹配行及上下n行
-q		静默模式,没有任何内容输出,使用$?来判断是否执行成功
-o      只显示匹配的内容

4、注意

  • 工作方式:grep可以在一个或多个文件中检索,如果条件中包含了空格,需要使用双引号引起
  • 工作结果:如果搜索成功则返回0状态码,否则为1状态码

5、示例

5.1 操作对象文件:/etc/passwd

  • 作用:记录账户的信息,共分为7段,使用冒号分割
  • 意义:账户名:密码代号x:UID:GID:注释:家目录:登录的Shell
  • 注意:最后一段/sbin/nologin表述不允许登录

5.2 grep过滤命令示例

bash 复制代码
[root@server ~]# grep  -n  "root"  /etc/passwd
[root@server ~]# grep  -n  "sshd"  /etc/passwd
[root@server ~]# grep  -n  "/sbin/nologin"  /etc/passwd
[root@server ~]# grep  -c  "/bin/bash"  /etc/passwd
[root@server ~]# grep    "/bin/bash"  /etc/passwd  | wc -l
[root@server ~]# grep  -nv  "/sbin/nologin"  /etc/passwd
[root@server ~]# grep  -ni  "d"  /etc/passwd
[root@server ~]# grep  -nA2  "ftp"  /etc/passwd
[root@server ~]# grep  -nB3  "ftp"  /etc/passwd
[root@server ~]# grep  -nC3  "ftp"  /etc/passwd


二、正则表达式

1、概念

  • 在进行程序设计的过程中,用户会不可避免地遇到处理某些文本的情况。有的时候,用户还需要查找符合某些比较复杂规则的字符串。对于这些情况,如果单纯依靠程序设计语言本身,则往往会使得用户通过复杂的代码来实现。但是,如果使用正则表达式,则会以非常简短的代码来完成

  • 正则表达式是通过一些特殊字符的排列,用以查找、替换、删除一行或多行文字字符串,简单的说,正则表达式就是用在字符串的处理上面的一项表示式。由于正则表达式语法简练,功能强大,得到了许多程序设计语言的支持,包括Java、C++、Perl以及Shell等

2、基本正则表达式

  • 基本正则表达式(Basic Regular Expression,BRE),又称为标准正则表达式,是最早制订的正则表达式规范,仅支持最基本的元字符集。基本正则表达式是POSIX规范制订的两种正则表达式语法标准之一,另外一种语法标准称为扩展正则表达式

2.1 常见元字符

元字符 说明
^ 以某个字符开头 或 行首
$ 以某个字符结尾 或行尾
. 匹配任意单字符
***** 对前一项进行0次或者多次重复匹配
{m,n} 将前一项字符重复m-n次,{m,},{,n},{m,n}
[] 对方括号内的单字符进行匹配
[^] 不匹配方括号内的单字符
^[] 匹配以某个字符开头的行
() 定义一个子表达式
词首【\<或\b】和词尾锚定【\>或者\b】 其后面的任意字符必须作为单词首部出现;其前面的任意字符必须作为单词尾部出现
\ 转义字符,让一些特殊符号失效

2.2 POSIX字符类

  • POSIX字符类是一个形如[:...:]的特殊元序列(meta sequence),他可以用于匹配特定的字符范围
正则表达式 描述 示例
[:alnum:] 匹配任意一个字母或数字字符 [[:alnum:]]+
[:alpha:] 匹配任意一个字母字符(包括大小写字母) [[:alpha:]]
[:blank:] 空格与制表符(横向和纵向) [[:blank:]]*
[:digit:] 匹配任意一个数字字符 [[:digit:]]?
[:lower:] 匹配小写字母 [[:lower:]]
[:upper:] 匹配大写字母 ([[:upper:]]+)?
[:punct:] 匹配标点符号 [[:punct:]]
[:space:] 匹配一个包括换行符、回车等在内的所有空白符 [[:space:]]+
[:graph:] 匹配任何一个可以看得见的且可以打印的字符 [[:graph:]]
[:xdigit:] 任何一个十六进制数(即:0-9,a-f,A-F) [[:xdigit:]]+
[:cntrl:] 任何一个控制字符(ASCII字符集中的前32个字符) [[:cntrl:]]
[:print:] 任何一个可以打印的字符 [[:print:]]

2.3 示例

  • [ab] : 检索包含a或者b的行信息,[]只能包含一个内容
bash 复制代码
[root@server ~]# grep  -n  [dD]  /etc/passwd
[root@server ~]# grep  -n  [oo]  /etc/passwd


  • [^]:根据关键字反向显示(反向着色)
bash 复制代码
[root@server ~]# grep  -n  [^o]  /etc/passwd
[root@server ~]# grep  -n  [^r]oot  /etc/passwd


  • [-]:表示范围,如:[0-9] [a-z] [A-Z] [a-zA-Z]
bash 复制代码
[root@server ~]# grep  -nw  [7-9]  /etc/passwd
[root@server ~]# grep  -n  [A-Z]  /etc/passwd
[root@server ~]# grep  -n  [A-G]  /etc/passwd
[root@server ~]# grep  -n  [0-9A-Za-z]  /etc/passwd
[root@server ~]# grep  -n  [[:alnum:]]  /etc/sos/sos.conf 




  • ^行首与$行尾
bash 复制代码
[root@server ~]# grep -n  ^root  /etc/passwd
[root@server ~]# grep  -n  ^#  /etc/sos/sos.conf   # 检索注释行
[root@server ~]# grep  -n  "^\["  /etc/sos/sos.conf 
[root@server ~]# grep  -n  "[0-9]$"   /etc/sos/sos.conf 
[root@server ~]# grep  -n  "^$"   /etc/sos/sos.conf 
# 注意:
[root@server ~]# grep  -n  ^[root]  /etc/passwd # 检索以r或o或t开头的不是root开头
[root@server ~]# grep  -n  ^root  /etc/passwd  # 整体对待
[root@server ~]# grep  -n  [^root]  /etc/passwd  # 检索不包含r或不包含o或不包含t,进行反向着色,注意:^[] 与  [^] 区别



  • 点(.)与星号(*)
bash 复制代码
[root@server ~]# grep  -n  r..t  /etc/passwd
[root@server ~]# grep  -n  ooo*    /etc/passwd
[root@server ~]# grep  -n  "\."    /etc/passwd
  • {m,n} 区间
bash 复制代码
[root@server ~]# grep  -n  "\<[0-9]\{2\}\>"  /etc/passwd
# {m,n}  描述区间

3、扩展正则表达式

3.1 概念

  • 扩展正则表达式(Extended Regular Expression,ERE)支持比基本正则表达式更多的元字符,但是扩展正则表达式对有些基本正则表达式所支持的元字符并不支持。前面介绍的元字符"^"、"$"、"."、"*"、"[]"以及"[^]"这6个元字符在扩展正则表达式都得到了支持,并且其意义和用法都完全相同,不再重复介绍。接下来重点介绍一下在扩展正则表达式中新增加的一些元字符。
元字符 说明
? 将前一项字符进行0次或者1次的重复匹配
+ 将前一项进行1次或者多次的重复匹配
(|) 匹配|符号左边或者右边的字符

3.2 示例

bash 复制代码
[root@server ~]# grep  -n  "bash$"  /etc/passwd
[root@server ~]# grep  -n  "\<[[:digit:]]\{3,4\}\>"  /etc/passwd
[root@server ~]# grep  -n  "\<[0-9]\{3,4\}\>"  /etc/passwd
[root@server ~]# egrep  -n  "^[[:space:]]+[^[:space:]]"  /etc/grub2.cfg 
[root@server ~]# grep  -nE  "^[[:space:]]+[^[:space:]]"  /etc/grub2.cfg 
[root@server ~]# grep  -n  "^[[:space:]]\+[^[:space:]]"  /etc/grub2.cfg 
# 注意:grep不支持扩展正则(? + (|)),要想生效,可以使用上述三种方法




bash 复制代码
# 将netstat  -tan显示结果中以LISTEN开头后跟0个或多个空白字符结尾的行信息
[root@server ~]# netstat  -tan  |  grep  "LISTEN[[:space:]]*$"
# 检索fdisk -l 命令结果中,包含/dev/开头后跟上n的行信息
[root@server ~]# fdisk -l  |  grep  "^/dev/n"
# 显示/etc/passwd中包含root、sshd、chrony的相关信息
[root@server ~]# egrep  -n  "(root|sshd|chrony)"  /etc/passwd
[root@server ~]# grep   -nE  "(root|sshd|chrony)"  /etc/passwd
# 检索ifconfig显示信息中结果为1-255间的整数
[root@server ~]# ifconfig |  egrep -o  "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]  )\>"   
# 取出echo输出的绝对路径名中的文件名
[root@server ~]# echo  /etc/yum.repos.d   |  egrep  [^/]+/?$


三、作业

1、作业一

编写脚本for1.sh,使用for循环创建20账户,账户名前缀由用户从键盘输入,账户初始密码由用广输入,例如: test1、test2、test3、...、 test10

  • 第一步,创建并编写脚本
bash 复制代码
[root@server ~]# vim for1.sh
  • 第二步、执行并查看:
bash 复制代码
[root@server ~]# bash for1.sh 
请输入用户账户名前缀: test
请输入用户的密码: 123456
[root@server ~]# cat  /etc/passwd  |  tail  -20

2、作业二

编写脚本for2.sh,使用for循环,通过ping命令测试网段的主机连通性,IP前3段由用户输入,如: 输入192.168.48 ,则pin 192.168.48.125 - 192.168.48.135,将可以ping通的主机IP地址写入到 /tmp/host_up.txt文件中,不能ping通的主机IP地址写入到: /tmp/host_down.txt文件中

  • 第一步、创建并修改脚本文件
bash 复制代码
[root@server ~]# vim for2.sh
  • 第二步、执行并查看
bash 复制代码
[root@server ~]# bash for2.sh 
请输入网段:192.168.13
up ip: 
192.168.13.134 is up

down ip :
192.168.13.125 is down
192.168.13.126 is down
192.168.13.127 is down
192.168.13.128 is down
192.168.13.129 is down
192.168.13.130 is down
192.168.13.131 is down
192.168.13.132 is down
192.168.13.133 is down
192.168.13.135 is down
[root@server ~]# cat /tmp/host_down.txt 

3、作业三

使用for循环实现批量主机root密码的修改

  • (1) 打开多台主机
  • (2) 使用ssh-keygen命令建立密钥对
  • (3) 多台主机间通过ssh-copy-id进行免密登录(4) 编写脚本for3.sh,通过for循环登录主机修改对方root账户密码

步骤:

  • 第一步:首先打开三台安装好的虚拟机:
  • 第二步、再主虚拟机上进行记录其他两台机子的IP地址:
bash 复制代码
[root@server ~]# vim ip.txt
  • 第三步、三台主机生成密钥对
    server

    NODE1:

    NODE2:
  • 第四步、将生成的密钥对进行上传:
bash 复制代码
[root@server ~]# ssh-copy-id  root@192.168.13.135
[root@server ~]# ssh-copy-id  root@192.168.13.136
  • 第五步、创建并修改脚本
bash 复制代码
[root@server ~]# vim for3.sh
  • 第六步,执行脚本:
bash 复制代码
[root@server ~]# bash for3.sh 
请输入密码:123       
更改用户 root 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 root 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[root@server ~]# 
相关推荐
明月看潮生16 分钟前
青少年编程与数学 02-003 Go语言网络编程 15课题、Go语言URL编程
开发语言·网络·青少年编程·golang·编程与数学
wowocpp27 分钟前
ubuntu 22.04 硬件配置 查看 显卡
linux·运维·ubuntu
jjyangyou29 分钟前
物联网核心安全系列——物联网安全需求
物联网·算法·安全·嵌入式·产品经理·硬件·产品设计
萨格拉斯救世主1 小时前
jenkins使用slave节点进行node打包报错问题处理
运维·jenkins
川石课堂软件测试1 小时前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
‍。。。1 小时前
使用Rust实现http/https正向代理
http·https·rust
龙哥说跨境1 小时前
如何利用指纹浏览器爬虫绕过Cloudflare的防护?
服务器·网络·python·网络爬虫
AltmanChan1 小时前
大语言模型安全威胁
人工智能·安全·语言模型
马船长1 小时前
红帆OA iorepsavexml.aspx文件上传漏洞
安全
懒大王就是我1 小时前
C语言网络编程 -- TCP/iP协议
c语言·网络·tcp/ip