今天用grep查log遇到了一件哔了狗的事。
我用vim打开log文件,里面有sysTid=3800这一行。但是grep “sysTid=3800” filename竟然找不到!
然后我grep “sysTid=xxxxx” xxxxx是另外一个数字,可以找到。。。另外如果用egrep “*sysTid.*3800*”也可以找到。。。简直哔了狗好吗!
一开始以为我是不是正则表达式用错了,是不是=要转义才行。但怎么查都不需要,而且加了\也一样不行。
后来注意到,搜索并不是完全没有结果,而是提示匹配到二进制文件。难道实际上已经匹配了,但grep认为是二进制文件?
于是去谷歌搜egrep match binary file,果然grep如果碰到\000 NUL字符,就会认为文件是二进制文件。必须加上-a或–text选项强制让grep认为是文本文件才可以看到正常的结果。
问题本身是解决了,但本质还没有完全搞清楚:为什么搜索其它的字符串不会有这个提示?为什么egrep “*sysTid.*3800*”也不会有这个提示?
让人费解的grep机制。。