CentOS中grep命令的问题?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CentOS中grep命令的问题?相关的知识,希望对你有一定的参考价值。

CentOS 一直提示 grep command not found
但是运行yum install grep 后,显示已安装。
我看了一下,bin目录下确实没有grep了,只有egrep,xzgrep等,哪位知道要怎么办?

常规情况下grep命令是在/usr/bin目录下,你可以使用which grep 或者where's grep 查找到这个执行命令的所在地。
你这个是丢失了grep命令,你可以先把已经有的frep卸载了,然后重新装一次应该就可以了,yum remove grep -y。
如果安装没有问题,你就可以正常使用了。
参考技术A [root@yumserver ~]# whereis grep
grep: /usr/bin/grep /usr/share/man/man1/grep.1.gz

[root@yumserver ~]# /usr/bin/grep --help
用法: /usr/bin/grep [选项]... PATTERN [FILE]...
如果你找到了文件,说明你的PATH环境变量设置被改过,丢失了/usr/bin/的路径设置。原因你自己再找找,是不是设置过什么profile文件。
如果你找不到这个文件,说明你可能误操作删除了,那么你可以这么操作:
yum reinstall -y grep
参考技术B 可能是失误操作丢失了关键文件,重新卸载重新安装一下应该就可以了。《Linux就该这么学》不错的Linux自学书籍 不懂得可以看看追问

请问是重装系统还是重装grep呀?不重装系统的话,有没有其他简便的方法或修复命令呀?

Linux CentOS 7 中grep的使用

9.1 正则介绍_grep上

(1)什么是正则

正则就是一串有规律的字符串。
掌握好正则对于shell有很大帮助。
各种语言都有正则,原理是一样的。
主要命令有:grep/egrep sed awk。

(2)grep

grep 过滤指定关键字
grep [-cinvrABC] ‘word‘ filename
grep -c 显示一共包含关键字的行数
grep -n 显示一共包含关键字的行号
grep -i 不区分大小写grep -v 取反
grep -r 遍历所有子目录
grep -A 后面根数字,过滤出符合要求的行以及下面的n行
grep -B 后面根数字,过滤出符合要求的行以及上面的n行
grep -C 后面根数字,过滤出符合要求的行以及上下面的n行
[[email protected] ~]# grep -c root /etc/passwd
2
[[email protected] ~]#
[[email protected] ~]# grep -n root /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
10:operator:x:11:0:operator:/root:/sbin/nologin
[[email protected] ~]#
[[email protected] ~]# grep -vn root /etc/passwd
2:bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
6:sync:x:5:0:sync:/sbin:/bin/sync
7:shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
8:halt:x:7:0:halt:/sbin:/sbin/halt
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
11:games:x:12:100:games:/usr/games:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
13:nobody:x:99:99:Nobody:/:/sbin/nologin
[[email protected] tmp]# grep -i root 1.txt 
1root:x:0:0:root:/root:/bin/bash
1ROOT:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator:/root:/sbin/nologin
[[email protected] tmp]#[[email protected] ~]# grep -r root /tmp/
/tmp/history_bak.log:      1 ./root/shell/mail.sh 111 111
/tmp/history_bak.log:      1 /bin/grep root /etc/passwd
/tmp/history_bak.log:      2 /usr/local/mysql/bin/mysql -u root -p
/tmp/history_bak.log:      1 /usr/local/mysql/bin/mysqldump -u root -p 
/tmp/history_bak.log:      1 /usr/local/mysql/bin/mysqldump -u root -p password "qing123."
/tmp/history_bak.log:      1 awk "/root/" 1.txt
/tmp/history_bak.log:      1 awk "/root|fxq/" 1.txt
/tmp/history_bak.log:      1 awk /root|fxq/ 1.txt
/tmp/history_bak.log:      1 cat /etc/passwd | grep root
/tmp/2.txt:1root:x:0:0:root:/root:/bin/bash
/tmp/2.txt:operator:x:11:0:operator:/root:/sbin/nologin
/tmp/1.txt:1root:x:0:0:root:/root:/bin/bash
/tmp/1.txt:operator:x:11:0:operator:/root:/sbin/nologin
[[email protected] ~]# grep -nA2 root /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
2-bin:x:1:1:bin:/bin:/sbin/nologin
3-daemon:x:2:2:daemon:/sbin:/sbin/nologin
--10:operator:x:11:0:operator:/root:/sbin/nologin
11-games:x:12:100:games:/usr/games:/sbin/nologin
12-ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
[[email protected] ~]# 
[[email protected] tmp]# grep -nB2 root /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
--
8-halt:x:7:0:halt:/sbin:/sbin/halt
9-mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
10:operator:x:11:0:operator:/root:/sbin/nologin
[[email protected] tmp]#
 [[email protected] tmp]# grep -nC2 root /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
2-bin:x:1:1:bin:/bin:/sbin/nologin
3-daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
8-halt:x:7:0:halt:/sbin:/sbin/halt
9-mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
10:operator:x:11:0:operator:/root:/sbin/nologin
11-games:x:12:100:games:/usr/games:/sbin/nologin
12-ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
[[email protected] tmp]#

9.2 grep中

grep -n ‘root‘ /etc/passwd
grep -nv ‘root‘ /etc/passwd
grep ‘[0-9]‘ /etc/inittab    过滤带数字的行
grep -v ‘[0-9]‘ /etc/inittab  过滤不包含数字化的行
grep -v ‘^#‘ /etc/inittab  过滤以非#开头行
grep ‘^[^a-zA-Z]‘ test.txt 过滤以非字母开头的行
[[email protected] tmp]# grep ‘[0-9]‘ /etc/passwd
root:x:0:0:root:/root:/bin/bash
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
[[email protected] tmp]# grep -vn ‘[0-9]‘ /etc/inittab 
1:# inittab is no longer used when using systemd.
2:#
3:# ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.
4:#
5:# Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target
6:#
7:# systemd uses ‘targets‘ instead of runlevels. By default, there are two
 main targets:
 8:#
 11:#
 12:# To view current default target, run:
 13:# systemctl get-default
 14:#
 15:# To set a default target, run:
 16:# systemctl set-default TARGET.target
 17:#
 [[email protected] tmp]# 
 [[email protected] tmp]# grep -nv ‘^#‘ 1.txt
 4:33335:11116:1root:x:0:0:root:/root:/bin/bash
 7:1ROOT:x:0:0:root:/root:/bin/bash
 8:bin:x:1:1:bin:/bin:/sbin/nologin

9.3 grep下

grep ‘r.o‘ test.txt .匹配任意一个字符
grep ‘oo*‘ test.txt * 匹配*前面的字符任意次 (>=0)
grep ‘.*‘ test.txt   .* 匹配任意个任意字符
grep ‘o\{2\}‘ /etc/passwd 
grep -E ‘o{2}‘ /etc/passwd
egrep ‘o{2}‘ /etc/passwd
egrep ‘o+‘ /etc/passwd  + 匹配+前面的1次或多次 (>=1)
egrep ‘oo?‘ /etc/passwd ?匹配?前面字符0或者1次 (0或1)
egrep ‘root|nologin‘ /etc/passwd  匹配root或nologin
egrep ‘(oo){2}‘ /etc/passwd  范围
[[email protected] tmp]# egrep ‘o{2}‘ /etc/passwd
root:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
mailnull:x:47:47::/var/spool/mqueue:/sbin/nologin
smmsp:x:51:51::/var/spool/mqueue:/sbin/nologin
[[email protected] tmp]#

扩展

把一个目录下,过滤所有*.php文档中含有eval的行

grep -r --include="*.php" ‘eval‘ /data/
[[email protected] fxq]# grep -r --include="*.php" ‘eval‘ /  
/backup/hszd_zabbix/bak/var_www_html_zabbix/jsLoader.php:header(‘Cache-Control: public, must-revalidate‘);
/backup/hszd_zabbix/bak/var_www_html_zabbix/include/triggers.inc.php: * Substitute macros in the expression with the given values and evaluate its result.
/backup/hszd_zabbix/bak/var_www_html_zabbix/include/triggers.inc.php:function evalExpressionData($expression, $replaceFunctionMacros) {
/backup/hszd_zabbix/bak/var_www_html_zabbix/include/triggers.inc.php:	eval(‘$result = (‘.trim($evStr).‘);‘);/backup/hszd_zabbix/bak/var_www_html_zabbix/include/schema.inc.php:			‘evaltype‘ => array(
/backup/hszd_zabbix/bak/var_www_html_zabbix/include/schema.inc.php:			‘evaltype‘ => array(
/backup/hszd_zabbix/bak/var_www_html_zabbix/include/schema.inc.php:			‘evaltype‘ => array(


本文出自 “冯晓庆的博客” 博客,请务必保留此出处http://fengyunshan911.blog.51cto.com/995251/1968446

以上是关于CentOS中grep命令的问题?的主要内容,如果未能解决你的问题,请参考以下文章

centos使用find和grep命令

linux grep命令详解

[CentOS 7系列]grep/egrep

Linux基础命令---显示文本grep

CentOS常用命令小结

12个 Linux 中 grep 命令的超级用法实例