
com.hazelcast.internal.monitor.impl.LocalWanPublisherStatsImpl Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2008-2024, Hazelcast, Inc. All Rights Reserved.
*
* 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.hazelcast.internal.monitor.impl;
import com.hazelcast.internal.json.JsonObject;
import com.hazelcast.internal.metrics.Probe;
import com.hazelcast.internal.monitor.LocalWanPublisherStats;
import com.hazelcast.wan.WanEventCounters.DistributedObjectWanEventCounters;
import com.hazelcast.wan.WanPublisherState;
import com.hazelcast.wan.impl.ConsistencyCheckResult;
import com.hazelcast.wan.impl.WanSyncStats;
import java.util.Map;
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
import static com.hazelcast.internal.metrics.MetricDescriptorConstants.WAN_METRIC_OUTBOUND_QUEUE_SIZE;
import static com.hazelcast.internal.metrics.MetricDescriptorConstants.WAN_METRIC_TOTAL_PUBLISHED_EVENT_COUNT;
import static com.hazelcast.internal.metrics.MetricDescriptorConstants.WAN_METRIC_TOTAL_PUBLISH_LATENCY;
import static com.hazelcast.internal.metrics.ProbeUnit.MS;
import static com.hazelcast.internal.util.JsonUtil.getBoolean;
import static com.hazelcast.internal.util.JsonUtil.getString;
import static java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater;
public class LocalWanPublisherStatsImpl implements LocalWanPublisherStats {
private static final AtomicLongFieldUpdater TOTAL_PUBLISH_LATENCY =
newUpdater(LocalWanPublisherStatsImpl.class, "totalPublishLatency");
private static final AtomicLongFieldUpdater TOTAL_PUBLISHED_EVENT_COUNT =
newUpdater(LocalWanPublisherStatsImpl.class, "totalPublishedEventCount");
private volatile boolean connected;
private volatile WanPublisherState state;
@Probe(name = WAN_METRIC_OUTBOUND_QUEUE_SIZE)
private volatile int outboundQueueSize;
@Probe(name = WAN_METRIC_TOTAL_PUBLISH_LATENCY, unit = MS)
private volatile long totalPublishLatency;
@Probe(name = WAN_METRIC_TOTAL_PUBLISHED_EVENT_COUNT)
private volatile long totalPublishedEventCount;
private volatile Map sentMapEventCounter;
private volatile Map sentCacheEventCounter;
private volatile Map lastConsistencyCheckResults;
private volatile Map lastSyncStats;
@Override
public boolean isConnected() {
return connected;
}
public void setConnected(boolean connected) {
this.connected = connected;
}
@Override
public int getOutboundQueueSize() {
return outboundQueueSize;
}
public void setOutboundQueueSize(int outboundQueueSize) {
this.outboundQueueSize = outboundQueueSize;
}
@Override
public WanPublisherState getPublisherState() {
return state;
}
public void setState(WanPublisherState state) {
this.state = state;
}
@Override
public long getTotalPublishLatency() {
return totalPublishLatency;
}
@Override
public long getTotalPublishedEventCount() {
return totalPublishedEventCount;
}
@Override
public Map getSentMapEventCounter() {
return sentMapEventCounter;
}
public void setSentMapEventCounter(Map sentMapEventCounter) {
this.sentMapEventCounter = sentMapEventCounter;
}
@Override
public Map getSentCacheEventCounter() {
return sentCacheEventCounter;
}
public void setSentCacheEventCounter(Map sentCacheEventCounter) {
this.sentCacheEventCounter = sentCacheEventCounter;
}
public void setLastConsistencyCheckResults(Map lastConsistencyCheckResults) {
this.lastConsistencyCheckResults = lastConsistencyCheckResults;
}
@Override
public Map getLastConsistencyCheckResults() {
return lastConsistencyCheckResults;
}
public void setLastSyncStats(Map lastSyncStats) {
this.lastSyncStats = lastSyncStats;
}
@Override
public Map getLastSyncStats() {
return lastSyncStats;
}
public void incrementPublishedEventCount(long latency) {
TOTAL_PUBLISHED_EVENT_COUNT.incrementAndGet(this);
TOTAL_PUBLISH_LATENCY.addAndGet(this, latency);
}
@Override
public JsonObject toJson() {
JsonObject root = new JsonObject();
root.add("isConnected", connected);
root.add("state", state.name());
return root;
}
@Override
public void fromJson(JsonObject json) {
connected = getBoolean(json, "isConnected", false);
state = WanPublisherState.valueOf(getString(json, "state", WanPublisherState.REPLICATING.name()));
}
@Override
public String toString() {
return "LocalPublisherStatsImpl{"
+ "connected=" + connected
+ ", totalPublishLatency=" + totalPublishLatency
+ ", totalPublishedEventCount=" + totalPublishedEventCount
+ ", outboundQueueSize=" + outboundQueueSize
+ ", state=" + state
+ '}';
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy