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

com.netflix.eureka.util.EurekaMonitors Maven / Gradle / Ivy

There is a newer version: 2.0.4
Show newest version
/*
 * Copyright 2012 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.eureka.util;

import java.util.concurrent.atomic.AtomicLong;

import com.netflix.appinfo.AmazonInfo;
import com.netflix.appinfo.AmazonInfo.MetaDataKey;
import com.netflix.appinfo.ApplicationInfoManager;
import com.netflix.appinfo.DataCenterInfo;
import com.netflix.appinfo.DataCenterInfo.Name;
import com.netflix.servo.DefaultMonitorRegistry;
import com.netflix.servo.annotations.DataSourceType;
import com.netflix.servo.monitor.Monitors;

/**
 * The enum that encapsulates all statistics monitored by Eureka.
 *
 * 

* Eureka Monitoring is done using Servo. The * users who wants to take advantage of the monitoring should read up on * Servo *

* * @author Karthik Ranganathan, Greg Kim * */ public enum EurekaMonitors { RENEW("renewCounter", "Number of total renews seen since startup"), CANCEL("cancelCounter", "Number of total cancels seen since startup"), GET_ALL_CACHE_MISS("getAllCacheMissCounter", "Number of total registery queries seen since startup"), GET_ALL_CACHE_MISS_DELTA("getAllCacheMissDeltaCounter", "Number of total registery queries for delta seen since startup"), GET_ALL_WITH_REMOTE_REGIONS_CACHE_MISS("getAllWithRemoteRegionCacheMissCounter", "Number of total registry with remote region queries seen since startup"), GET_ALL_WITH_REMOTE_REGIONS_CACHE_MISS_DELTA("getAllWithRemoteRegionCacheMissDeltaCounter", "Number of total registry queries for delta with remote region seen since startup"), GET_ALL_DELTA("getAllDeltaCounter", "Number of total deltas since startup"), GET_ALL_DELTA_WITH_REMOTE_REGIONS("getAllDeltaWithRemoteRegionCounter", "Number of total deltas with remote regions since startup"), GET_ALL("getAllCounter", "Number of total registry queries seen since startup"), GET_ALL_WITH_REMOTE_REGIONS("getAllWithRemoteRegionCounter", "Number of total registry queries with remote regions, seen since startup"), GET_APPLICATION("getApplicationCounter", "Number of total application queries seen since startup"), REGISTER("registerCounter", "Number of total registers seen since startup"), EXPIRED("expiredCounter", "Number of total expired leases since startup"), STATUS_UPDATE("statusUpdateCounter", "Number of total admin status updates since startup"), STATUS_OVERRIDE_DELETE("statusOverrideDeleteCounter", "Number of status override removals"), CANCEL_NOT_FOUND("cancelNotFoundCounter", "Number of total cancel requests on non-existing instance since startup"), RENEW_NOT_FOUND("renewNotFoundexpiredCounter", "Number of total renew on non-existing instance since startup"), REJECTED_REPLICATIONS("numOfRejectedReplications", "Number of replications rejected because of full queue"), FAILED_REPLICATIONS("numOfFailedReplications", "Number of failed replications - likely from timeouts"), RATE_LIMITED("numOfRateLimitedRequests", "Number of requests discarded by the rate limiter"), RATE_LIMITED_CANDIDATES("numOfRateLimitedRequestCandidates", "Number of requests that would be discarded if the rate limiter's throttling is activated"), RATE_LIMITED_FULL_FETCH("numOfRateLimitedFullFetchRequests", "Number of full registry fetch requests discarded by the rate limiter"), RATE_LIMITED_FULL_FETCH_CANDIDATES("numOfRateLimitedFullFetchRequestCandidates", "Number of full registry fetch requests that would be discarded if the rate limiter's throttling is activated"); private final String name; private final String myZoneCounterName; private final String description; private EurekaMonitors(String name, String description) { this.name = name; this.description = description; DataCenterInfo dcInfo = ApplicationInfoManager.getInstance().getInfo().getDataCenterInfo(); if (dcInfo.getName() == Name.Amazon) { myZoneCounterName = ((AmazonInfo) dcInfo).get(MetaDataKey.availabilityZone) + "." + name; } else { myZoneCounterName = "dcmaster." + name; } } @com.netflix.servo.annotations.Monitor(name = "count", type = DataSourceType.COUNTER) private final AtomicLong counter = new AtomicLong(); @com.netflix.servo.annotations.Monitor(name = "count-minus-replication", type = DataSourceType.COUNTER) private final AtomicLong myZoneCounter = new AtomicLong(); /** * Increment the counter for the given statistic. */ public void increment() { increment(false); } /** * Increment the counter for the given statistic based on whether this is * because of replication from other eureka servers or it is a eureka client * initiated action. * * @param isReplication * true if this a replication, false otherwise. */ public void increment(boolean isReplication) { counter.incrementAndGet(); if (!isReplication) { myZoneCounter.incrementAndGet(); } } /** * Gets the statistic name of this monitor. * * @return the statistic name. */ public String getName() { return name; } /** * Gets the zone specific statistic name of this monitor. Applies only for * AWS cloud. * * @return the zone specific statistic name. */ public String getZoneSpecificName() { return myZoneCounterName; } /** * Gets the description of this statistic means. * * @return the description of this statistic means. */ public String getDescription() { return description; } /** * Gets the actual counter value for this statistic. * * @return the long value representing the number of times this statistic * has occurred. */ public long getCount() { return counter.get(); } /** * Gets the zone specific counter value for this statistic. This is * application only for AWS cloud environment. * * @return the long value representing the number of times this statistic * has occurred. */ public long getZoneSpecificCount() { return myZoneCounter.get(); } /** * Register all statistics with Servo. */ public static void registerAllStats() { for (EurekaMonitors c : EurekaMonitors.values()) { Monitors.registerObject(c.getName(), c); } } /** * Unregister all statistics from Servo. */ public static void shutdown() { for (EurekaMonitors c : EurekaMonitors.values()) { DefaultMonitorRegistry.getInstance().unregister(Monitors.newObjectMonitor(c.getName(), c)); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy