当前位置: 首页 > 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,…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

vue3 字体颜色设置的多种方式

在Vue 3中设置字体颜色可以通过多种方式实现&#xff0c;这取决于你是想在组件内部直接设置&#xff0c;还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法&#xff1a; 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...

Qt Http Server模块功能及架构

Qt Http Server 是 Qt 6.0 中引入的一个新模块&#xff0c;它提供了一个轻量级的 HTTP 服务器实现&#xff0c;主要用于构建基于 HTTP 的应用程序和服务。 功能介绍&#xff1a; 主要功能 HTTP服务器功能&#xff1a; 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...

HTML前端开发:JavaScript 常用事件详解

作为前端开发的核心&#xff0c;JavaScript 事件是用户与网页交互的基础。以下是常见事件的详细说明和用法示例&#xff1a; 1. onclick - 点击事件 当元素被单击时触发&#xff08;左键点击&#xff09; button.onclick function() {alert("按钮被点击了&#xff01;&…...

什么是Ansible Jinja2

理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具&#xff0c;可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板&#xff0c;允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板&#xff0c;并通…...

群晖NAS如何在虚拟机创建飞牛NAS

套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...

yaml读取写入常见错误 (‘cannot represent an object‘, 117)

错误一&#xff1a;yaml.representer.RepresenterError: (‘cannot represent an object’, 117) 出现这个问题一直没找到原因&#xff0c;后面把yaml.safe_dump直接替换成yaml.dump&#xff0c;确实能保存&#xff0c;但出现乱码&#xff1a; 放弃yaml.dump&#xff0c;又切…...

写一个shell脚本,把局域网内,把能ping通的IP和不能ping通的IP分类,并保存到两个文本文件里

写一个shell脚本&#xff0c;把局域网内&#xff0c;把能ping通的IP和不能ping通的IP分类&#xff0c;并保存到两个文本文件里 脚本1 #!/bin/bash #定义变量 ip10.1.1 #循环去ping主机的IP for ((i1;i<10;i)) doping -c1 $ip.$i &>/dev/null[ $? -eq 0 ] &&am…...