我有一个服务流程,我想使用性能计数器来发布完成任务所需的平均时间。我正在使用AverageTimer32计数器来执行此操作。
它几乎按照我想要的方式工作,但并不完全:当我递增计数器时,它会短暂地提升到我期望的值(在性能监视器中观察),但随后它会下降到零。
所以,计数器为零,我运行一个任务,任务完成,计数器短暂地上升(到正确的值),但随后它几乎立即回落到零。
我使用AverageTimer32计数器,以AverageBase作为分母。每次启动任务时,我将AverageBase增加1,然后每次完成任务时,我将AverageTimer32增加一个刻度数。任何人都可以推动我吗?
答案 0 :(得分:17)
事实证明,我无法做到我想要的原因是没有一个性能计数器类型提供自动计算运行平均值。 (“平均”计数器,根据该时刻计算平均值,如“每秒字节数”)。
我想要一个跑动平均值。所以,我使用了RawFraction性能计数器类型。
该方法存在一个问题:公式将结果除以100以产生百分比,我想要一个原始数字(平均每秒操作完成)。
因此,我为每1次操作增加了分数的分母100(抵消了百分比计算)。
我的结果:我现在可以显示我的服务完成任务需要多长时间。如果我的服务不忙,平均值保持不变,这样您就可以看到我服务性能的长期趋势。