org.apache.hadoop.hbase.tmpl.regionserver.BlockCacheTmplImpl Maven / Gradle / Ivy
Show all versions of hbase-server Show documentation
// Autogenerated Jamon implementation
// /home/ndimiduk/hbase-rm/output/hbase/hbase-server/src/main/jamon/org/apache/hadoop/hbase/tmpl/regionserver/BlockCacheTmpl.jamon
package org.apache.hadoop.hbase.tmpl.regionserver;
// 32, 1
import java.util.Map;
// 33, 1
import org.apache.hadoop.hbase.io.hfile.BlockCacheUtil;
// 34, 1
import org.apache.hadoop.hbase.io.hfile.BlockCacheUtil.CachedBlocksByFile;
// 35, 1
import org.apache.hadoop.hbase.io.hfile.AgeSnapshot;
// 36, 1
import org.apache.hadoop.hbase.io.hfile.CachedBlock;
// 37, 1
import org.apache.hadoop.conf.Configuration;
// 38, 1
import org.apache.hadoop.hbase.io.hfile.CacheConfig;
// 39, 1
import org.apache.hadoop.hbase.io.hfile.BlockCache;
// 40, 1
import org.apache.hadoop.hbase.io.hfile.LruBlockCache;
// 41, 1
import org.apache.hadoop.hbase.io.hfile.bucket.BucketCacheStats;
// 42, 1
import org.apache.hadoop.hbase.io.hfile.bucket.BucketCache;
// 43, 1
import org.apache.hadoop.hbase.io.hfile.bucket.BucketAllocator;
// 44, 1
import org.apache.hadoop.hbase.io.hfile.bucket.BucketAllocator.Bucket;
// 45, 1
import org.apache.hadoop.util.StringUtils.TraditionalBinaryPrefix;
public class BlockCacheTmplImpl
extends org.jamon.AbstractTemplateImpl
implements org.apache.hadoop.hbase.tmpl.regionserver.BlockCacheTmpl.Intf
{
private final CacheConfig cacheConfig;
private final Configuration config;
private final BlockCache bc;
protected static org.apache.hadoop.hbase.tmpl.regionserver.BlockCacheTmpl.ImplData __jamon_setOptionalArguments(org.apache.hadoop.hbase.tmpl.regionserver.BlockCacheTmpl.ImplData p_implData)
{
return p_implData;
}
public BlockCacheTmplImpl(org.jamon.TemplateManager p_templateManager, org.apache.hadoop.hbase.tmpl.regionserver.BlockCacheTmpl.ImplData p_implData)
{
super(p_templateManager, __jamon_setOptionalArguments(p_implData));
cacheConfig = p_implData.getCacheConfig();
config = p_implData.getConfig();
bc = p_implData.getBc();
}
@Override public void renderNoFlush(final java.io.Writer jamonWriter)
throws java.io.IOException
{
// 25, 1
String bcUrl = bc == null ? null : "http://hbase.apache.org/devapidocs/" + bc.getClass().getName().replaceAll("\\.", "/") + ".html";
String bcName = bc == null ? null : bc.getClass().getSimpleName();
BlockCache [] bcs = bc == null ? null : bc.getBlockCaches();
boolean evictions = bcs != null && bcs.length > 1;
// 47, 1
jamonWriter.write("\n \n \n \n ");
// 57, 13
{
// 57, 13
__jamon_innerUnit__bc_baseInfo(jamonWriter, bc, bcUrl, bcName);
}
// 57, 73
jamonWriter.write("\n \n \n ");
// 60, 13
{
// 60, 13
__jamon_innerUnit__bc_config(jamonWriter, cacheConfig );
}
// 60, 55
jamonWriter.write("\n \n \n ");
// 63, 13
{
// 63, 13
__jamon_innerUnit__bc_stats(jamonWriter, bc );
}
// 63, 36
jamonWriter.write("\n \n \n ");
// 66, 13
{
// 66, 13
__jamon_innerUnit__bc_l(jamonWriter, bcs == null? bc: bcs[0], "L1", evictions);
}
// 66, 90
jamonWriter.write("\n \n \n ");
// 69, 13
{
// 69, 13
__jamon_innerUnit__bc_l(jamonWriter, bcs == null? null: bcs.length <= 1? null: bcs[1], "L2", evictions);
}
// 69, 115
jamonWriter.write("\n \n \n\n\n");
}
// 74, 1
private void __jamon_innerUnit__bc_baseInfo(final java.io.Writer jamonWriter, final BlockCache bc, final String bcUrl, final String bcName)
throws java.io.IOException
{
// 80, 1
BlockCache [] bcs = bc == null? null: bc.getBlockCaches();
String bcl1Url = null;
String bcl1Name = null;
String bcl2Url = null;
String bcl2Name = null;
if (bcs != null) {
BlockCache bcl1 = bcs[0];
if (bcl1 != null) {
bcl1Url = "http://hbase.apache.org/devapidocs/" + bcl1.getClass().getName().replaceAll("\\.", "/") + ".html";
bcl1Name = bcl1.getClass().getSimpleName();
}
if (bcs.length == 2) {
BlockCache bcl2 = bcs[1];
bcl2Url = "http://hbase.apache.org/devapidocs/" + bcl2.getClass().getName().replaceAll("\\.", "/") + ".html";
bcl2Name = bcl2.getClass().getSimpleName();
}
}
// 99, 1
jamonWriter.write("\n \n Attribute \n Value \n Description \n \n \n \n Implementation \n ");
// 108, 35
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(bcName), jamonWriter);
// 108, 47
jamonWriter.write(" \n Block cache implementing class \n \n
\nSee block cache in the HBase Reference Guide for help.
\n");
}
// 115, 1
private void __jamon_innerUnit__bc_config(final java.io.Writer jamonWriter, final CacheConfig cacheConfig)
throws java.io.IOException
{
// 119, 1
if (cacheConfig == null )
{
// 119, 28
jamonWriter.write("\nCacheConfig is null
\n");
}
// 121, 1
else
{
// 121, 8
jamonWriter.write("\n\n \n Attribute \n Value \n Description \n \n \n Cache DATA on Read \n ");
// 130, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldCacheDataOnRead()), jamonWriter);
// 130, 54
jamonWriter.write(" \n True if DATA blocks are cached on read\n (INDEX & BLOOM blocks are always cached) \n \n \n Cache DATA on Write \n ");
// 136, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldCacheDataOnWrite()), jamonWriter);
// 136, 55
jamonWriter.write(" \n True if DATA blocks are cached on write. \n \n \n Cache INDEX on Write \n ");
// 141, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldCacheIndexesOnWrite()), jamonWriter);
// 141, 58
jamonWriter.write(" \n True if INDEX blocks are cached on write \n \n \n Cache BLOOM on Write \n ");
// 146, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldCacheBloomsOnWrite()), jamonWriter);
// 146, 57
jamonWriter.write(" \n True if BLOOM blocks are cached on write \n \n \n Evict blocks on Close \n ");
// 151, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldEvictOnClose()), jamonWriter);
// 151, 51
jamonWriter.write(" \n True if blocks are evicted from cache when an HFile\n reader is closed \n \n \n Cache DATA in compressed format \n ");
// 157, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldCacheDataCompressed()), jamonWriter);
// 157, 58
jamonWriter.write(" \n True if DATA blocks are cached in their compressed form \n \n \n Prefetch on Open \n ");
// 162, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(cacheConfig.shouldPrefetchOnOpen()), jamonWriter);
// 162, 53
jamonWriter.write(" \n True if blocks are prefetched into cache on open \n \n
\n");
}
// 166, 7
jamonWriter.write("\n");
}
// 264, 1
private void __jamon_innerUnit__bc_l(final java.io.Writer jamonWriter, final BlockCache bc, final String name, final boolean evictions)
throws java.io.IOException
{
// 270, 1
if (bc == null )
{
// 270, 19
jamonWriter.write("\nNo ");
// 271, 7
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(name), jamonWriter);
// 271, 17
jamonWriter.write(" deployed
\n");
}
// 272, 1
else
{
// 272, 8
jamonWriter.write("\n");
// 273, 1
{
// 273, 1
__jamon_innerUnit__block_cache(jamonWriter, bc, name, evictions);
}
// 273, 65
jamonWriter.write("\n");
}
// 274, 7
jamonWriter.write("\n");
}
// 226, 1
private void __jamon_innerUnit__bc_stats(final java.io.Writer jamonWriter, final BlockCache bc)
throws java.io.IOException
{
// 230, 1
if (bc == null )
{
// 230, 19
jamonWriter.write("\nBlockCache is null
\n");
}
// 232, 1
else
{
// 232, 8
jamonWriter.write("\n\n \n Attribute \n Value \n Description \n \n \n Size \n ");
// 241, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(bc.getCurrentSize(),
"B", 1)), jamonWriter);
// 242, 23
jamonWriter.write(" \n Current size of block cache in use \n \n \n Free \n ");
// 247, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(bc.getFreeSize(),
"B", 1)), jamonWriter);
// 248, 23
jamonWriter.write(" \n The total free memory currently available to store more cache entries \n \n \n Count \n ");
// 253, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getBlockCount())), jamonWriter);
// 253, 59
jamonWriter.write(" \n Number of blocks in block cache \n \n ");
// 256, 5
{
// 256, 5
__jamon_innerUnit__evictions_tmpl(jamonWriter, bc);
}
// 256, 35
jamonWriter.write("\n ");
// 257, 5
{
// 257, 5
__jamon_innerUnit__hits_tmpl(jamonWriter, bc);
}
// 257, 30
jamonWriter.write("\n
\nIf block cache is made up of more than one cache -- i.e. a L1 and a L2 -- then the above\nare combined counts. Request count is sum of hits and misses.
\n");
}
// 261, 7
jamonWriter.write("\n");
}
// 277, 1
private void __jamon_innerUnit__block_cache(final java.io.Writer jamonWriter, final BlockCache bc, final String name, final boolean evictions)
throws java.io.IOException
{
// 283, 1
String bcUrl = "http://hbase.apache.org/devapidocs/" + bc.getClass().getName().replaceAll("\\.", "/") + ".html";
String bcName = bc.getClass().getSimpleName();
int maxCachedBlocksByFile = BlockCacheUtil.getMaxCachedBlocksByFile(config);
boolean lru = bc instanceof LruBlockCache;
boolean bucketCache = bc.getClass().getSimpleName().equals("BucketCache");
BucketCacheStats bucketCacheStats = null;
BucketAllocator bucketAllocator = null;
if (bucketCache) {
bucketCacheStats = (BucketCacheStats)bc.getStats();
bucketAllocator = ((BucketCache)bc).getAllocator();
}
// 299, 1
jamonWriter.write("\n \n Attribute \n Value \n Description \n \n \n Implementation \n ");
// 307, 35
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(bc.getClass().getSimpleName()), jamonWriter);
// 307, 70
jamonWriter.write(" \n Class implementing this block cache Level \n \n");
// 310, 1
if (bucketCache )
{
// 310, 20
jamonWriter.write("\n \n Implementation \n ");
// 313, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(((BucketCache)bc).getIoEngine()), jamonWriter);
// 313, 50
jamonWriter.write(" \n IOEngine \n \n");
}
// 316, 7
jamonWriter.write("\n \n Cache Size Limit \n ");
// 319, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(bc.getMaxSize(), "B", 1)), jamonWriter);
// 319, 79
jamonWriter.write(" \n Max size of cache \n \n \n Block Count \n ");
// 324, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getBlockCount())), jamonWriter);
// 324, 59
jamonWriter.write(" \n Count of Blocks \n \n");
// 327, 1
if (!bucketCache )
{
// 327, 21
jamonWriter.write("\n \n Data Block Count \n ");
// 330, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getDataBlockCount())), jamonWriter);
// 330, 63
jamonWriter.write(" \n Count of DATA Blocks \n \n");
}
// 333, 7
jamonWriter.write("\n");
// 334, 1
if (lru )
{
// 334, 12
jamonWriter.write("\n \n Index Block Count \n ");
// 337, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", ((LruBlockCache)bc).getIndexBlockCount())), jamonWriter);
// 337, 81
jamonWriter.write(" \n Count of INDEX Blocks \n \n \n Bloom Block Count \n ");
// 342, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", ((LruBlockCache)bc).getBloomBlockCount())), jamonWriter);
// 342, 81
jamonWriter.write(" \n Count of BLOOM Blocks \n \n");
}
// 345, 7
jamonWriter.write("\n \n Size of Blocks \n ");
// 348, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(bc.getCurrentSize(), "B", 1)), jamonWriter);
// 348, 83
jamonWriter.write(" \n Size of Blocks \n \n");
// 351, 1
if (!bucketCache )
{
// 351, 21
jamonWriter.write("\n \n Size of Data Blocks \n ");
// 354, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(bc.getCurrentDataSize(), "B", 1)), jamonWriter);
// 354, 87
jamonWriter.write(" \n Size of DATA Blocks \n \n");
}
// 357, 7
jamonWriter.write(" \n");
// 358, 1
if (lru )
{
// 358, 12
jamonWriter.write("\n \n Size of Index Blocks \n ");
// 361, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(((LruBlockCache)bc).getCurrentIndexSize(), "B", 1)), jamonWriter);
// 361, 105
jamonWriter.write(" \n Size of INDEX Blocks \n \n \n Size of Bloom Blocks \n ");
// 366, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(TraditionalBinaryPrefix.long2String(((LruBlockCache)bc).getCurrentBloomSize(), "B", 1)), jamonWriter);
// 366, 105
jamonWriter.write(" \n Size of BLOOM Blocks \n \n");
}
// 369, 7
jamonWriter.write("\n ");
// 370, 2
{
// 370, 2
__jamon_innerUnit__evictions_tmpl(jamonWriter, bc);
}
// 370, 32
jamonWriter.write("\n");
// 371, 1
{
// 371, 1
__jamon_innerUnit__hits_tmpl(jamonWriter, bc);
}
// 371, 26
jamonWriter.write("\n\n");
// 373, 1
if (bucketCache )
{
// 373, 20
jamonWriter.write("\n \n Hits per Second \n ");
// 376, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(bucketCacheStats.getIOHitsPerSecond()), jamonWriter);
// 376, 56
jamonWriter.write(" \n Block gets against this cache per second \n \n \n Time per Hit \n ");
// 381, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(bucketCacheStats.getIOTimePerHit()), jamonWriter);
// 381, 53
jamonWriter.write(" \n Time per cache hit \n \n");
}
// 384, 7
jamonWriter.write("\n
\n\nView block cache as JSON | Block cache as JSON by file\n");
// 389, 1
if (bc.getBlockCount() > maxCachedBlocksByFile )
{
// 389, 51
jamonWriter.write("\n
\nNote: JSON view of block cache will be incomplete, because block count ");
// 391, 79
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(bc.getBlockCount()), jamonWriter);
// 391, 103
jamonWriter.write(" is greater than hbase.ui.blockcache.by.file.max value of ");
// 391, 168
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(maxCachedBlocksByFile), jamonWriter);
// 391, 195
jamonWriter.write(".\nIncrease that value to get a complete picture.\n");
}
// 393, 7
jamonWriter.write("\n
\n");
}
// 169, 1
private void __jamon_innerUnit__evictions_tmpl(final java.io.Writer jamonWriter, final BlockCache bc)
throws java.io.IOException
{
// 173, 1
AgeSnapshot ageAtEvictionSnapshot = bc.getStats().getAgeAtEvictionSnapshot();
// Only show if non-zero mean and stddev as is the case in combinedblockcache
// 177, 5
jamonWriter.write("\n Evicted \n ");
// 179, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getEvictedCount())), jamonWriter);
// 179, 72
jamonWriter.write(" \n The total number of blocks evicted \n \n \n Evictions \n ");
// 184, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getEvictionCount())), jamonWriter);
// 184, 73
jamonWriter.write(" \n The total number of times an eviction has occurred \n \n \n Mean \n ");
// 189, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", (long)ageAtEvictionSnapshot.getMean())), jamonWriter);
// 189, 78
jamonWriter.write(" \n Mean age of Blocks at eviction time (seconds) \n \n");
}
// 194, 1
private void __jamon_innerUnit__hits_tmpl(final java.io.Writer jamonWriter, final BlockCache bc)
throws java.io.IOException
{
// 198, 5
jamonWriter.write("\n Hits \n ");
// 200, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getHitCount())), jamonWriter);
// 200, 68
jamonWriter.write(" \n Number requests that were cache hits \n \n \n Hits Caching \n ");
// 205, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getHitCachingCount())), jamonWriter);
// 205, 75
jamonWriter.write(" \n Cache hit block requests but only requests set to cache block if a miss \n \n \n Misses \n ");
// 210, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getMissCount())), jamonWriter);
// 210, 69
jamonWriter.write(" \n Block requests that were cache misses but set to cache missed blocks \n \n \n Misses Caching \n ");
// 215, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,d", bc.getStats().getMissCachingCount())), jamonWriter);
// 215, 76
jamonWriter.write(" \n Block requests that were cache misses but only requests set to use block cache \n \n \n Hit Ratio \n ");
// 220, 13
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf(String.format("%,.2f", bc.getStats().getHitRatio() * 100)), jamonWriter);
// 220, 76
org.jamon.escaping.Escaping.HTML.write(org.jamon.emit.StandardEmitter.valueOf("%"), jamonWriter);
// 220, 85
jamonWriter.write(" \n Hit Count divided by total requests count \n \n\n");
}
}