HBase安装配置

本文详细介绍了HBase的安装配置过程,包括下载、传输、解压、配置环境变量等步骤,还说明了伪分布式模式下的配置方法。同时,讲解了进入HBase数据库的操作,如创建表、添加数据等。此外,提及了HBase架构原理,并给出相关参考资料,还列举了一些常见报错及解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HBase安装配置

①下载压缩包(选择与自己安装的Hadoop版本的兼容版本,见后面附录)
官网下载地址:https://mirrors.tuna.tsinghua.edu.cn/apache/hbase/stable/
选择稳定版hbase-1.4.9-bin.tar.gz,在Windows里面下载。

②将压缩包从Windows传输到Linux当前目录下
SecureCRT 【File】→【Connect SFTP Session】开启sftp操作
在这里插入图片描述

③安装
解压安装到指定目录下/opt/module(/opt是系统自带目录,之下的/module是自己创建的)
在这里插入图片描述

④配置环境变量
在/etc/profile文件里添加HBase安装路径的配置信息,之后用source命令使配置生效。安装之后的目录为hbase-1.4.9,修改为hbase,所以我的HBase安装路径是/opt/module/hbase。
vi /etc/profile文件添加:
在这里插入图片描述
Esc :wq!保存并退出。
source /etc/profile配置生效
测试HBase安装成功,命令hbase version,或hbase。在这里插入图片描述
**

HBase配置(伪分布式模式

**)
配置文件位于HBase安装路径的conf目录(/opt/module/hbase/conf)下面

①配置hbase-(vi /opt/module/hbase/conf/hbase-env.sh)
设置Java安装路径
在这里插入图片描述
设置HBase的配置文件路径
在这里插入图片描述
采用HBase自带Zookeeper,设置参数true

在这里插入图片描述
②配置hbase-site.xml(vi /opt/module/hbase/conf/hbase-site.xml)

hbase.rootdir hdfs://bigdata128:9000/hbase hbase.cluster.distributed true hbase.zookeeper.quorum localhost

③启动并运行HBase(之前启动Hadoop)
启动HBase,并jps查看
在这里插入图片描述
在这里插入图片描述
用完停止HBase运行(之后停止Hadoop)

在这里插入图片描述

进入HBase数据库

进入HBase的shell命令行模式
在这里插入图片描述
了解命令使用方法,如创建表,输入help ‘create’

①创建表

在这里插入图片描述
②添加数据
在这里插入图片描述

③查看数据
在这里插入图片描述在这里插入图片描述

④删除数据
删除一个单元格
在这里插入图片描述
删除一行

在这里插入图片描述
⑤删除表

在这里插入图片描述

HBase架构原理

https://www.cnblogs.com/steven-note/p/7209398.html

Hbase Java API
https://www.cnblogs.com/liuwei6/p/6842536.html
https://www.cnblogs.com/tiantianbyconan/p/3557571.html
参考资料:
Linux下配置环境变量最常用的两种方法—— .bashrc 和 /etc/profile
https://blog.csdn.net/sun8112133/article/details/79901527

学习 HBase,应该选择哪个版本?
https://blog.csdn.net/tzhuwb/article/details/81153323

https://www.csdn.net/gather_2a/MtTaEgzsODU5Mi1ibG9n.html
在这里插入图片描述
WARN [main] zookeeper.ZooKeeperNodeTracker: Can’t get or delete the master znode
Will not attempt to authenticate using SASL (unknown error)
建表之后查看logs报错
ERROR [main] client.ConnectionManager H C o n n e c t i o n I m p l e m e n t a t i o n : C a n ′ t g e t c o n n e c t i o n t o Z o o K e e p e r : K e e p e r E r r o r C o d e = C o n n e c t i o n L o s s f o r / h b a s e 建 表 时 报 错 C a n ′ t g e t c o n n e c t i o n t o Z o o K e e p e r : K e e p e r E r r o r C o d e = C o n n e c t i o n L o s s f o r / h b a s e 重 新 停 止 、 启 动 H B A S E , 查 看 l o g s , 报 错 2019 − 04 − 0410 : 41 : 52 , 238 I N F O [ M : 0 ; b i g d a t a 128 : 35321 − S e n d T h r e a d ( l o c a l h o s t : 2181 ) ] z o o k e e p e r . C l i e n t C n x n : O p e n i n g s o c k e t c o n n e c t i o n t o s e r v e r l o c a l h o s t / 127.0.0.1 : 2181. W i l l n o t a t t e m p t t o a u t h e n t i c a t e u s i n g S A S L ( u n k n o w n e r r o r ) H b a s e s h e l l 运 行 s t a t u s 报 错 2019 − 04 − 0410 : 49 : 55 , 710 E R R O R [ m a i n ] c l i e n t . C o n n e c t i o n M a n a g e r HConnectionImplementation: Can't get connection to ZooKeeper: KeeperErrorCode = ConnectionLoss for /hbase 建表时报错 Can't get connection to ZooKeeper: KeeperErrorCode = ConnectionLoss for /hbase 重新停止、启动HBASE,查看logs,报错2019-04-04 10:41:52,238 INFO [M:0;bigdata128:35321-SendThread(localhost:2181)] zookeeper.ClientCnxn: Opening socket connection to server localhost/127.0.0.1:2181. Will not attempt to authenticate using SASL (unknown error) Hbase shell 运行status 报错2019-04-04 10:49:55,710 ERROR [main] client.ConnectionManager HConnectionImplementation:CantgetconnectiontoZooKeeper:KeeperErrorCode=ConnectionLossfor/hbaseCantgetconnectiontoZooKeeper:KeeperErrorCode=ConnectionLossfor/hbaseHBASElogs2019040410:41:52,238INFO[M:0;bigdata128:35321SendThread(localhost:2181)]zookeeper.ClientCnxn:Openingsocketconnectiontoserverlocalhost/127.0.0.1:2181.WillnotattempttoauthenticateusingSASL(unknownerror)Hbaseshellstatus2019040410:49:55,710ERROR[main]client.ConnectionManagerHConnectionImplementation: Can’t get connection to ZooKeeper: KeeperErrorCode = ConnectionLoss for /hbase

在这里插入图片描述
启动hbase,报错:
ERROR [main] server.ZooKeeperServer: ZKShutdownHandler is not registered
ERROR [main] master.HMasterCommandLine: Master exiting
java.io.IOException: Could not start ZK at requested port of 2181. ZK was started at port: 2182. Aborting as clients (e.g. shell) will not be able to find this ZK quorum.

关闭防火墙service iptables stop

### HBase 安装配置教程 #### 准备工作 在安装 HBase 前,需确认已准备好 Linux 环境并完成 Java 和 Zookeeper 的安装HBase 需要依赖于特定版本的 Hadoop 和 Zookeeper 运行,因此选择合适的版本组合至关重要[^1]。 --- #### 下载 HBase 安装包 访问官方或可信源下载适合的 HBase 版本。例如,可以通过 Apache 官方网站或者阿里云开源镜像站获取最新稳定版 `hbase-2.5.10-bin.tar.gz` 文件[^4]。 --- #### 解压安装包 使用以下命令解压 HBase 安装包至目标目录: ```bash tar -zxvf hbase-2.4.14-bin.tar.gz -C /usr/local/ ``` 完成后重命名文件夹以便管理: ```bash mv /usr/local/hbase-2.4.14 /usr/local/hbase ``` 此操作会将 HBase 安装到 `/usr/local/hbase/` 路径下[^3]。 --- #### 配置环境变量 编辑 `.bashrc` 或者全局环境变量文件 `/etc/profile` 添加如下内容: ```bash export HBASE_HOME=/usr/local/hbase export PATH=$PATH:$HBASE_HOME/bin ``` 保存修改后执行以下命令使更改生效: ```bash source ~/.bashrc ``` 验证是否成功设置路径: ```bash echo $HBASE_HOME which hbase ``` 如果返回正确的路径,则说明配置无误。 --- #### 修改核心配置文件 进入 HBase 主目录下的 `conf` 子目录进行必要的参数调整: ##### 1. **hbase-env.sh** 打开该脚本找到 `JAVA_HOME` 变量定义部分,并指定实际使用的 JDK 地址: ```bash vi conf/hbase-env.sh ``` 添加或更新为当前系统的 JAVA_HOME 设置: ```bash export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64 ``` 同时启用分布式模式支持(可选),取消注释下面两行代码: ```bash export HBASE_MANAGES_ZK=false ``` 上述选项表示不启动内置 ZK 实例而连接外部集群服务[^2]。 ##### 2. **hbase-site.xml** 创建 XML 形式的站点属性文档用于描述运行时行为特性。以下是单机测试场景的一个简单模板实例: ```xml <configuration> <!-- 指定存储位置 --> <property> <name>hbase.rootdir</name> <value>file:///home/user/hbase/data</value> </property> <!-- 启动本地伪分布模式 --> <property> <name>hbase.cluster.distributed</name> <value>false</value> </property> <!-- 外部ZooKeeper地址列表 (仅当关闭内部zk时有效)--> <property> <name>hbase.zookeeper.quorum</name> <value>localhost</value> </property> </configuration> ``` 注意:对于生产环境中多台机器组成的 HA 架构而言,还需要进一步扩展更多字段项来满足需求。 --- #### 初始化数据库结构 首次启动之前需要初始化底层表空间元数据信息。切换到 bin 目录输入指令即可完成这项任务: ```bash cd /usr/local/hbase/bin ./hbase-daemon.sh start master sleep 5s && ./create_table_example.sh ``` 此时可以登录 shell 查看状态以及尝试 CRUD 测试用例验证功能正常运作情况: ```bash hbase shell list &#39;mytable&#39; put &#39;mytable&#39;, &#39;rowkey1&#39;, &#39;cf:col1&#39;, &#39;value1&#39; scan &#39;mytable&#39; disable &#39;mytable&#39;; drop &#39;mytable&#39;; exit; ``` 以上步骤展示了如何从零构建起一套完整的开发调试框架体系。 --- ### 注意事项 - 如果计划采用完全分布式部署方案,请提前规划好网络拓扑关系图并分配静态 IP 给每台服务器节点。 - 不同操作系统之间可能存在细微差异,在遇到异常状况时查阅对应发行版手册寻求帮助。 - 推荐定期备份重要业务资料以防意外丢失风险发生。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值