Zookeeper与HBase的安装
一、Zookeeper的安装
1.http://www-us.apache.org/dist/zookeeper/stable/下载Zookeeper安装包,并将zookeeper-3.4.12.tar.gz复制到/home/jun下并解压
[jun@master ~]$ cd zookeeper-3.4./
[jun@master zookeeper-3.4.]$ ls -l
total
drwxr-xr-x. jun jun Mar : bin
-rw-rw-r--. jun jun Mar : build.xml
drwxr-xr-x. jun jun Mar : conf
drwxr-xr-x. jun jun Mar : contrib
drwxr-xr-x. jun jun Mar : dist-maven
drwxr-xr-x. jun jun Mar : docs
-rw-rw-r--. jun jun Mar : ivysettings.xml
-rw-rw-r--. jun jun Mar : ivy.xml
drwxr-xr-x. jun jun Mar : lib
-rw-rw-r--. jun jun Mar : LICENSE.txt
-rw-rw-r--. jun jun Mar : NOTICE.txt
-rw-rw-r--. jun jun Mar : README.md
-rw-rw-r--. jun jun Mar : README_packaging.txt
drwxr-xr-x. jun jun Mar : recipes
drwxr-xr-x. jun jun Mar : src
-rw-rw-r--. jun jun Mar : zookeeper-3.4..jar
-rw-rw-r--. jun jun Mar : zookeeper-3.4..jar.asc
-rw-rw-r--. jun jun Mar : zookeeper-3.4..jar.md5
-rw-rw-r--. jun jun Mar : zookeeper-3.4..jar.sha1
2.使用gedit编辑zoo.cfg配置文件
[jun@master zookeeper-3.4.]$ cp /home/jun/zookeeper-3.4./conf/zoo_sample.cfg /home/jun/zookeeper-3.4./conf/zoo.cfg
[jun@master zookeeper-3.4.]$ gedit /home/jun/zookeeper-3.4./conf/zoo.cfg
将下面的配置增加到最后面,配置的意思是“服务器编号、服务器地址、LF通信端口(Leader与Follower)、选举端口”
server.=master::
server.=slave0::
server.=slave1::
3.创建节点标志文件
由于在zoo.cfg当中配置了三台服务器,每一台服务器本地也需要一个myid文件,里面包含服务器的ID号,需要在三台机器上都创建myid文件。以master为例:
首先递归创建目录(-p)
[jun@master zookeeper-3.4.]$ mkdir -p /tmp/zookeeper
[jun@master zookeeper-3.4.]$ gedit /tmp/zookeeper/myid
然后新建myid文件并输入对应的id号,只输入一个1即可。
[jun@master zookeeper-3.4.]$ cat /tmp/zookeeper/myid
另外两台机器同理。
4.将Zookeeper安装文件从master复制到slave上(-r的意思是拷贝所有的文件和文件夹)
[jun@master zookeeper-3.4.]$ scp -r /home/jun/zookeeper-3.4./ slave0:~
[jun@master zookeeper-3.4.]$ scp -r /home/jun/zookeeper-3.4./ slave1:~
5.Zookeeper集群的启动
(1)需要在三个节点上分别执行启动操作
[jun@master zookeeper-3.4.]$ /home/jun/zookeeper-3.4./bin/zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4./bin/../conf/zoo.cfg
Starting zookeeper ... STARTED [jun@slave0 ~]$ /home/jun/zookeeper-3.4.12/bin/zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4.12/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED [jun@slave1 ~]$ /home/jun/zookeeper-3.4.12/bin/zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4.12/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
(2)至少启动两台服务器后,集群才会开始选举leader节点,可以在三台服务器上分别查看集群的状态,可以看到slave0节点是leader节点。
[jun@master ~]$ /home/jun/zookeeper-3.4./bin/zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: follower [jun@slave0 ~]$ /home/jun/zookeeper-3.4./bin/zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: leader [jun@slave1 ~]$ /home/jun/zookeeper-3.4./bin/zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /home/jun/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: follower
(3)Zookeeper客户端交互式操作
[jun@master ~]$ /home/jun/zookeeper-3.4./bin/zkCli.sh -server master:
Connecting to master:
-- ::, [myid:] - INFO [main:Environment@] - Client environment:zookeeper.version=3.4.-e5259e437540f349646870ea94dc2658c4e44b3b, built on // : GMT
-- ::, [myid:] - INFO [main:Environment@] - Client environment:host.name=master
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.version=1.8.0_171
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.vendor=Oracle Corporation
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.home=/usr/java/jdk1..0_171/jre
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.class.path=/home/jun/zookeeper-3.4./bin/../build/classes:/home/jun/zookeeper-3.4./bin/../build/lib/*.jar:/home/jun/zookeeper-3.4.12/bin/../lib/slf4j-log4j12-1.7.25.jar:/home/jun/zookeeper-3.4.12/bin/../lib/slf4j-api-1.7.25.jar:/home/jun/zookeeper-3.4.12/bin/../lib/netty-3.10.6.Final.jar:/home/jun/zookeeper-3.4.12/bin/../lib/log4j-1.2.17.jar:/home/jun/zookeeper-3.4.12/bin/../lib/jline-0.9.94.jar:/home/jun/zookeeper-3.4.12/bin/../lib/audience-annotations-0.5.0.jar:/home/jun/zookeeper-3.4.12/bin/../zookeeper-3.4.12.jar:/home/jun/zookeeper-3.4.12/bin/../src/java/lib/*.jar:/home/jun/zookeeper-3.4.12/bin/../conf:
2018-07-23 14:06:51,051 [myid:] - INFO [main:Environment@100] - Client environment:java.library.path=/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
2018-07-23 14:06:51,051 [myid:] - INFO [main:Environment@100] - Client environment:java.io.tmpdir=/tmp
2018-07-23 14:06:51,051 [myid:] - INFO [main:Environment@100] - Client environment:java.compiler=<NA>
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:os.name=Linux
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:os.arch=amd64
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:os.version=3.10.0-862.el7.x86_64
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:user.name=jun
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:user.home=/home/jun
2018-07-23 14:06:51,052 [myid:] - INFO [main:Environment@100] - Client environment:user.dir=/home/jun
2018-07-23 14:06:51,053 [myid:] - INFO [main:ZooKeeper@441] - Initiating client connection, connectString=master:2181 sessionTimeout=30000 watcher=org.apache.zookeeper.ZooKeeperMain$MyWatcher@799f7e29
Welcome to ZooKeeper!
2018-07-23 14:06:51,111 [myid:] - INFO [main-SendThread(master:2181):ClientCnxn$SendThread@1028] - Opening socket connection to server master/192.168.1.100:2181. Will not attempt to authenticate using SASL (unknown error)
JLine support is enabled
2018-07-23 14:06:51,191 [myid:] - INFO [main-SendThread(master:2181):ClientCnxn$SendThread@878] - Socket connection established to master/192.168.1.100:2181, initiating session
[zk: master:2181(CONNECTING) 0] 2018-07-23 14:06:51,269 [myid:] - INFO [main-SendThread(master:2181):ClientCnxn$SendThread@1302] - Session establishment complete on server master/192.168.1.100:2181, sessionid = 0x1000005d8900000, negotiated timeout = 30000 WATCHER:: WatchedEvent state:SyncConnected type:None path:null [zk: master:2181(CONNECTED) 0] help
ZooKeeper -server host:port cmd args
stat path [watch]
set path data [version]
ls path [watch]
delquota [-n|-b] path
ls2 path [watch]
setAcl path acl
setquota -n|-b val path
history
redo cmdno
printwatches on|off
delete path [version]
sync path
listquota path
rmr path
get path [watch]
create [-s] [-e] path data acl
addauth scheme auth
quit
getAcl path
close
connect host:port
[zk: master:2181(CONNECTED) 1] quit
Quitting...
2018-07-23 14:07:36,575 [myid:] - INFO [main:ZooKeeper@687] - Session: 0x1000005d8900000 closed
2018-07-23 14:07:36,577 [myid:] - INFO [main-EventThread:ClientCnxn$EventThread@521] - EventThread shut down for session: 0x1000005d8900000
二、HBase的安装
1.从http://apache.fayea.com/hbase/stable/下载hbase-1.2.6.1-bin.tar.gz并赋值到/home/jun下并解压。、
[jun@master ~]$ cd hbase-1.2.6.1/
[jun@master hbase-1.2.6.1]$ ls -l
total
drwxr-xr-x. jun jun Jun : bin
-rw-r--r--. jun jun Jun : CHANGES.txt
drwxr-xr-x. jun jun Jun : conf
drwxr-xr-x. jun jun Jun : docs
drwxr-xr-x. jun jun Jun : hbase-webapps
-rw-rw-r--. jun jun Jun : LEGAL
drwxrwxr-x. jun jun Jul : lib
-rw-rw-r--. jun jun Jun : LICENSE.txt
-rw-rw-r--. jun jun Jun : NOTICE.txt
-rw-r--r--. jun jun Jun : README.txt
2.修改conf文件夹下的环境变量hbase-env.sh
# The java implementation to use. Java 1.7+ required.
export JAVA_HOME=/usr/java/jdk1..0_171/
由于使用的jdk1.8,因此还需要将下面两行注释掉:
# Configure PermSize. Only needed in JDK7. You can safely remove it for JDK8+
#export HBASE_MASTER_OPTS="$HBASE_MASTER_OPTS -XX:PermSize=128m -XX:MaxPermSize=128m"
#export HBASE_REGIONSERVER_OPTS="$HBASE_REGIONSERVER_OPTS -XX:PermSize=128m -XX:MaxPermSize=128m"
3.修改conf文件夹下的配置文件hbase-site.xml
<configuration> <property>
<name>hbase.cluster.distributed</name>
<value>true</value>
</property> <property>
<name>hbase.rootdir</name>
<value>hdfs://master:9000/hbase</value>
</property> <property>
<name>hbase.zookeeper.quorum</name>
<value>master</value>
</property> <property>
<name>hbase.master.info.port</name>
<value></value>
</property> </configuration>
4.设置conf文件夹下的regionservers
regionservers文件类似Hadoop的slaves文件,其中保存了rigionserver的列表,启动HBase的时候,系统将根据该文件建立HBase集群。需要先删除localhost并添加两条配置
slave0
slave1
5.设置linux环境变量并source生效
#hbase
export HBASE_HOME=/home/jun/hbase-1.2.6.1/
export PATH=$HBASE_HOME/bin:$PATH
export HADOOP_CLASSPATH=$HBASE_HOME/lib/*
6.将HBase安装文件复制到slave节点
[jun@master conf]$ scp -r /home/jun/hbase-1.2.6.1/ slave0:~/
[jun@master conf]$ scp -r /home/jun/hbase-1.2.6.1/ slave1:~/
7.启动并验证HBase
(1)执行start-hbase.sh启动HBase,可以看到,系统首先启动HBase自带的ZooKeeper,然后启动HBase的HMaster,接着分别启动slave节点上的regionservers。
[jun@master conf]$ start-hbase.sh
master: starting zookeeper, logging to /home/jun/hbase-1.2.6.1/bin/../logs/hbase-jun-zookeeper-master.out
starting master, logging to /home/jun/hbase-1.2.6.1//logs/hbase-jun-master-master.out
slave0: starting regionserver, logging to /home/jun/hbase-1.2.6.1/bin/../logs/hbase-jun-regionserver-slave0.out
slave1: starting regionserver, logging to /home/jun/hbase-1.2.6.1/bin/../logs/hbase-jun-regionserver-slave1.out
(2)查看各结点的jps,其中HMaster是HBase的主控节点进程,HQuorumPeer是HBase的ZooKeeper进程(即HBase内置的ZooKeeper)。
[jun@master ~]$ jps
Jps
SecondaryNameNode
ResourceManager
HMaster
HQuorumPeer
NameNode [jun@slave0 ~]$ jps
NodeManager
HRegionServer
QuorumPeerMain
DataNode
Jps [jun@slave1 ~]$ jps
DataNode
Jps
QuorumPeerMain
HRegionServer
NodeManager
(3)使用Web方式查看HBase系统的运行状态,访问http://master:60010
三、HBase的Shell命令
执行hbase shell即可进入HBase Shell
1.创建表,其中第一个参数是表名,f1和f12是列名
hbase(main)::> create "test1", {NAME => 'f1', VERSION => }
Unknown argument ignored for column family f1: 1.8.
row(s) in 2.6300 seconds => Hbase::Table - test1
hbase(main)::> create 'test2', 'f12'
row(s) in 2.2360 seconds => Hbase::Table - test2
2.查看列表
hbase(main)::> list
TABLE
test1
test2
row(s) in 0.0270 seconds => ["test1", "test2"]
3.插入数据,其中test1是表名,id001是行键(row key),f1是列族名,uid是属性名,001是属性值
hbase(main)::> put 'test1', 'id001', 'f1:uid', ''
row(s) in 0.2300 seconds
4.扫描查询数据
hbase(main)::> scan 'test1'
ROW COLUMN+CELL
id001 column=f1:uid, timestamp=, value=
row(s) in 0.0750 seconds
5.查看表结构
hbase(main)::> describe 'test1'
Table test1 is ENABLED
test1
COLUMN FAMILIES DESCRIPTION
{NAME => 'f1', BLOOMFILTER => 'ROW', VERSIONS => '', IN_MEMORY => 'false', KEEP_DELETED_CELLS => 'FALSE', DATA_BLOCK_ENCODING => 'NONE', TTL => '
FOREVER', COMPRESSION => 'NONE', MIN_VERSIONS => '', BLOCKCACHE => 'true', BLOCKSIZE => '', REPLICATION_SCOPE => ''}
row(s) in 0.0310 seconds hbase(main)::> describe 'test2'
Table test2 is ENABLED
test2
COLUMN FAMILIES DESCRIPTION
{NAME => 'f12', BLOOMFILTER => 'ROW', VERSIONS => '', IN_MEMORY => 'false', KEEP_DELETED_CELLS => 'FALSE', DATA_BLOCK_ENCODING => 'NONE', TTL =>
'FOREVER', COMPRESSION => 'NONE', MIN_VERSIONS => '', BLOCKCACHE => 'true', BLOCKSIZE => '', REPLICATION_SCOPE => ''}
row(s) in 0.0140 seconds
6.删除表
hbase(main)::> list
TABLE
test1
test2
row(s) in 0.0100 seconds => ["test1", "test2"]
hbase(main)::> disable 'test2'
row(s) in 2.2890 seconds hbase(main)::> drop 'test2'
row(s) in 1.2660 seconds hbase(main)::> list
TABLE
test1
row(s) in 0.0110 seconds => ["test1"]
7.退出HBase Shell
hbase(main)::> exit
四、HBase和ZooKeeper的关系
如果用户在使用HBase自带的ZooKeeper的时候出现异常,导致HBase不能正常工作,这时可以停止使用自带的Zookeeper,转而启动独立安装的ZooKeeper,并重启HBase,可以快速解决上述问题。
要想让HBase使用独立安装的Zookeeper,需要对HBase进行一些配置上的修改。
1.修改conf/hbase-env.sh文件,添加如下代码(true表示使用自带的ZooKeeper)
export HBASE_MANAGES_ZK=false
2.将Zookeeper配置文件复制到HBase的CLASSPATH
cp /home/jun/zookeeper-3.4./conf/zoo.cfg /home/jun/hbase-1.2.6.1/conf
3.重启HBase即可
Zookeeper与HBase的安装的更多相关文章
- Hadoop、Zookeeper、Hbase分布式安装教程
参考: Hadoop安装教程_伪分布式配置_CentOS6.4/Hadoop2.6.0 Hadoop集群安装配置教程_Hadoop2.6.0_Ubuntu/CentOS ZooKeeper-3.3 ...
- mysql 和 hive 和分布式zookeeper和HBASE分布式安装教程
一,mysql 安装mysql5.7完整教程1. yum -y install mysql-server直接执行语句后等待就好已安装: mysql-community-server.x86_64 0: ...
- Hbase的安装测试工作
Hbase的安装测试工作: 安装:http://www.cnblogs.com/neverwinter/archive/2013/03/28/2985798.html 测试:http://www.cn ...
- HBase 的安装与配置
实验简介 本次实验学习和了解 HBase 在不同模式下的配置和安装,以及 HBase 后续的启动和停止等. 一.实验环境说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shi ...
- HBASE的安装
HBASE的安装: 安装的软件版本:hbase-0.98.4-hadoop2.tar.gz 下载链接:http://www.apache.org/dist/hbase/hbase-0.98.4/ 1. ...
- 一、Hbase的安装
一.Hbase配置 这个是我从网上找的一个版本,网上说配置成功. 先决条件: (1)hadoop的版本与hbase的版本要对应,主要是hadoop目录下的hadoop-core-1.0.4.jar的版 ...
- Centos7上HBase的安装和配置
注意事项 HBase配置必须使用主机名,不支持直接配置IP地址.我尝试过,如果不使用主机名直接用IP,会导致HBase连接zk超时. > 设置主机名 hostnamectl set-hostna ...
- Hbase简介安装配置
HBase —— Hadoop Database的简称 ,hbase 是分布式,稀疏的,持久化的,多维有序映射,它基于行键rowkey,列键column key,时间戳timestamp建立索引.它是 ...
- Hbase的安装和基本使用
Hbase介绍 HBase是一个开源的非关系型分布式数据库(NoSQL),它参考了谷歌的BigTable建模,实现的编程语言为 Java.它是Apache软件基金会的Hadoop项目的一部分,运行于H ...
随机推荐
- Roman and Browser-罗曼的浏览器 CodeForce1100A 暴力
题目链接:Roman and Browser 题目原文 This morning, Roman woke up and opened the browser with
- C++ 生成随机数 srand()和rand()
1. rand() rand(产生随机数)表头文件: #include<stdlib.h>定义函数 :int rand(void) 函数说明 :因为rand() 的内部实现是用线性同余法做 ...
- 使用Java元注解和反射实现简单MVC框架
Springmvc的核心是DispatcherServlet来进行各种请求的拦截,进而进行后续的各种转发处理.流程图如下: 说明:客户端发出一个http请求给web服务器,web服务器对http请求进 ...
- 第一篇:php开发环境
Window: 1.XAMPPhttps://www.apachefriends.org/index.html 2.WampServerhttp://www.wampserver.com/ Linux ...
- Scala 数组和List
Scala 数组和List: import scala.collection.mutable.ArrayBuffer import scala.collection.mutable.Buffer ob ...
- html5一些特性
html5可以理解为html+css+js 其目前可以解决:1.浏览器的兼容问题 2.统一web应用标准 3.解决文档结构定义不明确问题 4.解决web应用中的功能受限问题 5.是程序员编写的web应 ...
- python语言程序设计基础(嵩天)第四章课后习题部分答案
p121: *题4.1:猜数字游戏.在程序中预设一个0~9之间的整数,让用户通过键盘输入所猜的数,如果大于预设的数,显示“遗憾,太大了!”:小于预设的数,显示“遗憾,太小了!”,如此循环,直至猜中该数 ...
- 从零开始的vue学习笔记(七)
前言 今天花一天时间阅读完vuex的官方文档,简单的做一下总结和记录 Vuex是什么 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,以前的符合"单向数据流"理念的 ...
- java集合类之LinkedList详解
一.LinkedList简介 由于LinkedList是一个实现了Deque的双端队列,所以LinkedList既可以当做Queue,又可以当做Stack,在将LinkedList当做Stack时,使 ...
- JZOJ 3875 星球联盟
[问题描述] 在遥远的 S 星系中一共有 N 个星球,编号为 1…N.其中的一些星球决定组成联盟, 以方便相互间的交流. 但是,组成联盟的首要条件就是交通条件.初始时,在这 N 个星球间有 M 条太空 ...