kv-3.5.2.src.com.sleepycat.je.rep.ReplicatedEnvironmentStats Maven / Gradle / Ivy
Show all versions of oracle-nosql-client Show documentation
/*-
*
* This file is part of Oracle NoSQL Database
* Copyright (C) 2011, 2015 Oracle and/or its affiliates. All rights reserved.
*
* If you have received this file as part of Oracle NoSQL Database the
* following applies to the work as a whole:
*
* Oracle NoSQL Database server software is free software: you can
* redistribute it and/or modify it under the terms of the GNU Affero
* General Public License as published by the Free Software Foundation,
* version 3.
*
* Oracle NoSQL Database is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Affero General Public License for more details.
*
* If you have received this file as part of Oracle NoSQL Database Client or
* distributed separately the following applies:
*
* Oracle NoSQL Database client software is free software: you can
* redistribute it and/or modify it under the terms of the Apache License
* as published by the Apache Software Foundation, version 2.0.
*
* You should have received a copy of the GNU Affero General Public License
* and/or the Apache License in the LICENSE file along with Oracle NoSQL
* Database client or server distribution. If not, see
*
* or
* .
*
* An active Oracle commercial licensing agreement for this product supersedes
* these licenses and in such case the license notices, but not the copyright
* notice, may be removed by you in connection with your distribution that is
* in accordance with the commercial licensing terms.
*
* For more information please contact:
*
* [email protected]
*
*/
package com.sleepycat.je.rep;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.N_FEEDERS_CREATED;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.N_FEEDERS_SHUTDOWN;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.N_MAX_REPLICA_LAG;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.N_MAX_REPLICA_LAG_NAME;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.REPLICA_DELAY_MAP;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.REPLICA_LAST_COMMIT_TIMESTAMP_MAP;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.REPLICA_LAST_COMMIT_VLSN_MAP;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.REPLICA_VLSN_LAG_MAP;
import static com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition.REPLICA_VLSN_RATE_MAP;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.LATEST_COMMIT_LAG_MS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.MAX_COMMIT_PROCESSING_NANOS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.MIN_COMMIT_PROCESSING_NANOS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_ABORTS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_COMMITS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_COMMIT_ACKS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_COMMIT_NO_SYNCS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_COMMIT_SYNCS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_COMMIT_WRITE_NO_SYNCS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_ELAPSED_TXN_TIME;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_GROUP_COMMITS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_GROUP_COMMIT_MAX_EXCEEDED;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_GROUP_COMMIT_TIMEOUTS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_GROUP_COMMIT_TXNS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_LNS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.N_NAME_LNS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.TOTAL_COMMIT_LAG_MS;
import static com.sleepycat.je.rep.impl.node.ReplayStatDefinition.TOTAL_COMMIT_PROCESSING_NANOS;
import static com.sleepycat.je.rep.impl.node.ReplicaStatDefinition.N_LAG_CONSISTENCY_WAITS;
import static com.sleepycat.je.rep.impl.node.ReplicaStatDefinition.N_LAG_CONSISTENCY_WAIT_MS;
import static com.sleepycat.je.rep.impl.node.ReplicaStatDefinition.N_VLSN_CONSISTENCY_WAITS;
import static com.sleepycat.je.rep.impl.node.ReplicaStatDefinition.N_VLSN_CONSISTENCY_WAIT_MS;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.ACK_WAIT_MS;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.LAST_COMMIT_TIMESTAMP;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.LAST_COMMIT_VLSN;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.TOTAL_TXN_MS;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.TXNS_ACKED;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.TXNS_NOT_ACKED;
import static com.sleepycat.je.rep.stream.FeederTxnStatDefinition.VLSN_RATE;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.BYTES_READ_RATE;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.BYTES_WRITE_RATE;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.MESSAGE_READ_RATE;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.MESSAGE_WRITE_RATE;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_BYTES_READ;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_BYTES_WRITTEN;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_ENTRIES_WRITTEN_OLD_VERSION;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_MESSAGES_BATCHED;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_MESSAGES_READ;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_MESSAGES_WRITTEN;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_MESSAGE_BATCHES;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_READ_NANOS;
import static com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition.N_WRITE_NANOS;
import static com.sleepycat.je.utilint.CollectionUtils.emptySortedMap;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.SortedMap;
import com.sleepycat.je.Durability.ReplicaAckPolicy;
import com.sleepycat.je.Environment;
import com.sleepycat.je.EnvironmentFailureException;
import com.sleepycat.je.StatsConfig;
import com.sleepycat.je.Transaction;
import com.sleepycat.je.TransactionConfig;
import com.sleepycat.je.rep.impl.RepImpl;
import com.sleepycat.je.rep.impl.node.FeederManager;
import com.sleepycat.je.rep.impl.node.FeederManagerStatDefinition;
import com.sleepycat.je.rep.impl.node.RepNode;
import com.sleepycat.je.rep.impl.node.ReplayStatDefinition;
import com.sleepycat.je.rep.impl.node.Replica;
import com.sleepycat.je.rep.impl.node.ReplicaStatDefinition;
import com.sleepycat.je.rep.stream.FeederTxnStatDefinition;
import com.sleepycat.je.rep.utilint.BinaryProtocolStatDefinition;
import com.sleepycat.je.rep.vlsn.VLSNIndexStatDefinition;
import com.sleepycat.je.utilint.AtomicLongMapStat;
import com.sleepycat.je.utilint.IntegralLongAvgStat;
import com.sleepycat.je.utilint.LongAvgRateMapStat;
import com.sleepycat.je.utilint.LongAvgRateStat;
import com.sleepycat.je.utilint.LongDiffMapStat;
import com.sleepycat.je.utilint.StatDefinition;
import com.sleepycat.je.utilint.StatGroup;
/**
* Statistics for a replicated environment.
*
* The statistics are logically grouped into four categories. Viewing the
* statistics through {@link ReplicatedEnvironmentStats#toString()} displays
* the values in these categories, as does viewing the stats through the {@link
* RepJEMonitor
* mbean}. Viewing the stats with {@link
* ReplicatedEnvironmentStats#toStringVerbose()} will provide more detailed
* descriptions of the stats and stat categories.
*
* The current categories are:
*
* - FeederManager: A feed is the {@link replication
* stream} between a master and replica. The current number of feeders
* gives a sense of the connectivity of the replication group.
*
* - BinaryProtocol: These statistics center on the network traffic
* engendered by the replication stream, and provide a sense of the network
* bandwidth seen by the replication group.
*
* - Replay: The act of receiving and applying the replication stream
* at the Replica node is called Replay. These stats give a sense of how much
* load the replica node is experiencing when processing the traffic from the
* replication group.
*
* - ConsistencyTracker: The tracker is invoked when consistency
* policies are used at a replica node. This provides a measure of delays
* experienced by read requests at a replica, in order to conform with the
* consistency specified by the application.
*
*
*
* @see Viewing
* Statistics with JConsole
*/
public class ReplicatedEnvironmentStats implements Serializable {
private static final long serialVersionUID = 1L;
/**
* The "impossible" return value used by stats accessors to indicate the
* statistic is not available in this instance of
* ReplicatedEnvironmentStats, because it represents an earlier
* de-serialized instance in which this statistic was unavailable.
*/
private static final int VALUE_UNAVAILABLE = -1;
private StatGroup feederManagerStats;
private StatGroup feederTxnStats;
private StatGroup replayStats;
private StatGroup trackerStats;
private StatGroup protocolStats;
private StatGroup vlsnIndexStats;
private final Map tipsMap = new HashMap();
ReplicatedEnvironmentStats(RepImpl repImpl, StatsConfig config) {
final RepNode repNode = repImpl.getRepNode();
final FeederManager feederManager = repNode.feederManager();
feederManagerStats = feederManager.getFeederManagerStats(config);
feederTxnStats = repNode.getFeederTxns().getStats(config);
final Replica replica = repNode.getReplica();
replayStats = replica.getReplayStats(config);
trackerStats = replica.getTrackerStats(config);
protocolStats = feederManager.getProtocolStats(config);
vlsnIndexStats = repImpl.getVLSNIndex().getStats(config);
protocolStats.addAll(replica.getProtocolStats(config));
addMessageRateStats();
addBytesRateStats();
}
/**
* @hidden
* Internal use only.
*/
public ReplicatedEnvironmentStats() {
}
/**
* @hidden
* Internal use only.
*/
public Collection getStatGroups() {
return (feederTxnStats != null) ?
Arrays.asList(feederManagerStats,
feederTxnStats,
replayStats,
trackerStats,
protocolStats,
vlsnIndexStats) :
Arrays.asList(feederManagerStats,
replayStats,
trackerStats,
protocolStats,
vlsnIndexStats);
}
/**
* @hidden
* Internal use only.
*/
public Map getStatGroupsMap() {
HashMap statmap = new HashMap();
statmap.put(feederManagerStats.getName(), feederManagerStats);
statmap.put(replayStats.getName(), replayStats);
statmap.put(trackerStats.getName(), trackerStats);
statmap.put(protocolStats.getName(), protocolStats);
statmap.put(vlsnIndexStats.getName(), vlsnIndexStats);
if (feederTxnStats != null) {
statmap.put(feederTxnStats.getName(), feederTxnStats);
}
return statmap;
}
/**
* @hidden
* Internal use only.
*/
public void setStatGroup(StatGroup sg) {
if (sg.getName().equals(FeederManagerStatDefinition.GROUP_NAME)) {
feederManagerStats = sg;
} else if (sg.getName().equals(ReplayStatDefinition.GROUP_NAME)) {
replayStats = sg;
} else if (sg.getName().equals(ReplicaStatDefinition.GROUP_NAME)) {
trackerStats = sg;
} else if (sg.getName().equals
(BinaryProtocolStatDefinition.GROUP_NAME)) {
protocolStats = sg;
} else if (sg.getName().equals(VLSNIndexStatDefinition.GROUP_NAME)) {
vlsnIndexStats = sg;
} else if (sg.getName().equals(FeederTxnStatDefinition.GROUP_NAME)) {
feederTxnStats = sg;
} else {
throw EnvironmentFailureException.unexpectedState
("Internal error stat context is not registered");
}
}
/**
* @hidden
* Internal use only
*
* For JConsole plugin support.
*/
public static String[] getStatGroupTitles() {
return new String[] {
FeederManagerStatDefinition.GROUP_NAME,
FeederTxnStatDefinition.GROUP_NAME,
BinaryProtocolStatDefinition.GROUP_NAME,
ReplayStatDefinition.GROUP_NAME,
ReplicaStatDefinition.GROUP_NAME,
VLSNIndexStatDefinition.GROUP_NAME};
}
private void addMessageRateStats() {
long numerator;
long denominator;
numerator = (protocolStats.getLongStat(N_MESSAGES_READ) == null) ?
0 : protocolStats.getLongStat(N_MESSAGES_READ).get();
denominator = (protocolStats.getLongStat(N_READ_NANOS) == null) ?
0 : protocolStats.getLongStat(N_READ_NANOS).get();
@SuppressWarnings("unused")
IntegralLongAvgStat msgReadRate =
new IntegralLongAvgStat
(protocolStats,
MESSAGE_READ_RATE,
numerator,
denominator,
1000000000);
numerator = (protocolStats.getLongStat(N_MESSAGES_WRITTEN) == null) ?
0 : protocolStats.getLongStat(N_MESSAGES_WRITTEN).get();
denominator = (protocolStats.getLongStat(N_WRITE_NANOS) == null) ?
0 : protocolStats.getLongStat(N_WRITE_NANOS).get();
@SuppressWarnings("unused")
IntegralLongAvgStat msgWriteRate =
new IntegralLongAvgStat
(protocolStats,
MESSAGE_WRITE_RATE,
numerator,
denominator,
1000000000);
}
private void addBytesRateStats() {
long numerator;
long denominator;
numerator = (protocolStats.getLongStat(N_BYTES_READ) == null) ?
0 : protocolStats.getLongStat(N_BYTES_READ).get();
denominator = (protocolStats.getLongStat(N_READ_NANOS) == null) ?
0 : protocolStats.getLongStat(N_READ_NANOS).get();
@SuppressWarnings("unused")
IntegralLongAvgStat bytesReadRate =
new IntegralLongAvgStat
(protocolStats,
BYTES_READ_RATE,
numerator,
denominator,
1000000000);
numerator = (protocolStats.getLongStat(N_BYTES_WRITTEN) == null) ?
0 : protocolStats.getLongStat(N_BYTES_WRITTEN).get();
denominator = (protocolStats.getLongStat(N_WRITE_NANOS) == null) ?
0 : protocolStats.getLongStat(N_WRITE_NANOS).get();
@SuppressWarnings("unused")
IntegralLongAvgStat bytesWriteRate =
new IntegralLongAvgStat
(protocolStats,
BYTES_WRITE_RATE,
numerator,
denominator,
1000000000);
}
/* Feeder Stats. */
/**
* The number of Feeder threads since this node was started. A Master
* supplies the Replication Stream to a Replica via a Feeder thread. The
* Feeder thread is created when a Replica connects to the node and is
* shutdown when the connection is terminated.
*/
public int getNFeedersCreated() {
return feederManagerStats.getInt(N_FEEDERS_CREATED);
}
/**
* The number of Feeder threads that were shut down, either because this
* node, or the Replica terminated the connection.
*
* @see #getNFeedersCreated()
*/
public int getNFeedersShutdown() {
return feederManagerStats.getInt(N_FEEDERS_SHUTDOWN);
}
/**
* The lag (in VLSNs) associated with the replica that's farthest behind in
* replaying the replication stream.
*/
public long getNMaxReplicaLag() {
/* TODO: Implement using REPLICA_VLSN_LAG_MAP */
return feederManagerStats.getLong(N_MAX_REPLICA_LAG);
}
/**
* The name of the replica that's farthest behind in replaying the
* replication stream.
*/
public String getNMaxReplicaLagName() {
/* TODO: Implement using REPLICA_VLSN_LAG_MAP */
return feederManagerStats.getString(N_MAX_REPLICA_LAG_NAME);
}
/**
* Returns a map from replica node name to the delay, in milliseconds,
* between when a transaction was committed on the master and when the
* master learned that the transaction was processed on the replica, if
* known. Returns an empty map if this node is not the master.
*
* @since 6.3.0
*/
public SortedMap getReplicaDelayMap() {
final LongDiffMapStat stat =
(LongDiffMapStat) feederManagerStats.getStat(REPLICA_DELAY_MAP);
if (stat == null) {
return emptySortedMap();
}
return stat.getMap();
}
/**
* Returns a map from replica node name to the commit timestamp of the last
* committed transaction that was processed on the replica, if known.
* Returns an empty map if this node is not the master.
*
* @since 6.3.0
*/
public SortedMap getReplicaLastCommitTimestampMap() {
final AtomicLongMapStat stat = (AtomicLongMapStat)
feederManagerStats.getStat(REPLICA_LAST_COMMIT_TIMESTAMP_MAP);
if (stat == null) {
return emptySortedMap();
}
return stat.getMap();
}
/**
* Returns a map from replica node name to the VLSN of the last committed
* transaction that was processed on the replica, if known. Returns an
* empty map if this node is not the master.
*
* @since 6.3.0
*/
public SortedMap getReplicaLastCommitVLSNMap() {
final AtomicLongMapStat stat = (AtomicLongMapStat)
feederManagerStats.getStat(REPLICA_LAST_COMMIT_VLSN_MAP);
if (stat == null) {
return emptySortedMap();
}
return stat.getMap();
}
/**
* Returns a map from replica node name to the lag, in VLSNs, between the
* replication state of the replica and the master, if known. Returns an
* empty map if this node is not the master.
*
* @since 6.3.0
*/
public SortedMap getReplicaVLSNLagMap() {
final LongDiffMapStat stat =
(LongDiffMapStat) feederManagerStats.getStat(REPLICA_VLSN_LAG_MAP);
if (stat == null) {
return emptySortedMap();
}
return stat.getMap();
}
/**
* Returns a map from replica node name to a moving average of the rate, in
* VLSNs per minute, that the replica is processing replication data, if
* known. Returns an empty map if this node is not the master.
*
* @since 6.3.0
*/
public SortedMap getReplicaVLSNRateMap() {
final LongAvgRateMapStat stat = (LongAvgRateMapStat)
feederManagerStats.getStat(REPLICA_VLSN_RATE_MAP);
if (stat == null) {
return emptySortedMap();
}
return stat.getMap();
}
/* Master transaction commit acknowledgment statistics. */
/**
* The number of transactions that were successfully acknowledged based
* upon the {@link ReplicaAckPolicy} policy associated with the
* transaction commit.
*/
public long getNTxnsAcked() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(TXNS_ACKED);
}
/**
* The number of transactions that were not acknowledged as required by the
* {@link ReplicaAckPolicy} policy associated with the transaction commit.
* These transactions resulted in {@link InsufficientReplicasException} or
* {@link InsufficientAcksException}.
*/
public long getNTxnsNotAcked() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(TXNS_NOT_ACKED);
}
/**
* The total time in milliseconds spent in replicated transactions. This
* represents the time from the start of the transaction until its
* successful commit and acknowledgment. It includes the time spent
* waiting for transaction commit acknowledgments, as determined by
* {@link #getAckWaitMs()}.
*/
public long getTotalTxnMs() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(TOTAL_TXN_MS);
}
/**
* The total time in milliseconds that the master spent waiting for the
* {@link ReplicaAckPolicy} to be satisfied during successful transaction
* commits.
*
* @see #getTotalTxnMs()
*/
public long getAckWaitMs() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(ACK_WAIT_MS);
}
/**
* The VLSN of the last committed transaction on the master, or 0 if not
* known or this node is not the master.
*
* @since 6.3.0
*/
public long getLastCommitVLSN() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(LAST_COMMIT_VLSN);
}
/**
* The commit timestamp of the last committed transaction on the master, or
* 0 if not known or this node is not the master.
*
* @since 6.3.0
*/
public long getLastCommitTimestamp() {
return (feederTxnStats == null) ?
VALUE_UNAVAILABLE :
feederTxnStats.getAtomicLong(LAST_COMMIT_TIMESTAMP);
}
/**
* A moving average of the rate replication data is being generated by the
* master, in VLSNs per minute, or 0 if not known or this node is not the
* master.
*
* @since 6.3.0
*/
public long getVLSNRate() {
if (feederTxnStats == null) {
return VALUE_UNAVAILABLE;
}
final LongAvgRateStat stat =
(LongAvgRateStat) feederTxnStats.getStat(VLSN_RATE);
return (stat != null) ? stat.get() : 0;
}
/* Replay Stats. */
/**
* The number of commit log records that were replayed by this node when
* it was a Replica. There is one commit record record for each actual
* commit on the Master.
*/
public long getNReplayCommits() {
return replayStats.getLong(N_COMMITS);
}
/**
* The number of commit log records that needed to be acknowledged to the
* Master by this node when it was a Replica. The rate of change of this
* statistic, will show a strong correlation with that of
* NReplayCommits
statistic, if the Durability
* policy used by transactions on the master calls for transaction commit
* acknowledgments and the Replica is current with respect to the Master.
*/
public long getNReplayCommitAcks() {
return replayStats.getLong(N_COMMIT_ACKS);
}
/**
* The number of commitSync() calls executed when satisfying transaction
* commit acknowledgment requests from the Master.
*/
public long getNReplayCommitSyncs() {
return replayStats.getLong(N_COMMIT_SYNCS);
}
/**
* The number of commitNoSync() calls executed when satisfying transaction
* commit acknowledgment requests from the Master.
*/
public long getNReplayCommitNoSyncs() {
return replayStats.getLong(N_COMMIT_NO_SYNCS);
}
/**
* The number of commitNoSync() calls executed when satisfying transaction
* commit acknowledgment requests from the Master.
*/
public long getNReplayCommitWriteNoSyncs() {
return replayStats.getLong(N_COMMIT_WRITE_NO_SYNCS);
}
/**
* The number of abort records which were replayed while the node was in
* the Replica state.
*/
public long getNReplayAborts() {
return replayStats.getLong(N_ABORTS);
}
/**
* The number of NameLN records which were replayed while the node was in
* the Replica state.
*/
public long getNReplayNameLNs() {
return replayStats.getLong(N_NAME_LNS);
}
/**
* The number of data records (creation, update, deletion) which were
* replayed while the node was in the Replica state.
*/
public long getNReplayLNs() {
return replayStats.getLong(N_LNS);
}
/**
* The total elapsed time in milliseconds spent replaying committed and
* aborted transactions.
*/
public long getReplayElapsedTxnTime() {
return replayStats.getLong(N_ELAPSED_TXN_TIME);
}
/**
* The number of group commits that were initiated due to the
* {@link ReplicationConfig#REPLICA_GROUP_COMMIT_INTERVAL group timeout
* interval} being exceeded.
*
* @since 5.0.76
*/
public long getNReplayGroupCommitTimeouts() {
return replayStats.getLong(N_GROUP_COMMIT_TIMEOUTS);
}
/**
* The number of group commits that were initiated due the
* {@link ReplicationConfig#REPLICA_MAX_GROUP_COMMIT max group size} being
* exceeded.
*
* @since 5.0.76
*/
public long getNReplayGroupCommitMaxExceeded() {
return replayStats.getLong(N_GROUP_COMMIT_MAX_EXCEEDED);
}
/**
* The number of replay transaction commits that were part of a group
* commit operation.
*
* @since 5.0.76
*/
public long getNReplayGroupCommitTxns() {
return replayStats.getLong(N_GROUP_COMMIT_TXNS);
}
/**
* The number of group commit operations.
*
* @since 5.0.76
*/
public long getNReplayGroupCommits() {
return replayStats.getLong(N_GROUP_COMMITS);
}
/**
* The minimum time taken to replay a transaction commit operation.
*/
public long getReplayMinCommitProcessingNanos() {
return replayStats.getLong(MIN_COMMIT_PROCESSING_NANOS);
}
/**
* The maximum time taken to replay a transaction commit operation.
*/
public long getReplayMaxCommitProcessingNanos() {
return replayStats.getLong(MAX_COMMIT_PROCESSING_NANOS);
}
/**
* The total time spent to replay all commit operations.
*/
public long getReplayTotalCommitProcessingNanos() {
return replayStats.getLong(TOTAL_COMMIT_PROCESSING_NANOS);
}
/**
* @hidden
* TODO: Make visible after experimenting with this new stat
*
* The sum of time periods, measured in milliseconds, between when update
* operations commit on the master and then subsequently commit on the
* replica. Divide this value by the total number of commit operations,
* available by calling {@link #getNReplayCommits}, to find the average
* commit lag for a single operation.
*
* Note that each lag is computed on the replica by comparing the time
* of the master commit, as measured by the master, and time on the replica
* when it commits locally. As a result, the return value will be affected
* by any clock skew between the master and the replica.
*/
public long getReplayTotalCommitLagMs() {
return replayStats.getLong(TOTAL_COMMIT_LAG_MS);
}
/**
* @hidden
* TODO: Make visible after experimenting with this new stat
*
* The time in milliseconds between when the latest update operation
* committed on the master and then subsequently committed on the replica.
*
*
Note that the lag is computed on the replica by comparing the time of
* the master commit, as measured by the master, and time on the replica
* when it commits locally. As a result, the return value will be affected
* by any clock skew between the master and the replica.
*/
public long getReplayLatestCommitLagMs() {
return replayStats.getLong(LATEST_COMMIT_LAG_MS);
}
/* Protocol Stats. */
/**
* The number of bytes of Replication Stream read over the network. It does
* not include the TCP/IP overhead.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getNProtocolBytesRead() {
return protocolStats.getLong(N_BYTES_READ);
}
/**
* The number of Replication Stream messages read over the network.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getNProtocolMessagesRead() {
return protocolStats.getLong(N_MESSAGES_READ);
}
/**
* The number of Replication Stream bytes written over the network.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getNProtocolBytesWritten() {
return protocolStats.getLong(N_BYTES_WRITTEN);
}
/**
* The number of Replication Stream messages that were written as part
* of a message batch instead of being written individually.
*
* It represents a subset of the messages returned by
* {@link #getNProtocolMessagesWritten()}
*
* @see #getNProtocolMessageBatches
*
* @since 6.2.7
*/
public long getNProtocolMessagesBatched() {
return protocolStats.getLong(N_MESSAGES_BATCHED);
}
/**
* The number of Replication Stream message batches written to the network.
*
* @see #getNProtocolMessagesBatched
*
* @since 6.2.7
*/
public long getNProtocolMessageBatches() {
return protocolStats.getLong(N_MESSAGE_BATCHES);
}
/**
* The total number of Replication Stream messages written over the
* network.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getNProtocolMessagesWritten() {
return protocolStats.getLong(N_MESSAGES_WRITTEN);
}
/**
* The number of nanoseconds spent reading from the network channel.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getProtocolReadNanos() {
return protocolStats.getLong(N_READ_NANOS);
}
/**
* The number of nanoseconds spent writing to the network channel.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the sum total of all Feeder related
* network activity, as well as Replica network activity.
*/
public long getProtocolWriteNanos() {
return protocolStats.getLong(N_WRITE_NANOS);
}
/**
* Incoming replication message throughput, in terms of messages received
* from the replication network channels per second.
*
If the node has served as both a Replica and Master since
* it was first started, the number represents the message reading rate
* over all Feeder related network activity, as well as Replica network
* activity.
*/
public long getProtocolMessageReadRate() {
IntegralLongAvgStat rstat =
protocolStats.getIntegralLongAvgStat(MESSAGE_READ_RATE);
return (rstat != null) ? rstat.get().longValue() : 0;
}
/**
* Outgoing message throughput, in terms of message written to the
* replication network channels per second.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the message writing rate over all Feeder
* related network activity, as well as Replica network activity.
*/
public long getProtocolMessageWriteRate() {
IntegralLongAvgStat rstat =
protocolStats.getIntegralLongAvgStat(MESSAGE_WRITE_RATE);
return (rstat != null) ? rstat.get().longValue() : 0;
}
/**
* Bytes read throughput, in terms of bytes received from the replication
* network channels per second.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the bytes reading rate over all Feeder
* related network activity, as well as Replica network activity.
*/
public long getProtocolBytesReadRate() {
IntegralLongAvgStat rstat =
protocolStats.getIntegralLongAvgStat(BYTES_READ_RATE);
return (rstat != null) ? rstat.get().longValue() : 0;
}
/**
* Bytes written throughput, in terms of bytes written to the replication
* network channels per second.
*
* If the node has served as both a Replica and Master since it was first
* started, the number represents the bytes writing rate over all Feeder
* related network activity, as well as Replica network activity.
*/
public long getProtocolBytesWriteRate() {
IntegralLongAvgStat rstat =
protocolStats.getIntegralLongAvgStat(BYTES_WRITE_RATE);
return (rstat != null) ? rstat.get().longValue() : 0;
}
/**
* Returns the number of messages containing log entries that were written
* to the replication stream using the previous log format to support
* replication to a replica running an earlier version during an upgrade.
*/
public long getNProtocolEntriesWrittenOldVersion() {
return protocolStats.getLong(N_ENTRIES_WRITTEN_OLD_VERSION);
}
/* ConsistencyTracker Stats. */
/**
* The number of times a Replica held back a
* {@link Environment#beginTransaction(Transaction,TransactionConfig)}
* operation to satisfy the {@link TimeConsistencyPolicy}.
*/
public long getTrackerLagConsistencyWaits() {
return trackerStats.getLong(N_LAG_CONSISTENCY_WAITS);
}
/**
* The total time (in msec) for which a Replica held back a
* {@link Environment#beginTransaction(Transaction,TransactionConfig)}
* operation to satisfy the {@link TimeConsistencyPolicy}.
*/
public long getTrackerLagConsistencyWaitMs() {
return trackerStats.getLong(N_LAG_CONSISTENCY_WAIT_MS);
}
/**
* The number of times a Replica held back a
* {@link Environment#beginTransaction(Transaction,TransactionConfig)}
* operation to satisfy the {@link CommitPointConsistencyPolicy}.
*/
public long getTrackerVLSNConsistencyWaits() {
return trackerStats.getLong(N_VLSN_CONSISTENCY_WAITS);
}
/**
* The total time (in msec) for which a Replica held back a
* {@link Environment#beginTransaction(Transaction,TransactionConfig)}
* operation to satisfy the {@link CommitPointConsistencyPolicy}.
*/
public long getTrackerVLSNConsistencyWaitMs() {
return trackerStats.getLong(N_VLSN_CONSISTENCY_WAIT_MS);
}
/**
* Returns a string representation of the statistics.
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
for (StatGroup group : getStatGroups()) {
sb.append(group.toString());
}
return sb.toString();
}
public String toStringVerbose() {
StringBuilder sb = new StringBuilder();
for (StatGroup group : getStatGroups()) {
sb.append(group.toStringVerbose());
}
return sb.toString();
}
public Map getTips() {
/* Add FeederManager stats definition. */
for (StatGroup group : getStatGroups()) {
tipsMap.put(group.getName(), group.getDescription());
for (StatDefinition def : group.getStats().keySet()) {
tipsMap.put(def.getName(), def.getDescription());
}
}
return tipsMap;
}
}