-2

我正在制作一个 bash 代码来获取服务器中的事务总数,还​​包括成功和失败,到目前为止,这是我的输出

   TOTAL     SUCCESS    FAILED   AVERAGE SUCCESS    AVERAGE FAILED
 =====================================================================
  6139386    2079679    4059707     33.874381         66.125619

这是完美的,它还为每个事件生成一个文件,我的意思是一个用于成功交易的文件,一个用于失败的交易,一个用于所有交易

现在,从失败的交易文件中,我需要详细了解导致交易失败的错误及其频率。

我做了这个代码

cat /tmp/test1.txt | grep "|-1|" | cut -d'|' -f34 > /tmp/test3_1.txt

ERR=$(sort test3_1.txt | uniq -c)

其中 test1.txt 是存储失败事务的文件,而 test3_1.txt 是存储错误的文件

如您所见,我将此输出保存在一个变量中以供以后使用,这就是输出

82       -11
7241     -4
10040    1
7        10
3115778  1000
146      10002035

其中左边的数字是频率,右边的数字是错误代码

到目前为止,这正是我想要的,但我还需要根据每个错误代码的频率和失败事务的总数来计算每个错误代码的平均比率,基本上是这样的表

82      -11       0.002%
7241    -4        0.178%
10040   1         0.247%
7       10        0.000%
3115778 1000      76.749%
146     10002035  0.004%

基于失败事务的总数 (4059707)

现在,我不知道要做的是只选择左列来进行正确的计算,以获得每个错误的平均比率并将其显示在右列中。

到目前为止,我得到了这段代码:

for i in $(awk '{print $1}' test3_1.txt) do;
AVEE=$($i * 100 | bc)

但它没有用

4

1 回答 1

0

这个单线可以完成这项工作:

 awk '{s+=$1;i[NR]=$1" "$2;a[i[NR]]=$1}END{for(x in i)print i[x],sprintf("%.3f%", 100*a[i[x]]/s)}' file
  • 你可以改变 "%.3f%以获得不同的格式。
  • 如果你想有更好的输出格式,你可以awk....|column -t

这是测试:

kent$  awk '{s+=$1;i[NR]=$1" "$2;a[i[NR]]=$1}END{for(x in i)print i[x],sprintf("%.3f%", 100*a[i[x]]/s)}' file|column -t
82       -11       0.003%
7241     -4        0.231%
10040    1         0.320%
7        10        0.000%
3115778  1000      99.441%
146      10002035  0.005%

此测试是在 OP 给出的不完整示例上进行的(请参阅问题下的评论),结果可能与 OP 的输出不同。

于 2013-07-22T22:22:46.170 回答