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%2Fjmx%2Fmbeans%2Fshard%2FShardMBeanFactory.java;h=bdf125e7d45b84e41bffe47a80a84d689074de05;hp=946e525a6d0019418fd00e310064b0f78487485a;hb=2d60632f7cf63712e8357a3cf3fc40d83366e5e6;hpb=7a569e082e6be2fd081e8df16666d44e1fe9274a diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/jmx/mbeans/shard/ShardMBeanFactory.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/jmx/mbeans/shard/ShardMBeanFactory.java index 946e525a6d..bdf125e7d4 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/jmx/mbeans/shard/ShardMBeanFactory.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/jmx/mbeans/shard/ShardMBeanFactory.java @@ -7,41 +7,24 @@ */ package org.opendaylight.controller.cluster.datastore.jmx.mbeans.shard; -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutionException; - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import com.google.common.cache.Cache; -import com.google.common.cache.CacheBuilder; +import javax.annotation.Nonnull; +import org.opendaylight.controller.cluster.datastore.Shard; /** - * @author Basheeruddin syedbahm@cisco.com + * Factory for creating ShardStats mbeans. * + * @author Basheeruddin syedbahm@cisco.com */ -public class ShardMBeanFactory { - - private static final Logger LOG = LoggerFactory.getLogger(ShardMBeanFactory.class); +public final class ShardMBeanFactory { - private static Cache shardMBeansCache = - CacheBuilder.newBuilder().weakValues().build(); + private ShardMBeanFactory() { + } - public static ShardStats getShardStatsMBean(final String shardName, final String mxBeanType) { - final String finalMXBeanType = mxBeanType != null ? mxBeanType : "DistDataStore"; - try { - return shardMBeansCache.get(shardName, new Callable() { - @Override - public ShardStats call() throws Exception { - ShardStats shardStatsMBeanImpl = new ShardStats(shardName, finalMXBeanType); - shardStatsMBeanImpl.registerMBean(); - return shardStatsMBeanImpl; - } - }); - } catch(ExecutionException e) { - LOG.error(String.format("Could not create MXBean for shard: %s", shardName), e); - // Just return an instance that isn't registered. - return new ShardStats(shardName, finalMXBeanType); - } + public static ShardStats getShardStatsMBean(final String shardName, final String mxBeanType, + @Nonnull final Shard shard) { + String finalMXBeanType = mxBeanType != null ? mxBeanType : "DistDataStore"; + ShardStats shardStatsMBeanImpl = new ShardStats(shardName, finalMXBeanType, shard); + shardStatsMBeanImpl.registerMBean(); + return shardStatsMBeanImpl; } }