Hbase学习记录(1)|伪分布式安装
概述
Hbase –Haddop Database 是一个高性能,高可靠性、面向列、可伸缩的分布式存储系统。
Hbase利用HDFS作为文件存储系统,利用MapReduce来处理Hbase的海量数据,利用Zookeeper作为协调工具。
是NoSQL的一种。
数据模型

表(table),是用来存储管理数据的,是在schema声明的时候定义
行健(row key),类似于MySQL中的主键,与MySQL不同的是Hbase表天然自带的。
可以是字符串、整数、二进制串、串行化的结构。
按照字典顺序由低到高存储在表中的。
列族(column family),列的集合,在Hbase中列族需要在定义表时指定的,列是在插入记录时动态添加的。Hbase表中的数据,每个列族单独一个文件。
Cells ,A{row,column,version}元组就是一个Hbase中的一个cell。内容是不可分割的字节数组。
时间戳(timestamp),列(也称作标签、修饰符)的一个属性。行键和列确定的单元格,可以存储多个数据,每个数据含有时间戳属性,数据具有版本特性。如果不指定时间戳或者版本,默认取最新的数据。
Version,用一个长整型表示,是当前时间和1970-01-01的时间差,单位毫秒。
存储的数据都是字节数组。
存储顺序,表中的数据是按照行健的顺序物理存储的,关系型数据库是按照插入顺序存储的。
逻辑数据模型
数据模型的一行:
表按照行键的“逐字节排序”顺序对行进行有序化处理。
表内数据非常‘稀疏’,不同的行的列的数完全目可以大不相同。
可以只对一行上”锁“。
对行的写操作始终是”原子“的。
数据模型一列
列比较用‘族’famliy来定义。
任意一列形式:”族:标签”,其中,族和标签都可为任意形式的串。
物理上将同“族”数据存储在一起。
数据可以用通过时间戳区分版本。
物理数据模型

物理模型

Hbase是适合海量数据(PB)的秒级简单查询的数据库。
Hbase中的记录,按照行键进行拆分,拆分成一个个的region。
region存储在region server(单独的物理机器)中的,这样对表的操作转化为对多台region server中。
region的大小设置参数:hbase.hregion.max.filesize
体系架构
Hbase是主从式结构,Hmaster、HregionServer。
Client包含访问hbase的接口,client维护着一些cache来加快对hbase的访问,比如region的位置信息。
Zookeeper
保证任何时候,急群众只有一个运行的Master
存储所有Reion的寻址入口。
实时监控Region Server的状态,将Region Server的上下线信息实时通知给Master
存储Hbase的schema,包括有哪些table,每个table有哪些column family。
Master Server
可以启动多个Hmaster,通过Zookeeper的MasterElection机制保证总有一个Master运行。
负责Region Server分配region。
负责region server的负载均衡。
发现失效的region server并重新分配其上的region。
Region Server
负责Master分配给它的region,处理对这些region的IO请求。
负责切分在运行过程中变得过大的region。
总结:client访问hbase上数据的过程并不需要master参与,寻址访问zookeeper和region server数据读写访问region server。HregionServer主要负责响应用户I/O请求,向HDFS文件系统读写数据,是Hbase中最核心的模块。
Hbase初始化表
Hbase中有两张特殊的Table,-ROOT-和.META.
.META.: 记录了用户表中的Region信息,.META.可以用多个region。
-ROOT-:记录了.META.表中的Region信息,-ROOT-只有一个region。
Zookeeper中记录了-ROOT-表中的location。
Client访问用户数据之前首先访问Zookeeper,然后访问-ROOT-表,接着访问.META.表,最后才能找到用户数据的位置去访问。

Hbase伪分布安装
1、解压、更改目录名
tar –zxvf hbase-xxx.tar.gz –C /usr/src
cp –r hbase-xxx/ /usr/local/hbase
2、配置环境变量,执行立即生效
vi /etc/profile
export HBASE_HOME=/usr/local/hbase
PATH中添加:$HBASE_HOME/bin
source /etc/profile 立即生效
3、修改配置文件
hbase-env.sh
export /usr/local/jdk
export HBASE_MANAGES_ZK=true
hbase-site.xml
<property>
<name>hbase.rootdir</name>
<value>hdfs://h1:9000/hbase</value>
</property>
<property>
<name>hbase.cluster.distributed</name>
<value>true</value>
</property>
<property>
<name>hbase.zookeeper.quorum</name>
<value>h1</value>
</property>
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
注意:hbase.rootdir设置的主机名和端口必须与hadoop的dfs.default.name的主机名端口设置一致。
冗余master时:需要在conf中创建back-masters文件中添加master主机名。
4、文件regionservers(可选)
内容为主机名,如 h1
5、启动
启动hbase之前,确保hadoop是运行正常的。
start-hbase.sh
6、jps检验
4749 HMaster
4914 HRegionServer
4681 HquorumPeer
Hbase学习记录(1)|伪分布式安装的更多相关文章
- HBase基础和伪分布式安装配置
一.HBase(NoSQL)的数据模型 1.1 表(table),是存储管理数据的. 1.2 行键(row key),类似于MySQL中的主键,行键是HBase表天然自带的,创建表时不需要指定 1.3 ...
- HBase伪分布式安装(HDFS)+ZooKeeper安装+HBase数据操作+HBase架构体系
HBase1.2.2伪分布式安装(HDFS)+ZooKeeper-3.4.8安装配置+HBase表和数据操作+HBase的架构体系+单例安装,记录了在Ubuntu下对HBase1.2.2的实践操作,H ...
- hbase伪分布式安装(单节点安装)
hbase伪分布式安装(单节点安装) http://hbase.apache.org/book.html#quickstart 1. 前提配置好java,环境java变量 上传jdk ...
- Hbase伪分布式安装
前面的文章已经讲过hadoop伪分布式安装,这里直接介绍hbase伪分布式安装. 1. 下载hbase 版本hbase 1.2.6 2. 解压hbase 3. 修改hbase-env.sh 新增如下内 ...
- Hadoop生态圈-hbase介绍-伪分布式安装
Hadoop生态圈-hbase介绍-伪分布式安装 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.HBase简介 HBase是一个分布式的,持久的,强一致性的存储系统,具有近似最 ...
- 第二章 伪分布式安装hadoop hbase
安装单机模式的hadoop无须配置,在这种方式下,hadoop被认为是一个单独的java进程,这种方式经常用来调试.所以我们讲下伪分布式安装hadoop. 我们继续上一章继续讲解,安装完先试试SSH装 ...
- 指导手册02:伪分布式安装Hadoop(ubuntuLinux)
指导手册02:伪分布式安装Hadoop(ubuntuLinux) Part 1:安装及配置虚拟机 1.安装Linux. 1.安装Ubuntu1604 64位系统 2.设置语言,能输入中文 3.创建 ...
- 一.Kylin的伪分布式安装
一.伪分布式安装kylin 2018年4月15日 15:06 安装需要的环境 1. hadoop集群环境:由于安装的是CDH5.14.0的版本,所以相关组件都是跟5.14.0相关 2. spark采用 ...
- Hadoop大数据初入门----haddop伪分布式安装
一.hadoop解决了什么问题 hdfs 解决了海量数据的分布式存储,高可靠,易扩展,高吞吐量mapreduce 解决了海量数据的分析处理,通用性强,易开发,健壮性 yarn 解决了资源管理调度 二. ...
- Hadoop开发第3期---Hadoop的伪分布式安装
一.准备工作 1. 远程连接工具的安装 PieTTY 是在PuTTY 基础上开发的,改进了Putty 的用户界面,提供了多语种支持.Putty 作为远程连接linux 的工具,支持SSH 和telne ...
随机推荐
- 无开发经验,初学python
1.无开发经验,初学python 如果你不会其他语言,python是你的第一门语言: A Byte of Python (简明python教程,这个有中文版简明 Python 教程)是非常好的入门 ...
- MongoDB 学习笔记(三) MongoDB (replica set) 集群配置
MongoDB Replica Sets的结构类似于以集群,完全可以把他当成一个集群,因为他确实与集群实现的作用是一样的:如果其中一个节点出现故障,其他的节点会马上将业务接管过来.而无需停机操作 Mo ...
- HibernateTools实现pojo类 数据库schma mapping映射的相互转换
核心 利用HibernateTools,从POJO类,Mapping映射文件,数据库表有其中的一项,就能生成其他两项. 概述 在使用Hibernate开发系统持久层时,按照一般开发流程 1.分析业务 ...
- tuning 02 Diagnostic and Tuning Tools
statspack 是一个很重要的工具, 这是我们重点要知道的在这章 每天一上班就要看一下 alert log 文件, 可以通过/ORA找, 这是vi的知识,所有的ORACLE错误都是以ORA开头的 ...
- [Android] Android开发优化之——使用软引用和弱引用
Java从JDK1.2版本开始,就把对象的引用分为四种级别,从而使程序能更加灵活的控制对象的生命周期.这四种级别由高到低依次为:强引用.软引用.弱引用和虚引用. 这里重点介绍一下软引用和弱引用. ...
- .gitignore规则不生效的解决办法
.gitignore规则不生效的解决办法 使用git 的时候,在.gitignore中已经添加了某个文件或者文件夹,但是使用git status还能看见该文件的修改提示--–说明.gitignore未 ...
- hdu 4655 Cut Pieces 找规律
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4655 题意:给你一组整数,代表每个木块所能涂成的颜色种数(编号1~ai),相邻的两块所能涂成的颜色如果是一 ...
- wince6下载地址
http://geekswithblogs.net/WindowsEmbeddedCookbook/archive/2010/08/31/installing-windows-ce-6.0-tools ...
- (转载) jQuery 页面加载初始化的方法有3种
jQuery 页面加载初始化的方法有3种 ,页面在加载的时候都会执行脚本,应该没什么区别,主要看习惯吧,本人觉得第二种方法最好,比较简洁. 第一种: $(document).ready(functio ...
- ecshop文章详情页显示浏览数
1.后台执行以下SQL语句 ) NOT NULL 2.找到article.php的这段代码 else { $smarty->display('article_pro.dwt', $cache_i ...