All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.servo.monitor.LongGauge Maven / Gradle / Ivy

There is a newer version: 0.13.2
Show newest version
/*
 * Copyright 2011-2018 Netflix, Inc.
 * 

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *

* http://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.netflix.servo.monitor; import com.netflix.servo.SpectatorContext; import com.netflix.servo.annotations.DataSourceType; import com.netflix.servo.tag.TagList; import com.netflix.spectator.api.Id; import java.util.concurrent.atomic.AtomicLong; /** * A {@link Gauge} that reports a long value. */ public class LongGauge extends AbstractMonitor implements Gauge, SpectatorMonitor { private final MonitorConfig baseConfig; private final AtomicLong number; private final SpectatorContext.LazyGauge spectatorGauge; /** * Create a new instance with the specified configuration. * * @param config configuration for this gauge */ public LongGauge(MonitorConfig config) { super(config.withAdditionalTag(DataSourceType.GAUGE)); baseConfig = config; number = new AtomicLong(0L); spectatorGauge = SpectatorContext.gauge(config); } /** * Set the current value. */ public void set(Long n) { spectatorGauge.set(n); AtomicLong number = getNumber(); number.set(n); } /** * Returns a reference to the {@link java.util.concurrent.atomic.AtomicLong}. */ public AtomicLong getNumber() { return number; } /** * {@inheritDoc} */ @Override public void initializeSpectator(TagList tags) { Id id = SpectatorContext.createId(baseConfig.withAdditionalTags(tags)); spectatorGauge.setId(id); } /** * {@inheritDoc} */ @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } LongGauge that = (LongGauge) o; return getConfig().equals(that.getConfig()) && getValue(0).equals(that.getValue(0)); } /** * {@inheritDoc} */ @Override public int hashCode() { int result = getConfig().hashCode(); result = 31 * result + getValue(0).hashCode(); return result; } /** * {@inheritDoc} */ @Override public Long getValue(int pollerIdx) { // we return the actual value at the time of the call and not a reference // to the atomic number so the value doesn't change and is also available to jmx viewers return number.get(); } /** * {@inheritDoc} */ @Override public String toString() { return "LongGauge{config=" + config + ", number=" + number + '}'; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy