我正在使用以下代码对千分尺进行实验。如何配置速率聚合并从应用程序中的给定计数器获取速率聚合数据。通过汇总率,我指的是先前发布间隔的数据?
final MeterRegistry myRegistry = new SimpleMeterRegistry();
final Random random = new Random();
for (iteration = 0; iteration < 1000; iteration++)
{
final int randomNum = random.nextInt(10);
final Counter myCounter = myRegistry.counter("myTestCounter", "random", Integer.toString(randomNum));
myCounter.increment();
Thread.sleep(100);
}
System.out.println("measure = [" + myRegistry.counter("myTestCounter", "random", "0").measure());
System.out.println("count = [" + myRegistry.counter("myTestCounter", "random", "0").count());
注意:我不想将度量标准发布到任何监视系统。我想在应用程序本身中跟踪每个时间间隔内给定标签的请求数量(例如,给定时间间隔内的成功/失败请求),并将其用于恢复力目的。
答案 0 :(得分:1)
根据项目作者的评论,Micrometer打算将指标导出到Prometheus等外部产品就绪的监视系统,因此您的方法有点不寻常。
千分尺支持不支持速率汇总的监视系统(例如InfluxDB)的速率汇总,其支持来自StepMeterRegistry
。但是SimpleMeterRegistry
并不是其子类之一,因此,如果您要坚持使用该方法,则需要创建自己的子类。
已更新: