[ https://issues.apache.org/jira/browse/HBASE-6603?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Lars Hofhansl updated HBASE-6603: --------------------------------- Fix Version/s: 0.92.2 Committed to 0.94 and 0.96. > RegionMetricsStorage.incrNumericMetric is called too often > ---------------------------------------------------------- > > Key: HBASE-6603 > URL: https://issues.apache.org/jira/browse/HBASE-6603 > Project: HBase > Issue Type: Bug > Components: performance > Reporter: Lars Hofhansl > Assignee: M. Chen > Fix For: 0.92.2, 0.96.0, 0.94.2 > > Attachments: 6503-0.96.txt > > > Running an HBase scan load through the profiler revealed that > RegionMetricsStorage.incrNumericMetric is called way too often. > It turns out that we make this call for *each* KV in StoreScanner.next(...). > Incrementing AtomicLong requires expensive memory barriers. > The observation here is that StoreScanner.next(...) can maintain a simple > long in its internal loop and only update the metric upon exit. Thus the > AtomicLong is not updated nearly as often. > That cuts about 10% runtime from scan only load (I'll quantify this better > soon). -- This message is automatically generated by JIRA. If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa For more information on JIRA, see: http://www.atlassian.com/software/jira