com.codahale.metrics.Clock.getTick()方法的使用及代码示例

x33g5p2x  于2022-01-18 转载在 其他  
字(7.6k)|赞(0)|评价(0)|浏览(242)

本文整理了Java中com.codahale.metrics.Clock.getTick()方法的一些代码示例,展示了Clock.getTick()的具体用法。这些代码示例主要来源于Github/Stackoverflow/Maven等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。Clock.getTick()方法的具体详情如下:
包路径:com.codahale.metrics.Clock
类名称:Clock
方法名:getTick

Clock.getTick介绍

[英]Returns the current time tick.
[中]返回当前时间刻度。

代码示例

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private Context(Timer timer, Clock clock) {
  this.timer = timer;
  this.clock = clock;
  this.startTime = clock.getTick();
}

代码示例来源:origin: stagemonitor/stagemonitor

@Override
public long getTick() {
  return delegate.getTick();
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Creates a new {@link Meter}.
 *
 * @param clock the clock to use for the meter ticks
 */
public Meter(Clock clock) {
  this.clock = clock;
  this.startTime = this.clock.getTick();
  this.lastTick = new AtomicLong(startTime);
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private long getTick() {
  for ( ;; ) {
    final long oldTick = lastTick.get();
    final long tick = (clock.getTick() - startTick) * COLLISION_BUFFER;
    // ensure the tick is strictly incrementing even if there are duplicate ticks
    final long newTick = tick - oldTick > 0L ? tick : oldTick + 1L;
    if (lastTick.compareAndSet(oldTick, newTick)) {
      return newTick;
    }
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private long getTick() {
  for ( ;; ) {
    final long oldTick = lastTick.get();
    final long tick = clock.getTick() * COLLISION_BUFFER;
    // ensure the tick is strictly incrementing even if there are duplicate ticks
    final long newTick = tick - oldTick > 0 ? tick : oldTick + 1;
    if (lastTick.compareAndSet(oldTick, newTick)) {
      return newTick;
    }
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private boolean shouldLoad() {
    for ( ;; ) {
      final long time = clock.getTick();
      final long current = reloadAt.get();
      if (current > time) {
        return false;
      }
      if (reloadAt.compareAndSet(current, time + timeoutNS)) {
        return true;
      }
    }
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Times and records the duration of event.
 *
 * @param event a {@link Runnable} whose {@link Runnable#run()} method implements a process
 *              whose duration should be timed
 */
public void time(Runnable event) {
  final long startTime = clock.getTick();
  try {
    event.run();
  } finally {
    update(clock.getTick() - startTime);
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Creates a new {@link SlidingTimeWindowReservoir} with the given clock and window of time.
 *
 * @param window     the window of time
 * @param windowUnit the unit of {@code window}
 * @param clock      the {@link Clock} to use
 */
public SlidingTimeWindowReservoir(long window, TimeUnit windowUnit, Clock clock) {
  this.clock = clock;
  this.measurements = new ConcurrentSkipListMap<>();
  this.window = windowUnit.toNanos(window) * COLLISION_BUFFER;
  this.lastTick = new AtomicLong(clock.getTick() * COLLISION_BUFFER);
  this.count = new AtomicLong();
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Creates a new {@link SlidingTimeWindowArrayReservoir} with the given clock and window of time.
 *
 * @param window     the window of time
 * @param windowUnit the unit of {@code window}
 * @param clock      the {@link Clock} to use
 */
public SlidingTimeWindowArrayReservoir(long window, TimeUnit windowUnit, Clock clock) {
  this.startTick = clock.getTick();
  this.clock = clock;
  this.measurements = new ChunkedAssociativeLongArray();
  this.window = windowUnit.toNanos(window) * COLLISION_BUFFER;
  this.lastTick = new AtomicLong((clock.getTick() - startTick) * COLLISION_BUFFER);
  this.count = new AtomicLong();
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Times and records the duration of event. Should not throw exceptions, for that use the
 * {@link #time(Callable)} method.
 *
 * @param event a {@link Supplier} whose {@link Supplier#get()} method implements a process
 *              whose duration should be timed
 * @param <T>   the type of the value returned by {@code event}
 * @return the value returned by {@code event}
 */
public <T> T timeSupplier(Supplier<T> event) {
  final long startTime = clock.getTick();
  try {
    return event.get();
  } finally {
    update(clock.getTick() - startTime);
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Times and records the duration of event.
 *
 * @param event a {@link Callable} whose {@link Callable#call()} method implements a process
 *              whose duration should be timed
 * @param <T>   the type of the value returned by {@code event}
 * @return the value returned by {@code event}
 * @throws Exception if {@code event} throws an {@link Exception}
 */
public <T> T time(Callable<T> event) throws Exception {
  final long startTime = clock.getTick();
  try {
    return event.call();
  } finally {
    update(clock.getTick() - startTime);
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Updates the timer with the difference between current and start time. Call to this method will
 * not reset the start time. Multiple calls result in multiple updates.
 *
 * @return the elapsed time in nanoseconds
 */
public long stop() {
  final long elapsed = clock.getTick() - startTime;
  timer.update(elapsed, TimeUnit.NANOSECONDS);
  return elapsed;
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private void rescaleIfNeeded() {
  final long now = clock.getTick();
  final long next = nextScaleTime.get();
  if (now >= next) {
    rescale(now, next);
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

/**
 * Creates a new {@link ExponentiallyDecayingReservoir}.
 *
 * @param size  the number of samples to keep in the sampling reservoir
 * @param alpha the exponential decay factor; the higher this is, the more biased the reservoir
 *              will be towards newer values
 * @param clock the clock used to timestamp samples and track rescaling
 */
public ExponentiallyDecayingReservoir(int size, double alpha, Clock clock) {
  this.values = new ConcurrentSkipListMap<>();
  this.lock = new ReentrantReadWriteLock();
  this.alpha = alpha;
  this.size = size;
  this.clock = clock;
  this.count = new AtomicLong(0);
  this.startTime = currentTimeInSeconds();
  this.nextScaleTime = new AtomicLong(clock.getTick() + RESCALE_THRESHOLD);
}

代码示例来源:origin: spotify/helios

public <T> T time(final String tag, final String name, ZooKeeperCallable<T> callable)
  throws KeeperException {
 final long startTime = clock.getTick();
 try {
  return callable.call();
 } catch (KeeperException e) {
  checkException(e, tag, name);
  throw e;
 } catch (Exception e) {
  Throwables.throwIfUnchecked(e);
  throw new RuntimeException(e);
 } finally {
  metrics.updateTimer(name, clock.getTick() - startTime, TimeUnit.NANOSECONDS);
 }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

@Override
public double getMeanRate() {
  if (getCount() == 0) {
    return 0.0;
  } else {
    final double elapsed = clock.getTick() - startTime;
    return getCount() / elapsed * TimeUnit.SECONDS.toNanos(1);
  }
}

代码示例来源:origin: io.dropwizard.metrics/metrics-core

private void tickIfNecessary() {
  final long oldTick = lastTick.get();
  final long newTick = clock.getTick();
  final long age = newTick - oldTick;
  if (age > TICK_INTERVAL) {
    final long newIntervalStartTick = newTick - age % TICK_INTERVAL;
    if (lastTick.compareAndSet(oldTick, newIntervalStartTick)) {
      final long requiredTicks = age / TICK_INTERVAL;
      for (long i = 0; i < requiredTicks; i++) {
        m1Rate.tick();
        m5Rate.tick();
        m15Rate.tick();
      }
    }
  }
}

代码示例来源:origin: palantir/atlasdb

@Test
public void cachingExceptionHandlingGaugeChangesToNewValues() {
  when(testSupplier.get()).thenReturn(8L).thenReturn(11L);
  when(clock.getTick()).thenReturn(0L).thenReturn(TrackerUtils.DEFAULT_CACHE_INTERVAL.toNanos() + 1);
  assertThat(cachingExceptionHandlingGauge.getValue()).isEqualTo(8L);
  assertThat(cachingExceptionHandlingGauge.getValue()).isEqualTo(11L);
  verify(testSupplier, times(2)).get();
}

代码示例来源:origin: palantir/atlasdb

@Test
public void doesNotCallSupplierOnRequestsWithinRetriggerInterval() {
  when(mockClock.getTick()).thenReturn(0L, 1L, 2L);
  AtomicLong timestampValue = new AtomicLong(0L);
  TimestampTracker.registerTimestampForTracking(
      mockClock, metricsManager, FAKE_METRIC, timestampValue::incrementAndGet);
  assertThat(getGauge(FAKE_METRIC).getValue()).isEqualTo(1L);
  assertThat(getGauge(FAKE_METRIC).getValue()).isEqualTo(1L);
  assertThat(getGauge(FAKE_METRIC).getValue()).isEqualTo(1L);
}

代码示例来源:origin: palantir/atlasdb

@Test
public void timestampTrackersDoNotThrowEvenIfUnderlyingSupplierThrows() {
  when(mockClock.getTick()).thenReturn(0L, CACHE_INTERVAL_NANOS);
  TimestampTracker.registerTimestampForTracking(mockClock, metricsManager, FAKE_METRIC, () -> {
    throw new IllegalArgumentException("illegal argument");
  });
  getGauge(FAKE_METRIC).getValue();
}

相关文章