Metrics Crawler

Little library to crawl metrics

Лицензия

Лицензия

Категории

Категории

Metrics Тестирование приложения и мониторинг Monitoring
Группа

Группа

org.bytemechanics
Идентификатор

Идентификатор

metrics-crawler
Последняя версия

Последняя версия

1.0.2
Дата

Дата

Тип

Тип

jar
Описание

Описание

Metrics Crawler
Little library to crawl metrics
Ссылка на сайт

Ссылка на сайт

https://metrics-crawler.bytemechanics.org
Организация-разработчик

Организация-разработчик

Byte Mechanics
Система контроля версий

Система контроля версий

https://github.com/bytemechanics/metrics-crawler

Скачать metrics-crawler

Как подключить последнюю версию

<!-- https://jarcasting.com/artifacts/org.bytemechanics/metrics-crawler/ -->
<dependency>
    <groupId>org.bytemechanics</groupId>
    <artifactId>metrics-crawler</artifactId>
    <version>1.0.2</version>
</dependency>
// https://jarcasting.com/artifacts/org.bytemechanics/metrics-crawler/
implementation 'org.bytemechanics:metrics-crawler:1.0.2'
// https://jarcasting.com/artifacts/org.bytemechanics/metrics-crawler/
implementation ("org.bytemechanics:metrics-crawler:1.0.2")
'org.bytemechanics:metrics-crawler:jar:1.0.2'
<dependency org="org.bytemechanics" name="metrics-crawler" rev="1.0.2">
  <artifact name="metrics-crawler" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.bytemechanics', module='metrics-crawler', version='1.0.2')
)
libraryDependencies += "org.bytemechanics" % "metrics-crawler" % "1.0.2"
[org.bytemechanics/metrics-crawler "1.0.2"]

Зависимости

test (4)

Идентификатор библиотеки Тип Версия
org.junit.jupiter : junit-jupiter-api jar 5.5.2
org.junit.jupiter : junit-jupiter-params jar 5.5.2
org.junit.jupiter : junit-jupiter-engine jar 5.5.2
org.jmockit : jmockit jar 1.48

Модули Проекта

Данный проект не имеет модулей.

Metrics Crawler

Latest version Quality Gate Coverage License

A little library with zero dependencies to crawl metrics and store during a certain window. The library provides an utility to monitor certain code segments and measure with minimum performance some estatistics:

  • Number of measures taken
  • Last measure
  • Maximum measure
  • Minimum measure
  • Average measure
  • Last measure occurrence

And this measures can be:

  • Double
  • Long
  • Duration (elapsed time)

All sensors implements Autocloseable in order to reduce boilerplate when taking measures. The library allows create metric names manually or tracking your sensor stack if you are using imperative programming (As the library uses ThreadLocal to stack the sensors if you use multithreading you can have unexpected results)

Motivation

When you have performance problems in production environment and don't know where look, the only way is to have measures directly from real, using sensors allows to identify the bottlenecks in production

Quick start

(Please read our Javadoc for further information)

  1. First of all include the Jar file in your compile and execution classpath.

    Maven

    <dependency>
        <groupId>org.bytemechanics</groupId>
        <artifactId>metrics-crawler</artifactId>
        <version>X.X.X</version>
    </dependency>

    Graddle

    dependencies {
        compile 'org.bytemechanics:metrics-crawler:X.X.X'
    }

    1.1. Optionally register external MetricService supplier at application startup, take in account that expects this supplier always return the same instance (only necessary if you want to use a singleton distinct from the default one)

    AbstractSensor.registerMetricsServiceSupplier([your supplier]);
  2. Start measuring

    2.1. Option1: With manual naming

    import org.bytemechanics.metrics.crawler.sensors.DoubleSensor;
    import org.bytemechanics.metrics.crawler.sensors.LongSensor;
    import org.bytemechanics.metrics.crawler.sensors.DurationSensor;
    (...)
    try(DoubleSensor sensor1=DoubleSensor.get("myName")){
    	sensor1=2.0d;
    	(...)
    }
    (...)
    try(LongSensor sensor1=LongSensor.get("my{}Name{}","long",1)){
    	sensor1=2l;
    	(...)
    	try(LongSensor sensor2=LongSensor.get("my{}Name{}.my{}Name{}","long",1,"long",2)){
    		sensor2=5l;
    		(...)
    	}
    }
    (...)
    try(DurationSensor sensor1=DurationSensor.get("{}myName{}","duration","sensor")){
    	(...)
    }

    2.2. Option2: With stack naming (the same result)

    import org.bytemechanics.metrics.crawler.sensors.stack.DoubleStackSensor;
    import org.bytemechanics.metrics.crawler.sensors.stack.LongStackSensor;
    import org.bytemechanics.metrics.crawler.sensors.stack.DurationStackSensor;
    (...)
    try(DoubleStackSensor sensor1=DoubleStackSensor.get("myName")){
    	sensor1=2.0d;
    	(...)
    }
    (...)
    try(LongStackSensor sensor1=LongStackSensor.get("my{}Name{}","long",1)){
    	sensor1=2l;
    	(...)
    	try(LongStackSensor sensor2=LongStackSensor.get("my{}Name{}","long",2)){
    		sensor2=5l;
    		(...)
    	}
    }
    (...)
    try(DurationStackSensor sensor1=DurationStackSensor.get("{}myName{}","duration","sensor")){
    	(...)
    }
org.bytemechanics

ByteMechanics Foundation

Foundation dedicated to provide opensource libraries and resources to simplify developers life

Версии библиотеки

Версия
1.0.2
1.0.1
1.0.0