Class SimplePartitionManager

    • Method Summary

      All Methods Instance Methods Abstract Methods Concrete Methods 
      Modifier and Type Method Description
      protected abstract boolean acquireLock​(java.lang.String eventName, java.lang.String lockedBy)  
      java.util.Optional<Lock> lockPartitions​(java.lang.String eventName, java.util.List<Partition> partitions, java.lang.String lockedBy)
      Locks partitions for one event.
      protected abstract void releaseLock​(java.lang.String eventName, java.lang.String lockedBy)  
      void unlockPartitions​(Lock lock)
      Unlocks previously locked partitions.
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Constructor Detail

      • SimplePartitionManager

        public SimplePartitionManager()
    • Method Detail

      • acquireLock

        protected abstract boolean acquireLock​(java.lang.String eventName,
                                               java.lang.String lockedBy)
      • releaseLock

        protected abstract void releaseLock​(java.lang.String eventName,
                                            java.lang.String lockedBy)
      • lockPartitions

        public java.util.Optional<Lock> lockPartitions​(java.lang.String eventName,
                                                       java.util.List<Partition> partitions,
                                                       java.lang.String lockedBy)
        Description copied from interface: PartitionManager
        Locks partitions for one event. When running consumers on multiple nodes they should try to lock partitions so that events are only processed by one consumer.
        Specified by:
        lockPartitions in interface PartitionManager
        Parameters:
        eventName - Name of the event
        partitions - The partitions to lock
        lockedBy - Name of one node of the consuming application
        Returns:
        A Lock instance containing the list of locked partitions if locking succeeded, Optional.empty() otherwise