org.jgroups.blocks.atomic.CounterService Maven / Gradle / Ivy
Go to download
This artifact provides a single jar that contains all classes required to use remote Jakarta Enterprise Beans and Jakarta Messaging, including
all dependencies. It is intended for use by those not using maven, maven users should just import the Jakarta Enterprise Beans and
Jakarta Messaging BOM's instead (shaded JAR's cause lots of problems with maven, as it is very easy to inadvertently end up
with different versions on classes on the class path).
package org.jgroups.blocks.atomic;
import org.jgroups.Channel;
import org.jgroups.protocols.COUNTER;
/**
* Provides a distributed counter (similar to AtomicLong) which can be atomically updated across a cluster.
* @author Bela Ban
* @since 3.0.0
*/
public class CounterService {
protected Channel ch;
protected COUNTER counter_prot;
public CounterService(Channel ch) {
setChannel(ch);
}
public void setChannel(Channel ch) {
this.ch=ch;
counter_prot=(COUNTER)ch.getProtocolStack().findProtocol(COUNTER.class);
if(counter_prot == null)
throw new IllegalStateException("channel configuration must include the COUNTER protocol");
}
/**
* Returns an existing counter, or creates a new one if none exists
* @param name Name of the counter, different counters have to have different names
* @param initial_value The initial value of a new counter if there is no existing counter. Ignored
* if the counter already exists
* @return The counter implementation
*/
public Counter getOrCreateCounter(String name, long initial_value) {
return counter_prot.getOrCreateCounter(name, initial_value);
}
/**
* Deletes a counter instance (on the coordinator)
* @param name The name of the counter. No-op if the counter doesn't exist
*/
public void deleteCounter(String name) {
counter_prot.deleteCounter(name);
}
public String printCounters() {
return counter_prot.printCounters();
}
public String dumpPendingRequests() {return counter_prot.dumpPendingRequests();}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy