io.nats.client.StatisticsCollector Maven / Gradle / Ivy
// Copyright 2023 The NATS Authors
// 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 io.nats.client;
/**
* A collector for connection metrics.
*
* Information about key metrics is incremented on this collector by the connection.
*
* See {@link Statistics} for accessing the collected metrics.
*/
public interface StatisticsCollector extends Statistics {
/**
* Sets whether advanced stats are/should be tracked.
* @param trackAdvanced the advanced tracking flag. set to true to turn on advanced tracking
*/
void setAdvancedTracking(boolean trackAdvanced);
/**
* Increments the total number of pings that have been sent from this connection.
*/
void incrementPingCount();
/**
* Increments the total number of times this connection has tried to reconnect.
*/
void incrementReconnects();
/**
* Increments the total number of messages dropped by this connection across all slow consumers.
*/
void incrementDroppedCount();
/**
* Increments the total number of op +OKs received by this connection.
*/
void incrementOkCount();
/**
* Increments the total number of op -ERRs received by this connection.
*/
void incrementErrCount();
/**
* Increments the total number of exceptions seen by this connection.
*/
void incrementExceptionCount();
/**
* Increments the total number of requests sent by this connection.
*/
void incrementRequestsSent();
/**
* Increments the total number of replies received by this connection.
*/
void incrementRepliesReceived();
/**
* Increments the total number of duplicate replies received by this connection.
*
* NOTE: This is only counted if advanced stats are enabled.
*/
void incrementDuplicateRepliesReceived();
/**
* Increments the total number of orphan replies received by this connection.
*
* NOTE: This is only counted if advanced stats are enabled.
*/
void incrementOrphanRepliesReceived();
/**
* Increments the total number of messages that have come in to this connection.
*/
void incrementInMsgs();
/**
* Increments the total number of messages that have gone out of this connection.
*/
void incrementOutMsgs();
/**
* Increment the total number of message bytes that have come in to this connection.
* @param bytes the number of bytes coming in
*/
void incrementInBytes(long bytes);
/**
* Increment the total number of message bytes that have gone out of this connection.
* @param bytes the number of bytes going out
*/
void incrementOutBytes(long bytes);
/**
* Increment the total number of outgoing message flushes by this connection.
*/
void incrementFlushCounter();
/**
* Increments the count of outstanding of requests from this connection.
*/
void incrementOutstandingRequests();
/**
* Decrements the count of outstanding of requests from this connection.
*/
void decrementOutstandingRequests();
/**
* Registers a Socket read by this connection.
*
NOTE: Implementations should only count this if advanced stats are enabled.
* @param bytes the number of bytes being read
*/
void registerRead(long bytes);
/**
* Registers a Socket write by this connection.
* NOTE: Implementations should only count this if advanced stats are enabled.
* @param bytes the number of bytes being written
*/
void registerWrite(long bytes);
}