V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
token10086
V2EX  ›  程序员

遇见一个基础的运维命令,百思不得其解求 V 有指点一二

  •  
  •   token10086 · 2023-10-17 16:05:55 +08:00 · 1252 次点击
    这是一个创建于 412 天前的主题,其中的信息可能已经有所发展或是发生改变。
    [root@VM-16-14-opencloudos log]# cat t.log |grep -i amazonbot |wc -l
    120847
    [root@VM-16-14-opencloudos log]# cat t.log |grep -c amazonbot 
    220305
    [root@VM-16-14-opencloudos log]# awk '/amazonbot/ {count++} END {print count}' t.log
    220305
    [root@VM-16-14-opencloudos log]# 
    
    • 尝试把 t.log 跟换系统用 cat grep wc 统计正常,但是在 2c4G 的小鸡上就 yo 有点问题

    正常行数应该是 20 来万

    5 条回复    2023-10-17 17:24:15 +08:00
    rrfeng
        1
    rrfeng  
       2023-10-17 16:07:37 +08:00
    cat t.log |grep -i amazonbot > grep_i_log
    cat t.log |grep amazonbot > grep_log

    diff grep_i_log grep_log
    token10086
        2
    token10086  
    OP
       2023-10-17 16:11:28 +08:00
    @rrfeng
    ```
    [root@VM-16-14-opencloudos log]# diff grep_i_log grep_log
    [root@VM-16-14-opencloudos log]#
    ```
    返回为空
    token10086
        3
    token10086  
    OP
       2023-10-17 16:12:50 +08:00
    @token10086

    [root@VM-16-14-opencloudos log]# wc -l grep_i_log
    120847 grep_i_log
    [root@VM-16-14-opencloudos log]# wc -l grep_log
    120847 grep_log
    [root@VM-16-14-opencloudos log]#
    token10086
        4
    token10086  
    OP
       2023-10-17 16:21:51 +08:00
    破案了 `cat t.log |grep -i amazonbot > grep_i_log`,最后输出了

    ```
    匹配到二进制文件 (标准输入)
    ```

    grep -a 强制文本去解析就好了
    julyclyde
        5
    julyclyde  
       2023-10-17 17:24:15 +08:00
    你这个数量有点太大了
    要不然可以把两种 grep 分别存盘然后 diff 一下看看
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1123 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 18:45 · PVG 02:45 · LAX 10:45 · JFK 13:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.