當前位置: 首頁>>代碼示例>>Java>>正文


Java ScheduledReporter類代碼示例

本文整理匯總了Java中com.codahale.metrics.ScheduledReporter的典型用法代碼示例。如果您正苦於以下問題:Java ScheduledReporter類的具體用法?Java ScheduledReporter怎麽用?Java ScheduledReporter使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ScheduledReporter類屬於com.codahale.metrics包,在下文中一共展示了ScheduledReporter類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testPointsSent

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Test
public void testPointsSent() throws Exception {
    MetricRegistry registry = new MetricRegistry();
    new BasicJvmMetrics(registry);

    ScheduledReporter reporter = new ScheduledReporter(registry, "test", MetricFilter.ALL,
            TimeUnit.SECONDS, TimeUnit.MILLISECONDS) {

        @Override
        public void report(SortedMap<String, Gauge> gauges, SortedMap<String, Counter> counters,
                           SortedMap<String, Histogram> histograms,
                           SortedMap<String, Meter> meters, SortedMap<String, Timer> timers) {
            Assert.assertFalse(gauges.isEmpty());
            Assert.assertNotNull(gauges.get("jvm.uptime"));
            for (Map.Entry<String, Gauge> entry : gauges.entrySet()) {
                Assert.assertNotNull(entry.getValue().getValue());
            }
        }
    };

    reporter.report();
    reporter.close();
}
 
開發者ID:signalfx,項目名稱:signalfx-java,代碼行數:24,代碼來源:BasicJvmMetrisTest.java

示例2: build

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
public ScheduledReporter build(final MetricRegistry registry) {
  final Sender builtSender = new Sender(sender.build(registry));
  final DropwizardTransformer transformer = new DropwizardTransformer(
    globalTags,
    DropwizardMeasurementParser.withTemplates(metricTemplates),
    groupCounters,
    groupGauges,
    getRateUnit(),
    getDurationUnit()
  );

  return new InfluxDbMeasurementReporter(
    builtSender,
    registry,
    getFilter(),
    getRateUnit(),
    getDurationUnit(),
    Clock.systemUTC(),
    transformer
  );
}
 
開發者ID:kickstarter,項目名稱:dropwizard-influxdb-reporter,代碼行數:23,代碼來源:InfluxDbMeasurementReporterFactory.java

示例3: createAndGetConfiguredCSVReporter

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
private ScheduledReporter createAndGetConfiguredCSVReporter(String prefix, String csvDir) throws IOException {
    // NOTE:
    // 1) metrics output files are exclusive to a given process
    // 2) the output directory must exist
    // 3) if output files already exist they are not overwritten and there is no metrics output
    File outputDir;
    if (Strings.isNullOrEmpty(prefix)) {
        outputDir = new File(csvDir, prefix);
    } else {
        outputDir = new File(csvDir);
    }
    FileUtils.forceMkdir(outputDir);
    LOG.info("Configuring stats with csv output to directory [{}]", outputDir.getAbsolutePath());
    return CsvReporter.forRegistry(metrics)
            .convertRatesTo(TimeUnit.SECONDS)
            .convertDurationsTo(TimeUnit.MILLISECONDS)
            .build(outputDir);
}
 
開發者ID:apache,項目名稱:incubator-omid,代碼行數:19,代碼來源:CodahaleMetricsProvider.java

示例4: createReporter

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
private ScheduledReporter createReporter(String json)
        throws Exception {
    ObjectMapper objectMapper = Jackson.newObjectMapper();
    ReporterFactory reporterFactory = objectMapper.readValue(json, ReporterFactory.class);

    assertTrue(reporterFactory instanceof DatadogExpansionFilteredReporterFactory);
    DatadogExpansionFilteredReporterFactory datadogReporterFactory = (DatadogExpansionFilteredReporterFactory) reporterFactory;

    // Replace the transport with our own mock for testing

    Transport transport = mock(Transport.class);
    when(transport.prepare()).thenReturn(_request);

    AbstractTransportFactory transportFactory = mock(AbstractTransportFactory.class);
    when(transportFactory.build()).thenReturn(transport);

    datadogReporterFactory.setTransport(transportFactory);

    // Build the reporter
    return datadogReporterFactory.build(_metricRegistry);
}
 
開發者ID:bazaarvoice,項目名稱:emodb,代碼行數:22,代碼來源:DatadogMetricFilterTest.java

示例5: startMetricReporting

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
/**
 * Start metric reporting.
 *
 * @param properties configuration properties
 */
public void startMetricReporting(Properties properties) {
  if (this.reportingStarted) {
    LOGGER.warn("Metric reporting has already started");
    return;
  }

  long reportInterval = Long.parseLong(properties.getProperty(ConfigurationKeys.METRICS_REPORT_INTERVAL_KEY,
      ConfigurationKeys.DEFAULT_METRICS_REPORT_INTERVAL));

  buildJmxMetricReporter(properties);
  if (this.jmxReporter.isPresent()) {
    this.jmxReporter.get().start();
  }

  buildFileMetricReporter(properties);
  buildKafkaMetricReporter(properties);
  buildCustomMetricReporters(properties);

  for (ScheduledReporter reporter : this.scheduledReporters) {
    reporter.start(reportInterval, TimeUnit.MILLISECONDS);
  }

  this.reportingStarted = true;
}
 
開發者ID:Hanmourang,項目名稱:Gobblin,代碼行數:30,代碼來源:GobblinMetrics.java

示例6: build

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
public ScheduledReporter build(MetricRegistry metricRegistry) {
    MetricAdapterFactory metricAdapterFactory = new MetricAdapterFactoryImpl(
            new DefaultMetricDescriptorLookup(),
            new DefaultMetricNameTranslator(getReplacements()));

    MonitorableRegistry monitorableRegistry = MonitorableRegistry.getNamedInstance(getRegistryName());

    PcpMmvWriter pcpMmvWriter = new PcpMmvWriter(getPcpName(), IdentifierSourceSet.DEFAULT_SET);
    pcpMmvWriter.setClusterIdentifier(getClusterIdentifier());

    MonitoringView monitoringView = new PcpMonitorBridge(pcpMmvWriter);

    DynamicMonitoringView dynamicMonitoringView = new DynamicMonitoringView(monitorableRegistry, monitoringView, quietPeriod);

    return new ParfaitReporter(metricRegistry,
            monitorableRegistry,
            dynamicMonitoringView,
            metricAdapterFactory,
            getRateUnit(),
            getDurationUnit(),
            getFilter(),
            getPrefix());
}
 
開發者ID:performancecopilot,項目名稱:parfait,代碼行數:25,代碼來源:ParfaitReporterFactory.java

示例7: createElasticSearchReporter

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
/**
 * Create a new ElasticSearch reporter.
 *
 * @param metricRegistry
 *            the registry to report on
 * @param config
 *            the configuration map (see {@link MetricsFactory})
 * @return the reporter instance
 */
public static ScheduledReporter createElasticSearchReporter(MetricRegistry metricRegistry,
		Map<String, Object> config) throws BaleenException {
	try {
		String server = (String) config.getOrDefault("server", "localhost:9200");
		String index = (String) config.getOrDefault("index", "metrics");
		int timeout = (int) config.getOrDefault("timeout", 1000);
		int bulkSize = (int) config.getOrDefault("bulkSize", 2500);

		return ElasticsearchReporter.forRegistry(metricRegistry).convertRatesTo(getRatesUnit(config))
				.convertDurationsTo(getDurationUnit(config)).bulkSize(bulkSize).hosts(server).index(index)
				.timeout(timeout).build();
	} catch (IOException e) {
		throw new BaleenException("Unable to create ElasticSearch reporter", e);
	}
}
 
開發者ID:dstl,項目名稱:baleen,代碼行數:25,代碼來源:ReporterUtils.java

示例8: onPassivate

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
public void onPassivate( Application application )
{
    requestTimers.values().forEach( t -> t.stop() );
    requestTimers = null;
    reporters.forEach(
        r ->
        {
            if( r instanceof ScheduledReporter )
            {
                ( (ScheduledReporter) r ).stop();
            }
            else if( r instanceof JmxReporter )
            {
                ( (JmxReporter) r ).stop();
            }
        }
    );
    reporters = null;
    api = null;
    eventRegistration.unregister();
    eventRegistration = null;
    SharedMetricRegistries.clear();
    SharedHealthCheckRegistries.clear();
}
 
開發者ID:werval,項目名稱:werval,代碼行數:26,代碼來源:MetricsPlugin.java

示例9: build

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
public ScheduledReporter build(MetricRegistry registry) {

    final EnumSet<Expansions> expansions = EnumSet.of(COUNT, RATE_1_MINUTE,
            RATE_15_MINUTE, MEDIAN, P95, P99);
    final DatadogReporter reporter;
    try {
        reporter = new DatadogReporter.Builder(registry).withEC2Host()
                .withApiKey(apiKey).withExpansions(expansions).build();
    } catch (IOException e) {
        e.printStackTrace();
        throw new IllegalStateException(
                "Unable to construct DataDog metrics reporter", e);
    }
    return reporter;
}
 
開發者ID:skidder,項目名稱:metrics-datadog-factory,代碼行數:17,代碼來源:DatadogReporterFactory.java

示例10: build

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
/**
 * Builds a {@link ScheduledReporter} with the given properties, sending
 * metrics using the given InfluxDB.
 *
 * @return a {@link ScheduledReporter}
 */
public ScheduledReporter build() {
	ScheduledReporter reporter;

	switch (influxdbVersion) {
	case V08:
		Influxdb influxdb = buildInfluxdb();
		reporter = (executor == null)
				? new ReporterV08(registry, influxdb, clock, prefix, rateUnit, durationUnit, filter, skipIdleMetrics)
				: new ReporterV08(registry, influxdb, clock, prefix, rateUnit, durationUnit, filter, skipIdleMetrics, executor)
				;
		break;
	default:
		Sender s = buildSender();
		reporter = executor == null
				? new MeasurementReporter(s, registry, filter, rateUnit, durationUnit, clock, tags, transformer)
				: new MeasurementReporter(s, registry, filter, rateUnit, durationUnit, clock, tags, transformer, executor)
				;
	}
	return reporter;
}
 
開發者ID:davidB,項目名稱:metrics-influxdb,代碼行數:27,代碼來源:InfluxdbReporter.java

示例11: builder_api_with_tags

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Test
public void builder_api_with_tags() {
	String tagKey = "tag-name";
	String tagValue = "tag-value";

	Builder builder = InfluxdbReporter
			.forRegistry(registry)
			.tag(tagKey, tagValue)
			.protocol(new HttpInfluxdbProtocol());

	assertThat(builder.tags, notNullValue());
	assertThat(builder.tags, hasEntry(tagKey, tagValue));

	ScheduledReporter reporter = builder.build();
	assertThat(reporter, notNullValue());
}
 
開發者ID:davidB,項目名稱:metrics-influxdb,代碼行數:17,代碼來源:InfluxdbReporterBuilderTest.java

示例12: NbdStatsReporter

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Inject
public NbdStatsReporter(MetricRegistry metrics) {
    ScheduledReporter reporter = Slf4jReporter.forRegistry(metrics)
            .withLoggingLevel(Slf4jReporter.LoggingLevel.DEBUG)
            .outputTo(LOGGER)
            .convertRatesTo(TimeUnit.SECONDS)
            .convertDurationsTo(TimeUnit.MILLISECONDS)
            .build();
    reporter.start(5, TimeUnit.SECONDS);
}
 
開發者ID:MineboxOS,項目名稱:minebox,代碼行數:11,代碼來源:NbdStatsReporter.java

示例13: shutDown

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
protected void shutDown() throws Exception {
    for (ScheduledReporter entry : reporter.values()) {
        LOG.debug("Stopping metrics reporter: {}", entry);
        entry.stop();
    }
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:8,代碼來源:MetricService.java

示例14: newInstance

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
@Override
public ScheduledReporter newInstance(String qualifiedReplicaName) {
  InetSocketAddress address = new InetSocketAddressFactory().newInstance(graphiteHost);
  Graphite graphite = new Graphite(address);
  String prefix = DotJoiner.join(graphitePrefix, qualifiedReplicaName);
  return GraphiteReporter.forRegistry(runningMetricRegistry).prefixedWith(prefix).build(graphite);
}
 
開發者ID:HotelsDotCom,項目名稱:circus-train,代碼行數:8,代碼來源:GraphiteScheduledReporterFactory.java

示例15: build

import com.codahale.metrics.ScheduledReporter; //導入依賴的package包/類
public ScheduledReporter build(MetricRegistry registry) {
  try {
    return new ApptuitReporter(registry, getFilter(), getRateUnit(), getDurationUnit(),
        globalTags, apiKey, apiUrl != null ? new URL(apiUrl) : null, reportingMode);
  } catch (MalformedURLException e) {
    throw new IllegalArgumentException(e);
  }
}
 
開發者ID:ApptuitAI,項目名稱:JInsight,代碼行數:9,代碼來源:ApptuitReporterFactory.java


注:本文中的com.codahale.metrics.ScheduledReporter類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。