【问题标题】:Script to extract and find min, max and avg from a file using a shell script from traceroute output使用来自 traceroute 输出的 shell 脚本从文件中提取和查找最小值、最大值和平均值的脚本
【发布时间】:2015-07-29 16:56:09
【问题描述】:

我正在创建一个 shell 脚本来存储 traceroute 命令的输出以及用户输入的文件。

我想提取每个数据包和每个路由器的延迟,并找出每个数据包的最小、最大和平均时间。

如果这是traceroute的输出:

1  176.221.87.1 (176.221.87.1)  1.474 ms  1.444 ms  1.390 ms
2  f126.broadband2.quicknet.se (92.43.37.126)  10.047 ms  19.868 ms  23.156 ms
3  10.5.12.1 (10.5.12.1)  24.098 ms  24.340 ms  25.311 ms

我需要找到第一个数据包的所有延迟的最大值,在本例中为 24.098 ms。同样,最小值为1.474,第一个数据包的平均值为11.873 ms。我需要为每个数据包执行此操作。

我想要这样的输出:

1  176.221.87.1 (176.221.87.1)  1.474 ms  1.444 ms  1.390 ms
2  f126.broadband2.quicknet.se (92.43.37.126)  10.047 ms  19.868 ms  23.156 ms
3  10.5.12.1 (10.5.12.1)  24.098 ms  24.340 ms  25.311 ms

对于第一个数据包:

Minimum: 1.474 ms
Maximum: 24.098 ms
Average: 11.873 ms

.
.

等等。

我无法提出 awk 语句来执行此操作。也许还有其他方法?

任何输入都会非常有帮助。

【问题讨论】:

  • 如果你的样本输出匹配数据,有一个奇怪的计算规则。不应该 Max=24.098,Average=(1.474+10.047+24.098)/3=11.873 吗?
  • 哦,对不起,我写错了。感谢您的关注。已更新。

标签: linux shell unix awk traceroute


【解决方案1】:

如果我的理解是正确的,你想要这样的东西

    NR == 1 {
            n = $4                   # set min to first value
            u = $5                   # keep time unit for later
    }

    {
            s += $4
            c++
            if ($4 > m) {            # update max
                    m = $4
            }
            if ($4 < n) {            # update min
                    n = $4
            }
    }       

    END {
            print "Minimum: " n, u "\nMaximum: " m, u "\nAverage: " s / c, u
    }

对于所有三列,您可以轻松扩展它

    NR == 1 {
            split("4,6,8",ix,",")
            for(i in ix) n[ix[i]] = $(ix[i])
            u = $5
    }

    {
            c++
            for(i in ix) {
                 p = ix[i];
                 s[p] += $(p)
                 if ($p > m[p]) m[p] = $p
                 if ($p < n[p]) n[p] = $p
            }
    }

    END {
            mins = "Minimum ("u"):"
            maxs = "Maximum ("u"):"
            avgs = "Average ("u"):"
            for(i in ix) {
                  mins = mins FS n[ix[i]]
                  maxs = maxs FS m[ix[i]]
                  avgs = avgs FS s[ix[i]]/c
            }
            print mins
            print maxs
            print avgs
    }

应该打印

Minimum (ms):  1.474 1.444 1.390
Maximum (ms):  24.098 24.340 25.311
Average (ms):  11.873 15.2173 16.619

【讨论】:

  • 谢谢!所以这找到了第一个数据包的信息,如何将它应用到第二个和第三个?
  • 感谢您的帮助:)
猜你喜欢
  • 1970-01-01
  • 2023-03-15
  • 1970-01-01
  • 1970-01-01
  • 2016-12-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-01-16
相关资源
最近更新 更多