X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FAbstractShardDataTreeNotificationPublisherActorProxy.java;h=b4c65a80c07f672172d878b8d2eee1aefee72f34;hp=6b348fb76f904e6de35e105b0bc46cf796aabe32;hb=e84f63ee098fff5b02cbce1281ca0d1208f966fa;hpb=ec870dee9bacb971f11bc747b69e84ac37f5d746 diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeNotificationPublisherActorProxy.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeNotificationPublisherActorProxy.java index 6b348fb76f..b4c65a80c0 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeNotificationPublisherActorProxy.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeNotificationPublisherActorProxy.java @@ -10,30 +10,29 @@ package org.opendaylight.controller.cluster.datastore; import akka.actor.ActorContext; import akka.actor.ActorRef; import akka.actor.Props; -import javax.annotation.concurrent.NotThreadSafe; -import org.opendaylight.controller.cluster.datastore.utils.Dispatchers; -import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeCandidate; +import edu.umd.cs.findbugs.annotations.SuppressFBWarnings; +import org.opendaylight.controller.cluster.common.actor.Dispatchers; +import org.opendaylight.yangtools.yang.data.tree.api.DataTreeCandidate; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Abstract base class for a ShardDataTreeNotificationPublisher that offloads the generation and publication - * of data tree notifications to an actor. + * of data tree notifications to an actor. This class is NOT thread-safe. * * @author Thomas Pantelis */ -@NotThreadSafe abstract class AbstractShardDataTreeNotificationPublisherActorProxy implements ShardDataTreeNotificationPublisher { - private static final Logger LOG = LoggerFactory.getLogger( - AbstractShardDataTreeNotificationPublisherActorProxy.class); + @SuppressFBWarnings("SLF4J_LOGGER_SHOULD_BE_PRIVATE") + protected final Logger log = LoggerFactory.getLogger(getClass()); private final ActorContext actorContext; private final String actorName; private final String logContext; - private ActorRef notifierActor; + private ActorRef publisherActor; - protected AbstractShardDataTreeNotificationPublisherActorProxy(ActorContext actorContext, String actorName, - String logContext) { + protected AbstractShardDataTreeNotificationPublisherActorProxy(final ActorContext actorContext, + final String actorName, final String logContext) { this.actorContext = actorContext; this.actorName = actorName; this.logContext = logContext; @@ -50,21 +49,20 @@ abstract class AbstractShardDataTreeNotificationPublisherActorProxy implements S } @Override - public void publishChanges(DataTreeCandidate candidate, String logContext) { - notifierActor().tell(new ShardDataTreeNotificationPublisherActor.PublishNotifications(candidate), + public void publishChanges(final DataTreeCandidate candidate) { + publisherActor().tell(new ShardDataTreeNotificationPublisherActor.PublishNotifications(candidate), ActorRef.noSender()); } - protected final ActorRef notifierActor() { - if (notifierActor == null) { - LOG.debug("Creating actor {}", actorName); - + protected final ActorRef publisherActor() { + if (publisherActor == null) { String dispatcher = new Dispatchers(actorContext.system().dispatchers()).getDispatcherPath( Dispatchers.DispatcherType.Notification); - notifierActor = actorContext.actorOf(props().withDispatcher(dispatcher).withMailbox( - org.opendaylight.controller.cluster.datastore.utils.ActorContext.BOUNDED_MAILBOX), actorName); + publisherActor = actorContext.actorOf(props().withDispatcher(dispatcher), actorName); + + log.debug("{}: Created publisher actor {} with name {}", logContext, publisherActor, actorName); } - return notifierActor; + return publisherActor; } }