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=2a409c0300889cb34586524fa12d2381b15f4a8b;hb=2d60632f7cf63712e8357a3cf3fc40d83366e5e6;hpb=be324821e7ef3dba64375e74b920b7ab513c42e3 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 2a409c0300..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,28 +7,24 @@ */ package org.opendaylight.controller.cluster.datastore.jmx.mbeans.shard; -import java.util.HashMap; -import java.util.Map; +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 Map shardMBeans = - new HashMap(); +public final class ShardMBeanFactory { - public static ShardStats getShardStatsMBean(String shardName) { - if (shardMBeans.containsKey(shardName)) { - return shardMBeans.get(shardName); - } else { - ShardStats shardStatsMBeanImpl = new ShardStats(shardName); - - if (shardStatsMBeanImpl.registerMBean()) { - shardMBeans.put(shardName, shardStatsMBeanImpl); - } - return shardStatsMBeanImpl; - } + private ShardMBeanFactory() { } + 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; + } }