grep的基本理解
文本搜索工具,通过正则表达式及文本字符编写的过滤条件进行搭配来对文本进行匹配检查,打印匹配并输出结果。
grep基本选项
#语法
grep[OPTIONS]PATTERN[FILE...]
#基本选项
grep-I不区分大小写
grep-v取反
grep-n显示行号
grep-c显示匹配的有多少行
grep-o只显示匹配的字符或其他
grep-q静默模式就是不显示匹配的结果,什么都不显示
用echo%?得出上一条命令的结果
0为正确输出
非0位错误的命令输出
Grep-A{number}匹配结果行后几行
Grep-B{number}匹配结果前几行
Grep-C{number}匹配结果的前后几行
Grep-e关键字-e关键字多个关键字作为匹配条件(不限制说一定要匹配前后,匹配前后其中一个)
Grep-w匹配整个单词不包含包括
grep应用实例
1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用两种方式)
[root@localhost~]#grep-i"^s"/proc/meminfo
SwapCached:64kB
SwapTotal:2097148kB
SwapFree:2091288kB
Shmem:6016kB
Slab:228152kB
SReclaimable:153116kB
SUnreclaim:75036kB
[root@localhost~]#grep-e"^S"-e"^s"/proc/meminfo
SwapCached:64kB
SwapTotal:2097148kB
SwapFree:2091288kB
Shmem:6016kB
Slab:228152kB
SReclaimable:153116kB
SUnreclaim:75036kB
2、显示/etc/passwd文件中不以/bin/bash结尾的行
[root@localhost~]#grep-v"/bin/bash$"/etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTPUser:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
avahi-autoipd:x:170:170:AvahiIPv4LLStack:/var/lib/avahi-autoipd:/sbin/nologin
systemd-bus-proxy:x:999:997:systemdBusProxy:/:/sbin/nologin
systemd-network:x:998:996:systemdNetworkManagement:/:/sbin/nologin
dbus:x:81:81:Systemmessagebus:/:/sbin/nologin
3、显示用户rpc默认的shell程序
[root@localhost~]#grep"brpcb"/etc/passwd|cut-d:-f7
/sbin/nologin
4、找出/etc/passwd中的两位或三位数
[root@localhost~]#grep"b[[:digit:]]{2,3}b"/etc/passwd
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTPUser:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
avahi-autoipd:x:170:170:AvahiIPv4LLStack:/var/lib/avahi-autoipd:/sbin/nologin
systemd-bus-proxy:x:999:997:systemdBusProxy:/:/sbin/nologin
systemd-network:x:998:996:systemdNetworkManagement:/:/sbin/nologin
dbus:x:81:81:Systemmessagebus:/:/sbin/nologin
polkitd:x:997:995:Userforpolkitd:/:/sbin/nologin
colord:x:996:994:Userforcolord:/var/lib/colord:/sbin/nologin
5、显示/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面存非空白字符的行
[root@localhost~]#grep"^[[:space:]]+[^[:space:]].*"/etc/grub2.cfg
load_env
setdefault="${next_entry}"
setnext_entry=
save_envnext_entry
setboot_once=true
setdefault="${saved_entry}"
menuentry_id_option="--id"
menuentry_id_option=""
setsaved_entry="${prev_saved_entry}"
save_envsaved_entry
setprev_saved_entry=
save_envprev_saved_entry
setboot_once=true
if[-z"${boot_once}"];
6、找出"netstat -tan"命令的结果中以'LISTEN'后跟0、1或多个空白字符结尾的行
[root@localhost~]#netstat-tan|grep"LISTEN[[:space:]]*$"
tcp00192.168.122.1:530.0.0.0:*LISTEN
tcp000.0.0.0:220.0.0.0:*LISTEN
tcp00127.0.0.1:6310.0.0.0:*LISTEN
tcp00127.0.0.1:250.0.0.0:*LISTEN
tcp00127.0.0.1:60100.0.0.0:*LISTEN
tcp600:::22:::*LISTEN
tcp600::1:631:::*LISTEN
tcp600::1:25:::*LISTEN
tcp600::1:6010:::*LISTEN
7、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin),而后找出/etc/passwd文件中用户名同shell名的行
[root@localhosttestdir]#grep"^(&;.*&;).*/1$"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:1001:1001::/home/bash:/bin/bash
nologin:x:1004:1004::/home/nologin:/sbin/nologin
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!