io.zeebe.gateway.impl.configuration.MembershipCfg Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH under
* one or more contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright ownership.
* Licensed under the Zeebe Community License 1.0. You may not use this file
* except in compliance with the Zeebe Community License 1.0.
*/
package io.zeebe.gateway.impl.configuration;
import java.time.Duration;
public final class MembershipCfg {
// the following values are from atomix per default
private static final boolean DEFAULT_BROADCAST_UPDATES = false;
private static final boolean DEFAULT_BROADCAST_DISPUTES = true;
private static final boolean DEFAULT_NOTIFY_SUSPECT = false;
private static final Duration DEFAULT_GOSSIP_INTERVAL = Duration.ofMillis(250);
private static final int DEFAULT_GOSSIP_FANOUT = 2;
private static final Duration DEFAULT_PROBE_INTERVAL = Duration.ofMillis(1000);
private static final Duration DEFAULT_PROBE_TIMEOUT = Duration.ofMillis(2000);
private static final int DEFAULT_SUSPECT_PROBES = 3;
private static final Duration DEFAULT_FAILURE_TIMEOUT = Duration.ofMillis(10_000);
private static final Duration DEFAULT_SYNC_INTERVAL = Duration.ofMillis(10_000);
private boolean broadcastUpdates = DEFAULT_BROADCAST_UPDATES;
private boolean broadcastDisputes = DEFAULT_BROADCAST_DISPUTES;
private boolean notifySuspect = DEFAULT_NOTIFY_SUSPECT;
private Duration gossipInterval = DEFAULT_GOSSIP_INTERVAL;
private int gossipFanout = DEFAULT_GOSSIP_FANOUT;
private Duration probeInterval = DEFAULT_PROBE_INTERVAL;
private Duration probeTimeout = DEFAULT_PROBE_TIMEOUT;
private int suspectProbes = DEFAULT_SUSPECT_PROBES;
private Duration failureTimeout = DEFAULT_FAILURE_TIMEOUT;
private Duration syncInterval = DEFAULT_SYNC_INTERVAL;
public boolean isBroadcastUpdates() {
return broadcastUpdates;
}
public MembershipCfg setBroadcastUpdates(final boolean broadcastUpdates) {
this.broadcastUpdates = broadcastUpdates;
return this;
}
public boolean isBroadcastDisputes() {
return broadcastDisputes;
}
public MembershipCfg setBroadcastDisputes(final boolean broadcastDisputes) {
this.broadcastDisputes = broadcastDisputes;
return this;
}
public boolean isNotifySuspect() {
return notifySuspect;
}
public MembershipCfg setNotifySuspect(final boolean notifySuspect) {
this.notifySuspect = notifySuspect;
return this;
}
public Duration getGossipInterval() {
return gossipInterval;
}
public MembershipCfg setGossipInterval(final Duration gossipInterval) {
this.gossipInterval = gossipInterval;
return this;
}
public int getGossipFanout() {
return gossipFanout;
}
public MembershipCfg setGossipFanout(final int gossipFanout) {
this.gossipFanout = gossipFanout;
return this;
}
public Duration getProbeInterval() {
return probeInterval;
}
public MembershipCfg setProbeInterval(final Duration probeInterval) {
this.probeInterval = probeInterval;
return this;
}
public Duration getProbeTimeout() {
return probeTimeout;
}
public MembershipCfg setProbeTimeout(final Duration probeTimeout) {
this.probeTimeout = probeTimeout;
return this;
}
public int getSuspectProbes() {
return suspectProbes;
}
public MembershipCfg setSuspectProbes(final int suspectProbes) {
this.suspectProbes = suspectProbes;
return this;
}
public Duration getFailureTimeout() {
return failureTimeout;
}
public MembershipCfg setFailureTimeout(final Duration failureTimeout) {
this.failureTimeout = failureTimeout;
return this;
}
public Duration getSyncInterval() {
return syncInterval;
}
public MembershipCfg setSyncInterval(final Duration syncInterval) {
this.syncInterval = syncInterval;
return this;
}
@Override
public String toString() {
return "MembershipCfg{"
+ "broadcastUpdates="
+ broadcastUpdates
+ ", broadcastDisputes="
+ broadcastDisputes
+ ", notifySuspect="
+ notifySuspect
+ ", gossipInterval="
+ gossipInterval
+ ", gossipFanout="
+ gossipFanout
+ ", probeInterval="
+ probeInterval
+ ", probeTimeout="
+ probeTimeout
+ ", suspectProbes="
+ suspectProbes
+ ", failureTimeout="
+ failureTimeout
+ ", syncInterval="
+ syncInterval
+ '}';
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy