当前位置: 首页 > news >正文

大数据开发(HBase面试真题-卷二)

大数据开发(HBase面试真题)

  • 1、HBase读写数据流程?
  • 2、HBase的读写缓存?
  • 3、在删除HBase中的一个数据的时候,它什么时候真正的进行删除呢?
  • 4、HBase的一个region由哪些东西组成?
  • 5、HBase的rowkey为什么不能超过一定的长度?为什么要唯一?rowkey太长会影响HFile的存储?
  • 6、HBase的Get和Scan的区别和联系?
  • 7、HBase的预分区?
  • 8、既然HBase底层数据是存储在HDFS上,为什么不直接使用HDFS,而还要用HBase?

1、HBase读写数据流程?

HBase是一个面向大规模数据集的分布式存储系统。它基于Hadoop分布式文件系统(HDFS)构建,并提供了可靠性、高性能和高伸缩性的数据存储解决方案。

HBase的数据读写流程如下:

  1. 客户端发起读写请求应用程序通过HBase客户端API向HBase集群发起读写请求
  2. 客户端与Zookeeper交互HBase客户端与Zookeeper集群进行交互,以获取HBase集群的元数据信息,如表的信息、区域服务器等
  3. 客户端与HMaster交互HBase客户端向HMaster发送读写请求,请求涉及到的表和列族的元数据信息
  4. HMaster分配RegionServerHMaster根据表的元数据信息,将对应的RegionServer分配给客户端
  5. 客户端与RegionServer交互客户端与被分配的RegionServer进行通信,发送具体的读写请求
  6. RegionServer处理请求RegionServer接收到请求后,根据HBaser表的数据分布规则(Row Key)定位到对应的Region
  7. RegionServer与HDFS交互RegionServer通过HDFS访问底层的数据文件,进行读取或写入操作
  8. 数据读写完成RegionServer将读取到的数据或写入的数据返回给客户端

2、HBase的读写缓存?

写缓存HBase在接收到写请求后,会将数据先写入内存中的写缓存(Write Ahead Log),然后再异步地将数据刷写到磁盘上的数据文件。这种机制可以提高写入性能,因为内存的写入速度远快于磁盘的写入速度。
读缓存HBase再读取数据时,首先会尝试从内存中读缓存(BlockCache)中读取数据,如果缓存中没有相应的数据,则需要从磁盘上的数据文件中读取。读缓存可以提高读取性能,因为内存的读取速度远快于磁盘的读取速度。

3、在删除HBase中的一个数据的时候,它什么时候真正的进行删除呢?

在HBase中,删除操作并不会立即将数据从存储中删除。实际上,删除操作只是在数据的特定版本上打上一个删除标记,标记该数据已经被删除。这是因为HBase使用LSM存储结构。
当执行删除操作时,HBase会创建一个新的版本,并将该版本的数据标记为删除。之后,HBase会在后续的Major Compaction(主要合并)或Minor Compaction(次要合并)过程中,才会真正将带有删除标记的数据从存储中清除
Major Compaction是指HBase将所有的HFile文件进行合并,以减少存储空间的占用,并清理已标记为删除的数据。Major Compaction通常由系统自动触发,但也可以手动执行。
Minor Compaction是指HBase将相邻的小文件进行合并,以减少文件数量和提高读取性能。Minor Compaction也会清理已标记为删除的数据。

4、HBase的一个region由哪些东西组成?

  1. 行键范围(start key 和 end key)每个region都有一个唯一的行键范围,用于标识该region负责存储的数据范围
  2. MemStore:每个region都有一个内存中的MemStore,用于缓存该region内的写入操作。当MemStore的大小达到一定阈值时,会将其刷新到磁盘上的HFile。
  3. HFile每个region都包含一个或多个HFile,用于持久化存储该region内的数据。HFile是HBase中的底层存储格式,以块的形式存储数据,并提供快速的读取和写入操作。
  4. WAL(Write-Ahead-Log)每个region都有一个WAL,用于记录该region内的写入操作。WAL在写入操作发生时先将操作记录到日志中,然后再将数据写入MemStore。WAL的作用是保证数据的持久化和可恢复性。
  5. Region Server:每个region都由一个Region Server负责管理和处理。Region Server是HBase集群中的工作节点,负责处理读写请求、维护和管理region以及与HDFS进行交互

5、HBase的rowkey为什么不能超过一定的长度?为什么要唯一?rowkey太长会影响HFile的存储?

是的,HBase的rowkey不能超过一定的长度是为了保证HBase的性能和存储效率。当rowkey过长时,会导致HBase在存储数据时需要占用更多的存储空间,同时也会增加数据的读取和检索的时间
HBase的存储结构是基于HFile的,HFile使用了类似B+树的索引结构来组织数据。当rowkey过长时,HFile中的索引节点需要占用更多的存储空间,从而导致HFile文件变大,进而影响了存储性能。
此外,rowkey的唯一性是HBase中数据的检索和存储的重要依据。HBase使用rowkey来进行数据的分布和定位,保证了数据在分布式环境下的高效读写和检索。如果rowkey不唯一,可能会导致数据覆盖或重复存储的问题

6、HBase的Get和Scan的区别和联系?

HBase的Get和Scan是两种不同的读取数据的方式
Get操作:是通过指定行键(rowkey)来获取单个数据行的详细信息。通过Get操作,可以获取到指定行键对应的完整数据行,包括所有的行族和列的数据。Get操作适用于需要获取指定行的详细信息的场景。
Scan操作:是通过指定起始行键和终止行键来获取一系列数据行的信息。通过Scan操作,可以按照指定的范围获取多个数据行,范围可以是某个列族的所有数据,也可以是某个列族下某些列的数据。Scan操作适用于需要按照范围获取多个数据行的场景。

7、HBase的预分区?

HBase的预分区是将HBase的表按照指定的规则提前进行分区划分,以便在数据插入时自动将数据分散到不同的Region Server上。这样可以提高数据的负载均衡和查询性能。
预分区可以通过在创建表时指定预分区键来实现。预分区键可以是任意的字节数组,通常是根据数据的特点和访问模式来选择的。
预分区的好处是可以保证数据均匀分布在集群的不同Region Server上,避免数据倾斜问题。此外,预分区还可以提高查询的并行性,因为查询可以同时在多个Region Server上进行。
预分区的规则可以是基于哈希值,也可以是基于范围。基于哈希值的预分区可以确保数据均匀分布,但可能导致某些特定查询需要跨多个Region Server进行。基于范围的预分区可以根据数据的顺序进行分区,可以提高某些特定查询的性能

8、既然HBase底层数据是存储在HDFS上,为什么不直接使用HDFS,而还要用HBase?

首先,HDFS是一个分布式文件系统,主要用于存储大规模数据文件。它具有高容错性、高吞吐量和拓展性好等特点,适用于顺序读写大文件。但是,HDFS并不适用进行随机读写操作,因为它对小文件的支持不够高效
相比之下,HBase是一个分布式的、面向列的NoSQL数据块。它在HDFS上建立了一层抽象,提供了快速的随机读写能力。HBase的设计目标是支持高并发、低延迟的在线数据访问,适用于实时的数据查询和更新。另外,HBase还提供了强一致性的数据模型和灵活的数据模式,可以根据需求动态地添加和删除列。

相关文章:

大数据开发(HBase面试真题-卷二)

大数据开发(HBase面试真题) 1、HBase读写数据流程?2、HBase的读写缓存?3、在删除HBase中的一个数据的时候,它什么时候真正的进行删除呢?4、HBase的一个region由哪些东西组成?5、HBase的rowkey为…...

基于springboot+vue的线上教育系统(源码+论文)

目录 前言 一、功能设计 二、功能实现 三、库表设计 四、论文 前言 现在大家的生活方式正在被计算机的发展慢慢改变着,学习方式也逐渐由书本走向荧幕,我认为这并不是不能避免的,但说实话,现在的生活方式与以往相比有太大的改变,人们的娱乐方式不仅仅…...

01-shell的自学课-基础变量学习

一、echo变量的一个坑 声明【临时变量】,然后打印出来;(拓展:env是linux的全局变量) [rootgong ~]# xinjizhiwashell [rootgong ~]# echo $xinjizhiwa shell [rootgong ~]# echo $xinjizhiwa-haha shell-haha [rootgo…...

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Span)

作为Text组件的子组件,用于显示行内文本的组件。 说明: 该组件从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 该组件从API Version 10开始支持继承父组件Text的属性,即如果子组件未设置…...

前端框架的演进之路:从静态网页到现代交互体验的探索

前端框架的发展史 随着互联网的快速发展,前端技术也在不断进步,前端框架作为前端开发的重要工具,经历了从简单到复杂、从单一到多元的演变过程。本文将回顾前端框架的发展史,探讨其变迁背后的原因和趋势。 一、静态网页时代 在…...

在Linux/Ubuntu/Debian中设置字体

下载字体。 下载你喜欢的字体,双击并安装。 之后更新字体缓存: fc-cache -f -v安装 GNOME 调整。 GNOME Tweaks 是一个工具,允许你自定义 GNOME 桌面环境的各个方面,包括字体。 如果你还没有安装 GNOME Tweaks: …...

Python 常用内置函数,及实例演示

Python的内置函数非常强大,可以帮助你完成各种任务。以下是20个非常有用的Python内置函数及其使用实例: 1. abs() 返回数字的绝对值。 print(abs(-5)) # 输出:52. all() 如果迭代器的所有元素都为真(或迭代器为空&#xff09…...

C++标准输入输出和名字空间

C标准输入输出和名字空间 标准输入输出 在C中,标准输入输出(I/O)是通过标准库中的iostream库来实现的,它提供了一套流(stream)抽象来进行数据的输入和输出操作。这套流抽象包括输入流用于读取数据&#x…...

hive逗号分割行列转换

select * from ( select back_receipt_nos,order_no,reject_no from ods_oneplus.ods_us_wms_reject_order_match_all_d where order_no 10150501385980001 ) t1 lateral view explode(split(t1.back_receipt_nos, ,)) t as back_receipt_no where 1 1;...

Jenkins插件Parameterized Scheduler用法

Jenkins定时触发构建的同时设定参数。可以根据不同的定时构建器设置不同参数或环境变量的值。可以设置多个参数。并结合when控制stage流程的执行。结合when和triggeredBy区分定时构建的stage和手动执行的stage。 目录 什么是Parameterized Scheduler?如何配置实现呢…...

西门子S7.NET通信库【读】操作详解

在使用西门子PLC进行工业自动化控制的过程中,经常需要与PLC进行数据交换。S7.NET是一款广泛应用于.NET平台的西门子PLC通信库,它为开发者提供了一系列的API函数,以便在C#、VB.NET等.NET语言中轻松实现与西门子PLC的数据交互。本文将详细介绍如…...

Qt/C++音视频开发69-保存监控pcm音频数据到mp4文件/监控录像/录像存储和回放/264/265/aac/pcm等

一、前言 用ffmpeg做音视频保存到mp4文件,都会遇到一个问题,尤其是在视频监控行业,就是监控摄像头设置的音频是PCM/G711A/G711U,解码后对应的格式是pcm_s16be/pcm_alaw/pcm_mulaw,将这个原始的音频流保存到mp4文件是会…...

闲聊Swift的枚举关联值

闲聊Swift的枚举关联值 枚举,字面上理解,就是把东西一件件列出来。 在许多计算机语言中,枚举都是一种重要的数据结构。使用枚举可以使代码更简洁,语义性更强,更加健壮。 Swift语言也不例外。但和其他语言相比&#xf…...

抓取Instagram数据:Fizzler库带您进入C#爬虫程序的世界

引言 在当今数字化的世界中,数据是无价之宝。社交媒体平台如Instagram成为了用户分享照片、视频和故事的热门场所。作为开发人员,我们可以利用爬虫技术来抓取这些平台上的数据,进行分析、挖掘和应用。本文将介绍如何使用C#编写一个简单的Ins…...

Codeforces Round 933 (Div. 3) A~D

比赛链接 : codeforces.com/contest/1941 A . Rudolf and the Ticket 直接暴力即可 ; #include<bits/stdc.h> #define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0); #define endl \n #define lowbit(x) (x&(-x)) #define sz(a) (int)a.size() #define p…...

《vtk9 book》 官方web版 第3章 - 计算机图形基础 (3 / 5)

3.8 演员几何 我们已经看到了光照属性如何控制演员的外观&#xff0c;以及相机如何结合变换矩阵将演员投影到图像平面上。剩下的是定义演员的几何形状&#xff0c;以及如何将其定位在世界坐标系中。 建模 计算机图形学研究中的一个重要主题是建模或表示物体的几何形状。…...

pytorch 函数整理

pytorch 函数整理 method_code.init.code.co_argcount&#xff1a;获取method_code.init 函数的输入变量的数目&#xff1b; input_params method_code.init.code.co_varnames&#xff1a;获取method_code.init 函数的输入变量的名称列表&#xff1b; __enter__和__exit__魔…...

docker实战之制作filebeat镜像

一&#xff0c;下载filebeat-6.5.4安装包&#xff1a; https://www.elastic.c o/downloads/beats 二&#xff0c;拉取centos:7镜像 docker pull centos:7 三&#xff0c;将下载的filebeat包放在~/filebeat下&#xff08;自定义就好&#xff09; 四&#xff0c;创建名为fileb…...

【DAY11 软考中级备考笔记】数据结构 查找和排序

数据结构 查找和排序 3月12日 – 天气&#xff1a;晴 1. 顺序查找 顺序查找就是简单的从头一个一个的进行比较&#xff0c;注意它的平均查找长度 2. 折半查找 折半查找和二叉排序树一致&#xff1a; 优点&#xff1a;查找效率很高 缺点&#xff1a;要求必须是循序存储并且表中…...

华为机考:HJ102 字符统计

华为机考&#xff1a;HJ102 字符统计 描述 方法1 先将所有字符计算数量&#xff0c;在对比其中字符的assic码 #include<iostream> #include<vector> #include<algorithm> #include<string> using namespace std; bool cmp(pair<char, int> a,…...

Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误

HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误&#xff0c;它们的含义、原因和解决方法都有显著区别。以下是详细对比&#xff1a; 1. HTTP 406 (Not Acceptable) 含义&#xff1a; 客户端请求的内容类型与服务器支持的内容类型不匹…...

Appium+python自动化(十六)- ADB命令

简介 Android 调试桥(adb)是多种用途的工具&#xff0c;该工具可以帮助你你管理设备或模拟器 的状态。 adb ( Android Debug Bridge)是一个通用命令行工具&#xff0c;其允许您与模拟器实例或连接的 Android 设备进行通信。它可为各种设备操作提供便利&#xff0c;如安装和调试…...

Java面试专项一-准备篇

一、企业简历筛选规则 一般企业的简历筛选流程&#xff1a;首先由HR先筛选一部分简历后&#xff0c;在将简历给到对应的项目负责人后再进行下一步的操作。 HR如何筛选简历 例如&#xff1a;Boss直聘&#xff08;招聘方平台&#xff09; 直接按照条件进行筛选 例如&#xff1a…...

Redis数据倾斜问题解决

Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中&#xff0c;部分节点存储的数据量或访问量远高于其他节点&#xff0c;导致这些节点负载过高&#xff0c;影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念&#xff0c;其实 Fiori当中还有 V4&#xff0c;咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务)&#xff0c;代理中间件&#xff08;ui5-middleware-simpleproxy&#xff09;-CSDN博客…...

管理学院权限管理系统开发总结

文章目录 &#x1f393; 管理学院权限管理系统开发总结 - 现代化Web应用实践之路&#x1f4dd; 项目概述&#x1f3d7;️ 技术架构设计后端技术栈前端技术栈 &#x1f4a1; 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 &#x1f5c4;️ 数据库设…...

springboot整合VUE之在线教育管理系统简介

可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生&#xff0c;小白用户&#xff0c;想学习知识的 有点基础&#xff0c;想要通过项…...

如何更改默认 Crontab 编辑器 ?

在 Linux 领域中&#xff0c;crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用&#xff0c;用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益&#xff0c;允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...

【C++进阶篇】智能指针

C内存管理终极指南&#xff1a;智能指针从入门到源码剖析 一. 智能指针1.1 auto_ptr1.2 unique_ptr1.3 shared_ptr1.4 make_shared 二. 原理三. shared_ptr循环引用问题三. 线程安全问题四. 内存泄漏4.1 什么是内存泄漏4.2 危害4.3 避免内存泄漏 五. 最后 一. 智能指针 智能指…...

Git 3天2K星标:Datawhale 的 Happy-LLM 项目介绍(附教程)

引言 在人工智能飞速发展的今天&#xff0c;大语言模型&#xff08;Large Language Models, LLMs&#xff09;已成为技术领域的焦点。从智能写作到代码生成&#xff0c;LLM 的应用场景不断扩展&#xff0c;深刻改变了我们的工作和生活方式。然而&#xff0c;理解这些模型的内部…...