我正在制作一个 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)
但它没有用