Mac下安装HBase及详解
Mac下安装HBase及详解
1. 千篇一律的HBase简介
HBase是Hadoop的数据库, 而Hive数据库的管理工具, HBase具有分布式, 可扩展及面向列存储的特点(基于谷歌BigTable). HBase可以使用本地文件系统和HDFS文件存储系统, 存储的是松散的数据(key-value的映射关系).
HBase位于HDFS的上层, 向下提供存储, 向上提供运算
2. HBase安装
HBase有单机, 伪分布式, 全分布式运行模式
依赖:
- 匹配HBase的Hadoop版本
- Java JDK 1.6+
- SSH
安装
$ brew install hbase
# 安装在/usr/local/Cellar/hbase/1.0.0
配置HBase
在conf/hbase-env.sh设置JAVA_HOME
$ cd /usr/local/Cellar/hbase/1.0.0/libexec/conf
$ vim hbase-env.sh
export JAVA_HOME="/usr/bin/java"
在conf/hbase-site.xml设置HBase的核心配置
$ vim hbase-site.xml
<configuration>
<property>
<name>hbase.rootdir</name>
//这里设置让HBase存储文件的地方
<value>file:///Users/andrew_liu/Downloads/hbase</value>
</property>
<property>
<name>hbase.zookeeper.property.dataDir</name>
//这里设置让HBase存储内建zookeeper文件的地方
<value>/Users/andrew_liu/Downloads/zookeeper</value>
</property>
</configuration>
/usr/local/Cellar/hbase/1.0.0/bin/start-hbase.sh提供HBase的启动
$ ./start-hbase.sh
starting master, logging to /usr/local/Cellar/hbase/1.0.0/libexec/bin/../logs/hbase-andrew_liu-master-Andrew-liudeMacBook-Pro.local.out
验证是否安装成功
$ jps
3440 Jps
3362 HMaster # 有HMaster则说明安装成功
1885
启动HBase Shell
$ ./bin/hbase shell
HBase Shell; enter 'help<RETURN>' for list of supported commands.
Type "exit<RETURN>" to leave the HBase Shell
Version 1.0.0, r6c98bff7b719efdb16f71606f3b7d8229445eb81, Sat Feb 14 19:49:22 PST 2015
1.8.7-p357 :001 >
1.8.7-p357 :001 > exit #退出shell
停止HBase运行
$ ./bin/stop-hbase.sh
stopping hbase....................
3. 伪分布式模式
必须关闭HBase
修改hbase-env.sh
HBASE_MANAGE_XK = true
修改hbase-site.xml, 设置HBase使用分布式模式运行
<configuration>
<property>
<name>hbase.rootdir</name>
//Here you have to set the path where you want HBase to store its files.
<value>hdfs://localhost:8020/hbase</value>
</property>
<property>
<name>hbase.cluster.distributed</name>
<value>true</value>
</property>
</configuration>
hbase.rootdir路径一定要跟hadoop中core-site.xml中fs.default.name相同change the hbase.rootdir from the local filesystem to the address of your HDFS instance ---offical quick start
如何两处设置不同会引起ERROR: Can't get master address from ZooKeeper; znode data == null错误错误
在启动HBase之前, 请先启动Hadoop, 使之运行
启动HBase
$ ./start-hbase.sh
$ jps #验证是否启动成功, 包含HMaster和HRegionServer说明启动成功
6400 DataNode
7872 Jps
7702 HMaster
7624 HQuorumPeer
6315 NameNode
6508 SecondaryNameNode
6716 NodeManager
7804 HRegionServerHBase
6623 ResourceManager
如果在启动HBase后, 提示如下
regionserver running as process 4667. Stop it first.
#请执行以下操作
$ kill -9 4667 #这里4667是要杀掉的进程号
启动成功HBase会在HDFS下创建/hbase目录
$ hdfs dfs -ls /hbase
4. HBase Shell
$ hbase shell #启动HBase Shell
#创建表
> create 'student', 'description', 'course' #创建表名为student的表, 指明两个列名, 分别为description和course
#信息明细
> list 'student' #列出list表信息
#插入数据
> put 'student', 'row1', 'description:age', '18' #意思为在student表row1处插入description:age的数据为18
> put 'student', 'row1', 'description:name', 'liu'
put 'student', 'row1', 'course:chinese', '100'
#一次扫描所有数据
> scan 'student
#使表失效 / 有效
> disable 'student'
> enable 'student'
#删除表(要先disable)
> drop 'student'
#退出shell
> quit
5. HBase与HDFS
HBase是一个稀疏的长期存储的, 多维度的, 排序的映射表, 通过行键, 行键 + 时间戳 或 行键 + 列(列族: 列修饰符)就可以定位特殊的数据
5.1. HBase体系结构
HBase的服务器体系遵从简单的主从服务器架构, 由HRegion服务器群和HBase服务器构成, Master服务器负责管理所有的HRegion服务器, 而HBase中所有的服务器通过ZooKeeper来进行协调并处理HBase服务器运行期间可能遇到的错误.
HBase逻辑上的表可能会被划分为多个HRegion, 然后存储在HRegion服务器上.
- HBase不涉及数据的直接删除和更新, 当Store中的Storefile数量超出阈值会触发合并操作
- HMaster的主要任务是告诉每个HRegion服务器它要维护那些HRegion
- ZooKeeper存储的是HBase中ROOT表和META表的位置, ZooKeeper还负责监控各个机器的状态
元数据子表采用三级索引结构: 根子表->用户表的元数据表->用户表
5.2. Java API
- HBaseConfiguration, 通过此类对HBase进行配置
- HBaseAdmin, 提供一个接口来管理HBase数据库的表信息, 提供创建, 删除表, 列出表项,
使表有效或无效, 以及添加或删除列族成员 - HTableDescriptor, 包含了表的名字及对应表的列族
- HColumnDescriptor, 维护关于列族的信息
- HTable, 用来与HBase表进行通信
- Put, 用来对单个行执行添加操作
- Get, 用来获取单个行的相关信息
- Result, 存储Get或者Scan操作后获取的表的单行值
6. 参考链接
Mac下安装HBase及详解的更多相关文章
- 【Node.js】Mac 下安装node图文详解
1 进入官网,下载node最新版 官网:https://nodejs.org/en/ 2 双击下载的安装包,一路默认安装就行 3 打开终端,输入以下命令查看结果,如出现下图信息则为安装成功 4 ...
- (转)windows 下安装配置 Nginx 详解
windows 下安装配置 Nginx 详解 本文转自https://blog.csdn.net/kingscoming/article/details/79042874 nginx功能之一可以启动一 ...
- 在RedHat 5下安装Oracle 10g详解(转)
在RedHat 5下安装Oracle 10g详解(转) Posted on 2012-09-14 13:26 疯狂 阅读(5075) 评论(0) 编辑 收藏 所属分类: database .uni ...
- Ubuntu下安装JDK图文详解
很详细的在Ubuntu中安装JDK图文详解教程,我们选择的是jdk1.6.0_30版本.安装文件名为jdk-6u30-linux-i586.bin. 1.复制jdk到安装目录 (1)假设jdk安装文件 ...
- RedHat 7.1 下安装 Zabbix监控程序详解(适合linux初级用户)
RedHat 7.1 安装 Zabbix 监控程序详解(适合对linux初级用户)2017-05-02 安装步骤: 1.zabbix需要安装LAMP架构 2.安装zabbix服务 3.初始化zabbi ...
- Linux下安装软件命令详解
---------------------------------------------------------------- 或许你对于linux还不够了解,但是一旦你步入公司后,你就会发现lin ...
- windows下安装Mysql—图文详解
mysql安装过程及注意事项: 1.1. 下载: 我下载的是64位系统的zip包: 下载地址:https://dev.mysql.com/downloads/mysql/ 下载zip的包: 下载后解压 ...
- windows下安装Mysql(图文详解)
博客园 | 首页 | 新随笔 | 联系 | 订阅 | 管理 mysql安装过程及注意事项: 1.1. 下载: 我下载的是64位系统的zip包: 下载地址:https://dev.mysql.com ...
- Windows下安装solr步骤详解
Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引:也可以通过Http Get操 ...
随机推荐
- php字符串函数和数组函数
/验证码$str="abcdefghijklmnopqrstuvwxyz0123456789";$a=substr($str,rand(0,35),1);$b=substr($st ...
- STM32的SPI问题。
问题描述: 之前一直使用的单片机是LPC2109,对其SPI很熟悉.基本就是原本拿来稍作修改就用.由于某种原因需要使用STM32,然后设备的驱动是之前写好的,只修改了一些硬件控制端口,由于硬件驱动使用 ...
- matlab查找回车字符
Hi all, I would like to read the data all at once with: `file_text = fread(fid, inf, 'uint8=>char ...
- 2064: 分裂 - BZOJ
Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力. 同时经常搞OI的他把这个变成了一个数学模型. 假设中 ...
- NuGet使用简要说明
引言 什么是NuGet?Nuget是 ASP .NET Gallery 的一员.NuGet 是免费.开源的包管理开发工具,专注于在 .NET 应用开发过程中,简单地合并第三方的组件库.当需要分享开发的 ...
- POJ 1068 AC 2014-01-07 15:24 146人阅读 评论(0) 收藏
POJ的题目都是英文的,所以,,,还是直接贴代码吧 #include<stdio.h> int main(){ int x,y,z; int n,nm,max; scanf("% ...
- Eclipse plugin插件开发 NoClassDefFoundError
Eclipse的每一个plugin都有属于自己的类加载器,这是OSGI架构的基础,每一个plugin项目都是一个bundle,独立运行在各自的运行环境里面,这就造成了开发时和运行时的不同. Eclip ...
- POJ 3286 How many 0's?
题目链接 题意 :写下m到n之间所有的数,会写多少个0. 思路 :先算0到m的,再算0到n的,最后相减. 网上有位大神是这么推的,看下面.... 首先转化成求 [0, x] 中所有数中,含有的 0 的 ...
- POJ2151Check the difficulty of problems
题意 : 举办一次比赛不容易,为了不让题目太难,举办方往往希望能够讲出的题目满足两点,1是所有的队伍都至少能够解出一个题目,2是冠军队至少能解出确定数量的题目,最后让你求的是每个队伍至少解出一道题并且 ...
- lintcode 中等题: reverse linked list II 翻转链表II
题目 翻转链表 II 翻转链表中第m个节点到第n个节点的部分 样例 给出链表1->2->3->4->5->null, m = 2 和n = 4,返回1->4-> ...