HBase 集群部署

安装 hbase 之前需要先搭建好 hadoop 集群和 zookeeper 集群。hadoop 集群搭建可以参考:https://www.cnblogs.com/javammc/p/16545146.html

  1. 下载安装包 http://archive.apache.org/dist/hbase/1.3.1/
  1. 解压到安装目录
  1. tar -zxvf hbase-1.3.1-bin.tar.gz

我解压到了/opt/lagou/servers/hbase-1.3.1 目录。

  1. 修改配置文件
  • 把 hadoop 中配置的 core-site.xml、hdfs-site.xml 拷贝到 hbase 下的 conf 目录下
  1. ln -s /opt/lagou/servers/hadoop-2.9.2/etc/hadoop/core-site.xml /opt/lagou/servers/hbase-1.3.1/conf/core-site.xml
  2. ln -s /opt/lagou/servers/hadoop-2.9.2/etc/hadoop/hdfs-site.xml /opt/lagou/servers/hbase-1.3.1/conf/hdfs-site.xml
  • 修改 hbase-env.sh
  1. #添加java环境变量
  2. export JAVA_HOME=/opt/module/jdk1.8.0_231
  3. #指定使用外部的zk集群
  4. export HBASE_MANAGES_ZK=FALSE
  • 修改 hbase-site.xml
  1. <configuration>
  2.  <!-- 指定hbase在HDFS上存储的路径 -->
  3.    <property>
  4.        <name>hbase.rootdir</name>
  5.        <value>hdfs://linux2:9000/hbase</value>
  6.    </property>
  7.        <!-- 指定hbase是分布式的 -->
  8.    <property>
  9.        <name>hbase.cluster.distributed</name>
  10.        <value>true</value>
  11.    </property>
  12.        <!-- 指定zk的地址,多个用“,”分割 -->
  13.    <property>
  14.        <name>hbase.zookeeper.quorum</name>
  15.        <value>linux2:2181,linux3:2181,linux4:2181</value>
  16.    </property>
  17. </configuration>
  • 修改 regionservers
  1. linux2
  2. linux3
  3. linux4
  • 在 hbase 的 conf 目录下创建文件 backup-masters

内容如下:

  1. linux2
  • 在每个节点上配置环境变量,vi /etc/profile
  1. export HBASE_HOME=/opt/lagou/servers/hbase-1.3.1
  2. export PATH=$PATH:$HBASE_HOME/bin

执行命令使配置生效

  1. source /etc/profile
  • 将 hbase-1.3.1 目录分发到其他 2 个节点
  1. scp -r hbase-1.3.1 linux3:/opt/lagou/servers/
  2. scp -r hbase-1.3.1 linux4:/opt/lagou/servers/
  1. 启动集群
  1. #启动命令
  2. start-hbase.sh
  3. #停止命令
  4. stop-hbase.sh
  1. 启动完成后,可以访问地址:

    HMaster 的 ip:16010

HBase shell 基本操作

  1. 进入 HBase 客户端命令操作界面
  1. hbase shell

shell 命令行里如果输错了命令,删除需要使用 Ctrl+Backspace

  1. 查看帮助命令
  1. help
  1. 查看当前数据库里有哪些表
  1. list
  1. 创建一个 user 表,包含 user_info、extra_info 两个列族
  1. create 'user','base_info','extra_info'
  2. #或者指定版本
  3. create 'user2',{NAME => 'base_info',VERSIONS => '3'},{NAME => 'extra_info',VERSIONS => '3'}
  1. 添加数据
  • 向 user 表中 row key 为 rk1,列族 base_info 的 name 列上插入值'xiaowang'
  1. put 'user','rk1','base_info:name','xiaowang'
  • 向 user 表中 row key 为 rk1,列族为 base_info 的 age 列插入值 30
  1. put 'user','rk1','base_info:age',30
  • 向 user 表中 row key 为 rk1,列族为 extra_info 的 address 列插入值'shanghai'
  1. put 'user','rk1','extra_info:address','shanghai'
  1. 查询数据
  • 查询 user 表中 row key 为 rk1 的所有信息
  1. get 'user','rk1'
  • 查询 user 表中 row key 为 rk1 的 base_info 列族的所有信息
  1. get 'user','rk1','base_info'
  • 查询 user 表中指定列族,指定字段的值
  1. get 'user','rk1','base_info:name','base_info:age'
  • 查询 user 表中多个列族的信息
  1. get 'user','rk1','base_info','extra_info'
  • 根据 rowkey 和列值进行查询
  1. get 'user','rk1',{FILTER => "ValueFilter (=,'binary:shanghai')"}
  • 根据 row key 和列名进行模糊查询

查询出列名:address

  1. get 'user','rk1',{FILTER => "QualifierFilter (=,'substring:add')"}
  • 查询表中所有数据
  1. scan 'user'
  • 查询表中列族为 base_info 的信息
  1. scan 'user',{COLUMNS => 'base_info'}
  2. # Scan时可以设置是否开启Raw模式,开启Raw模式会返回包括已添加删除标记但是未实际删除的数据
  3. # VERSIONS指定查询的最大版本数
  4. scan 'user',{COLUMNS => 'base_info',RAW => true, VERSIONS=> 3}
  • 查询 user 表中列族为 base_info、extra_info,且列名中含 add 字符的数据
  1. scan 'user',{COLUMNS => ['base_info','extra_info'],FILTER => "(QualifierFilter(=,'substring:add'))"}
  • rowkey 的范围值查询
  1. scan 'user',{COLUMNS => 'base_info',STARTROW => 'rk1',ENDROW => 'rk3'}
  • 指定 rowkey 模糊查询

查询 user 表中 row key 以 rk 开头的数据

  1. scan 'user' ,{FILTER =>"PrefixFilter('rk')"}
  1. 更新数据

更新操作同插入操作一模一样,只不过有数据就更新,没数据就添加

  • 更新数据值

将 user 表中 rowkey 为 rk1 的 base_info 列族下的 name 修改为 xiaoliao

  1. put 'user','rk1','base_info:name','xiaoliao'
  1. 删除数据和表
  • 指定 rowkey 以及列名进行删除
  1. delete 'user','rk2','base_info:name'
  • 指定 rowkey 以及列名、时间戳进行删除
  1. delete 'user','rk2','base_info:age',1662245345710
  • 删除列族
  1. alter 'user','delete' => 'extra_info'
  • 清空表数据
  1. truncate 'user'
  • 删除表
  1. #先disable,再drop,否则会报错
  2. disable 'user'
  3. drop 'user'

HBase集群部署与基础命令的更多相关文章

  1. Hbase集群部署及shell操作

    本文详述了Hbase集群的部署. 集群部署 1.将安装包上传到集群并解压 scp hbase-0.99.2-bin.tar.gz mini1:/root/apps/ tar -zxvf hbase-0 ...

  2. HBase 集群部署

     前提条件:hadoop及zookeeper机群已经搭建好. 配置hbase集群步骤: 1.配置hbase集群,要修改3个文件 注意:要把hadoop的hdfs-site.xml和core-site. ...

  3. Hbase集群部署

    1.安装Hadoop集群 这个之前已经写过 2.安装Zookeeper 这个之前也已经写过 3.下载hbase,放到master机器,解压 4.修改hbase-env.sh,添加Java地址 expo ...

  4. Kubernetes集群部署及简单命令行操作

    三个阶段部署docker:https://www.cnblogs.com/rdchenxi/p/10381631.html 环境准备 [root@master ~]# hostnamectl set- ...

  5. HBase集群部署脚本

    #!/bin/bash # Sync HBASE_HOME across the cluster. Must run on master using HBase owner user. HBASE_H ...

  6. HBase集成Zookeeper集群部署

    大数据集群为了保证故障转移,一般通过zookeeper来整体协调管理,当节点数大于等于6个时推荐使用,接下来描述一下Hbase集群部署在zookeeper上的过程: 安装Hbase之前首先系统应该做通 ...

  7. Hadoop及Zookeeper+HBase完全分布式集群部署

    Hadoop及HBase集群部署 一. 集群环境 系统版本 虚拟机:内存 16G CPU 双核心 系统: CentOS-7 64位 系统下载地址: http://124.202.164.6/files ...

  8. Storm集群部署及单词技术

    1. 集群部署的基本流程 集群部署的流程:下载安装包.解压安装包.修改配置文件.分发安装包.启动集群 注意: 所有的集群上都需要配置hosts vi  /etc/hosts 192.168.239.1 ...

  9. 2.Storm集群部署及单词统计案例

    1.集群部署的基本流程 2.集群部署的基础环境准备 3.Storm集群部署 4.Storm集群的进程及日志熟悉 5.Storm集群的常用操作命令 6.Storm源码下载及目录熟悉 7.Storm 单词 ...

随机推荐

  1. Sublime Text 3 如何清除上次打开文件记录

    打开顶部菜单栏:进入 Preferences => Settings-User修改如下: {"hot_exit": false,"remember_open_fil ...

  2. 一分钟入门 Babel(下一代 JavaScript 语法的编译器)

    简单来说把 JavaScript 中 es2015/2016/2017/2046 的新语法转化为 es5,让低端运行环境(如浏览器和 node )能够认识并执行.严格来说,babel 也可以转化为更低 ...

  3. 实现领域驱动设计 - 使用ABP框架 - 创建实体

    用例演示 - 创建实体 本节将演示一些示例用例并讨论可选场景. 创建实体 从实体/聚合根类创建对象是实体生命周期的第一步.聚合/聚合根规则和最佳实践部分建议为Entity类创建一个主构造函数,以保证创 ...

  4. React中setState方法说明

    setState跟新数据是同步还是异步? setState跟新数据是异步的. 如何用代码表现出来是异步的. 点击按钮更新数据,然后去打印这个值看一下 setState跟新数据是异步的 class Fa ...

  5. Linux YUM yum-utils 模块详解

    yum-utils 详解 yum-utils是yum的工具包集合,由不同的作者开发,使yum使用起来更加方便和强大.包括:debuginfo-install,find-repos-of-install ...

  6. Golang并发编程——goroutine、channel、sync

    并发与并行 并发和并行是有区别的,并发不等于并行. 并发 两个或多个事件在同一时间不同时间间隔发生.对应在Go中,就是指多个 goroutine 在单个CPU上的交替运行. 并行 两个或者多个事件在同 ...

  7. 函数式(Functional)接口

    public class LambdaTest2 { @Test public void test1(){ happyTime(500, new Consumer<Double>() { ...

  8. 【docker专栏1】docker解决的实际问题及应用场景

    Docker是一个开源的容器引擎,它轻巧,且易移植,"build once, configure once and run anywhere".使用go语言开发,并遵从apache ...

  9. labview从入门到出家3--制作和调用子VI

    当程序越写越大的时候,我们会发现代码界面会比较乱(线太多),那要怎么做可以让代码更简洁一点,我只管直接调用某个功能函数,而不需要在一个VI上面去实现这个功能函数呢?--子VI.好比C语言里面的Main ...

  10. docker安装Nessus

    Nessus家庭版最大只支持扫描16个主机,但利用docker无限使用,当然虚拟机快照也可以. 关于网上其他的破解版,我是没有成功(显示成功了,其实是自慰版),所以才弄得这个镜像 提供两个镜像(不懂d ...