HADOOP-10169. Remove the unnecessary synchronized in JvmMetrics class. Contributed by Liang Xie.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1552820 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
04dac63695
commit
71b4903ea4
|
@ -404,6 +404,9 @@ Release 2.4.0 - UNRELEASED
|
||||||
|
|
||||||
HADOOP-10164. Allow UGI to login with a known Subject (bobby)
|
HADOOP-10164. Allow UGI to login with a known Subject (bobby)
|
||||||
|
|
||||||
|
HADOOP-10169. Remove the unnecessary synchronized in JvmMetrics class.
|
||||||
|
(Liang Xie via jing9)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
HADOOP-9748. Reduce blocking on UGI.ensureInitialized (daryn)
|
HADOOP-9748. Reduce blocking on UGI.ensureInitialized (daryn)
|
||||||
|
|
|
@ -24,10 +24,8 @@ import java.lang.management.MemoryUsage;
|
||||||
import java.lang.management.ThreadInfo;
|
import java.lang.management.ThreadInfo;
|
||||||
import java.lang.management.ThreadMXBean;
|
import java.lang.management.ThreadMXBean;
|
||||||
import java.lang.management.GarbageCollectorMXBean;
|
import java.lang.management.GarbageCollectorMXBean;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import com.google.common.collect.Maps;
|
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.log.metrics.EventCounter;
|
import org.apache.hadoop.log.metrics.EventCounter;
|
||||||
|
@ -67,7 +65,8 @@ public class JvmMetrics implements MetricsSource {
|
||||||
ManagementFactory.getGarbageCollectorMXBeans();
|
ManagementFactory.getGarbageCollectorMXBeans();
|
||||||
final ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
|
final ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
|
||||||
final String processName, sessionId;
|
final String processName, sessionId;
|
||||||
final Map<String, MetricsInfo[]> gcInfoCache = Maps.newHashMap();
|
final ConcurrentHashMap<String, MetricsInfo[]> gcInfoCache =
|
||||||
|
new ConcurrentHashMap<String, MetricsInfo[]>();
|
||||||
|
|
||||||
JvmMetrics(String processName, String sessionId) {
|
JvmMetrics(String processName, String sessionId) {
|
||||||
this.processName = processName;
|
this.processName = processName;
|
||||||
|
@ -123,13 +122,17 @@ public class JvmMetrics implements MetricsSource {
|
||||||
.addCounter(GcTimeMillis, timeMillis);
|
.addCounter(GcTimeMillis, timeMillis);
|
||||||
}
|
}
|
||||||
|
|
||||||
private synchronized MetricsInfo[] getGcInfo(String gcName) {
|
private MetricsInfo[] getGcInfo(String gcName) {
|
||||||
MetricsInfo[] gcInfo = gcInfoCache.get(gcName);
|
MetricsInfo[] gcInfo = gcInfoCache.get(gcName);
|
||||||
if (gcInfo == null) {
|
if (gcInfo == null) {
|
||||||
gcInfo = new MetricsInfo[2];
|
gcInfo = new MetricsInfo[2];
|
||||||
gcInfo[0] = Interns.info("GcCount"+ gcName, "GC Count for "+ gcName);
|
gcInfo[0] = Interns.info("GcCount" + gcName, "GC Count for " + gcName);
|
||||||
gcInfo[1] = Interns.info("GcTimeMillis"+ gcName, "GC Time for "+ gcName);
|
gcInfo[1] = Interns
|
||||||
gcInfoCache.put(gcName, gcInfo);
|
.info("GcTimeMillis" + gcName, "GC Time for " + gcName);
|
||||||
|
MetricsInfo[] previousGcInfo = gcInfoCache.putIfAbsent(gcName, gcInfo);
|
||||||
|
if (previousGcInfo != null) {
|
||||||
|
return previousGcInfo;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return gcInfo;
|
return gcInfo;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue