我的编程空间,编程开发者的网络收藏夹
学习永远不晚

HBase BucketAllocatorException 异常剖析

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

HBase BucketAllocatorException 异常剖析

HBase BucketAllocatorException 异常剖析

近日,观察到HBase集群出现如下WARN日志:

2020-04-18 16:17:03,081 WARN [regionserver/xxx-BucketCacheWriter-1] bucket.BucketCache:Failed allocation for 604acc82edd349ca906939af14464bcb_175674734;
org.apache.hadoop.hbase.io.hfile.bucket.BucketAllocatorException: Allocation too big size=1114202; adjust BucketCache sizes hbase.bucketcache.bucket.sizes to accomodate if size seems reasonable and you want it cached.

大概意思是说:由于block块太大(size=1114202)导致BucketAllocator无法为其分配空间,如果想要被缓存并且觉得这样做合理,可以调整参数hbase.bucketcache.bucket.sizes。

默认情况下,HBase BucketCache 能够缓存block的最大值为512KB,即hbase.bucketcache.bucket.sizes=5120,9216,17408,33792,41984,50176,58368,66560,99328,132096,197632,263168,394240,525312,默认14种size标签。如果想要缓存更大的block块,我们可以调整参数为 hbase.bucketcache.bucket.sizes=5120,9216,17408,33792,41984,50176,58368,66560,99328,132096,197632,263168,394240,525312,1049600,2098176,此时最大容许2MB的block。

下面我们简单看一下对应源代码,涉及相关类为:
/hbase-server/class="lazy" data-src/main/java/org/apache/hadoop/hbase/io/hfile/bucket/BucketAllocator.java
BucketAllocator主要实现对bucket的组织管理,为block分配内存空间。


  public synchronized long allocateBlock(int blockSize) throws CacheFullException,
      BucketAllocatorException {
    assert blockSize > 0;
    BucketSizeInfo bsi = roundUpToBucketSizeInfo(blockSize);
    if (bsi == null) {
      throw new BucketAllocatorException("Allocation too big size=" + blockSize +
        "; adjust BucketCache sizes " + BlockCacheFactory.BUCKET_CACHE_BUCKETS_KEY +
        " to accomodate if size seems reasonable and you want it cached.");
    }
    long offset = bsi.allocateBlock();

    // Ask caller to free up space and try again!
    if (offset < 0)
      throw new CacheFullException(blockSize, bsi.sizeIndex());
    usedSize += bucketSizes[bsi.sizeIndex()];
    return offset;
  }

在调用roundUpToBucketSizeInfo()方法后,返回结果如果为null则抛出BucketAllocatorException异常。看一下roundUpToBucketSizeInfo()方法:


public BucketSizeInfo roundUpToBucketSizeInfo(int blockSize) {
	for (int i = 0; i < bucketSizes.length; ++i)
	  if (blockSize <= bucketSizes[i])
		return bucketSizeInfos[i];
	return null;
}

该方法将传入的blockSize与数组bucketSizes从索引0开始取值进行比较,一旦小于bucketSize[i],则为该block分配bucketSizeInfos[i]大小的空间存放该block。

我们看一下数组bucketSizes的初始化过程:

private static final int DEFAULT_BUCKET_SIZES[] = { 4 * 1024 + 1024, 8 * 1024 + 1024,
  16 * 1024 + 1024, 32 * 1024 + 1024, 40 * 1024 + 1024, 48 * 1024 + 1024,
  56 * 1024 + 1024, 64 * 1024 + 1024, 96 * 1024 + 1024, 128 * 1024 + 1024,
  192 * 1024 + 1024, 256 * 1024 + 1024, 384 * 1024 + 1024,
  512 * 1024 + 1024 };

private final int[] bucketSizes;
BucketAllocator(long availableSpace, int[] bucketSizes)
  throws BucketAllocatorException {
  this.bucketSizes = bucketSizes == null ? DEFAULT_BUCKET_SIZES : bucketSizes;
  Arrays.sort(this.bucketSizes);
  ...
}

可以看到,如果bucketSizes == null默认取数组DEFAULT_BUCKET_SIZES的值,并对该数组进行排序。这一步的排序为上一步的循环比较奠定了基础。

而数组DEFAULT_BUCKET_SIZES的值,也就是参数hbase.bucketcache.bucket.sizes的默认值。

扫描二维码关注博主公众号

转载请注明出处!欢迎关注本人微信公众号【HBase工作笔记】

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

HBase BucketAllocatorException 异常剖析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

HBase BucketAllocatorException 异常剖析

近日,观察到HBase集群出现如下WARN日志:2020-04-18 16:17:03,081 WARN [regionserver/xxx-BucketCacheWriter-1] bucket.BucketCache:Failed allocation
HBase BucketAllocatorException 异常剖析
2020-01-21

Hbase架构剖析

HBase隶属于hadoop生态系统,它参考了谷歌的BigTable建模,实现的编程语言为 Java, 建立在hdfs之上,提供高可靠性、高性能、列存储、可伸缩、实时读写的数据库系统。它仅能通过主键(row key)和主键的range来检索数据,主要用来存储非
Hbase架构剖析
2021-03-06

剖析 Golang 函数异常处理机制

golang 中的函数异常处理机制通过 panic() 抛出异常,recover() 在 defer 函数中捕获未处理异常。当 panic() 被调用时,程序立即终止并查找最近的 defer 函数,按声明顺序执行,recover() 在第一
剖析 Golang 函数异常处理机制
2024-04-21

HBase写入异常RejectedExecutionException

HBase在大数据量并发写入时,写一段时间后HBase监控界面出现告警,写入程序日志里频繁出现异常java.util.concurrent.RejectedExecutionException HBase在大数据量并发写入时,写一段时间后HBas
HBase写入异常RejectedExecutionException
2022-01-25

HBase的存储引擎内部原理剖析

HBase是一个分布式、可扩展、面向列的NoSQL数据库,它建立在Hadoop分布式文件系统(HDFS)之上,用于处理大规模数据集。以下是HBase存储引擎内部原理的剖析:HBase存储引擎内部原理数据模型:HBase的数据模型是一个稀疏
HBase的存储引擎内部原理剖析
2024-10-19

C++ 函数异常剖析:程序健壮性的基石

异常处理是 c++++ 中的机制,用于抛出、捕获和处理运行时错误。当函数遇到错误时,它可以通过 throw 关键字抛出异常。异常由 try-catch 块捕获,该块指定相应的异常处理代码。异常处理提供了程序健壮性、代码清晰度和丰富的错误信息
C++ 函数异常剖析:程序健壮性的基石
2024-05-04

C++技术中的调试:深层剖析异常和错误代码

在 c++++ 中,调试异常可利用断点、检查异常消息、进行后验剖析。调试错误代码可参考错误代码文档、使用调试器和修复错误原因。C++ 技术中的调试:深入剖析异常和错误代码调试是软件开发中至关重要的一步,它可以帮助开发人员查明和解决代码中的
C++技术中的调试:深层剖析异常和错误代码
2024-05-08

Python——异常层级分析

1、大部分的内置异常都是Exception的子类2、Exception本身是从BaseException类继承过来的3、因此所有的异常都是必须从BaseException类进行扩展4、Exception是BaseException类的子类,
2023-01-31

分析Python异常处理

本篇内容主要讲解“分析Python异常处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“分析Python异常处理”吧!  “你不可能总是对的”  甚至计算机也会有失误的时候。当然程序员也不例外,
2023-06-01

怎么分析Java异常

怎么分析Java异常,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。你觉得自己是一个Java专家吗?是否肯定自己已经全面掌握了Java的异常处理机制?在下面这段代码中,你能够迅速
2023-06-03

深入解析java.lang.ClassNotFoundException异常

1. 引言 在Java开发中,我们经常会遇到各种异常。其中,java.lang.ClassNotFoundException异常是一种常见的异常。本文将深入解析这个异常的定义、作用、产生原因以及常见场景。 1.1 介绍ClassNotFou
2023-08-30

Python 循环与迭代:全面剖析其异同点

Python 中的循环和迭代是用于重复执行代码块的重要概念,它们之间的细微差别可能会影响代码的性能和可读性。本文将深入探讨循环和迭代,分析它们的异同点,并提供代码示例以加深理解。
Python 循环与迭代:全面剖析其异同点
2024-02-17

PHP 常用算法实现的剖析和优化

在 php 中,优化算法性能的有效方法包括:减少比较次数,例如预排序元素或使用标志。使用空间换时间,例如使用辅助数组避免重新分配。并行化算法,例如使用多线程或分布式计算。PHP 常用算法实现的剖析和优化在 PHP 中,理解和有效地实现算法
PHP 常用算法实现的剖析和优化
2024-05-07

编程热搜

目录