Class OortPrimaryService<R,​C>

java.lang.Object
org.eclipse.jetty.util.component.AbstractLifeCycle
org.cometd.oort.OortService<R,​C>
org.cometd.oort.OortPrimaryService<R,​C>
Type Parameters:
R - the result type
C - the opaque context type
All Implemented Interfaces:
EventListener, Bayeux.BayeuxListener, ConfigurableServerChannel.ServerChannelListener, ServerChannel.MessageListener, org.eclipse.jetty.util.component.LifeCycle
Direct Known Subclasses:
OortPrimaryLong

public abstract class OortPrimaryService<R,​C> extends OortService<R,​C>

OortPrimaryService extends OortService to allow applications to perform actions on entities that always live in a "primary" node.

Applications may have entities that are naturally owned by any node. For example, in a chat application a chat room may be created by a user in any node, and be owned by the node the user that created it is connected to.

There are cases, however, where entities cannot be owned by any node, but instead must be owned by one node only, usually referred to as the "primary" node.

A typical example of such an entity is a unique (across the cluster) ID generator that produces IDs in the form of long - the primitive Java type - values, or a service that accesses a storage (such as a file system) that is only available on a particular node, etc.

OortPrimaryService makes easier to write services that perform actions on entities that must be owned by a single node only. There is one instance of OortPrimaryService with the same name for each node, but only one of them is the "primary". Then, applications may call getPrimaryOortURL() to get the Oort URL of the "primary" node, and pass that Oort URL to OortService.forward(String, Object, Object) as described in OortService.

  • Constructor Details

    • OortPrimaryService

      public OortPrimaryService(Oort oort, String name, boolean primary)
      Parameters:
      oort - the oort this instance is associated to
      name - the name of this service
      primary - whether this service lives on the "primary" node
  • Method Details

    • isPrimary

      public boolean isPrimary()
      Returns:
      whether this node is the "primary" node
    • getPrimaryOortURL

      public String getPrimaryOortURL()
      Returns:
      the "primary" Oort URL, or null if the "primary" node is down.
    • doStart

      protected void doStart() throws Exception
      Overrides:
      doStart in class OortService<R,​C>
      Throws:
      Exception
    • doStop

      protected void doStop() throws Exception
      Overrides:
      doStop in class OortService<R,​C>
      Throws:
      Exception