如果初学hbase,没必要弄一个集群,hbase的local mode够用了。

这里写一个简单的教程。适用于初学hbase,想要用代码访问hbase的童鞋们。

目录:

0. 准备

1).  开发环境

2).  修改主机名

3). centos里安装jdk

1. 安装hbase (local mode)

1). 下载

2). 解压

3). 配置

4). 运行

5). hbase shell访问

2. 远程访问

3. 总结

0. 准备

1).  开发环境

一台laptop,win10,eclipse,vmware 10,centos 7.3

这是本人的笔记本的开发环境,基本上eclipse运行在 windows上,hbase运行在vm中。

如果在centos7.3里装个eclipse,这个就不算远程访问了。这里不讨论这种情况。

2).  修改centos 7.3的机器名

本地模式的hbase,默认是使用主机名作为/hbase/master的地址的。如果主机名是localhost,在eclipse远程访问时有问题。所以要修centos的主机名。

# vi /etc/sysconfig/network
NETWORKING=yes
HOSTNAME=docker # vi /etc/hosts
192.168.1.135 docker 重启centos
# init 6

因为这个vm本人也用来学习docker,所以主机名就改为docker了。

3). centos里安装jdk

下载一个rpm形式的jdk, 然后

# rpm -ivh jdk-8u101-linux-x64.rpm

其它如.tar.gz形式也无所谓,安装就行了。

2.  安装hbase

本地模式是指底层的文件系统不是使用HDFS,而是直接使用OS的本地文件系统。

1). 下载

下载hbase-1.2.6, 这个去hbase.apache.org去下载就好了,可以在win10里下,再copy进centos,也可以直接在centos里下

# wget ...

下载zookeeper-3.4.6,这个下载后只要解压即可,放在/opt/zookeeper-3.4.6

2).  解压

假设文件在/opt/hbase-1.2..tar.gz
# cd /opt
# tar zvxf hbase-1.2..tar.gz

则hbase解压后位于/opt/hbase-1.2.6

3). 配置

本机运行,需要配置两个文件: conf/hbase-env.sh, conf/hbase-site.xml

conf/hbase-env.sh

依据你的JDK的位置,配置JAVA_HOME

# cd /opt/hbase-1.2.
# vi conf/hbase-env.sh
...
export JAVA_HOME=/usr/java/latest
...

conf/hbase-site.xml

# vi conf/hbase-site.xml
<configuration>
<property>
<name>hbase.rootdir</name>
<value>file:///opt/hbase-1.2.6/data/hbase</value>
</property> <property>
<name>hbase.zookeeper.property.dataDir</name>
<value>/opt/hbase-1.2./data/zookeeper</value>
</property>
</configuration>

再新建两个目录, 用于保存数据

# cd /opt/hbase-1.2.
# mkdir -p data/hbase
# mkdir data/zookeeper

4). 运行

运行后,可以在浏览器里打开hbase的web ui  -> http://192.168.1.135:16010

因为本地模式zookeeper是运行于hbase的jvm内,使用 jps命令看不到zookeeper的进程,此时可以使用下载的zookeeper连接查看:

# cd /opt/zookeeper-3.4.
# bin/zkCli.sh

这样就连接到zookeeper,可以查看master的地址:

如果不改主机名, centos默认是localhost, 那么红框这个地方就是localhost。

停止运行:

5). hbase shell访问

新建表,表名:test,列族:cf

然后向test表中put一行:  rowkey:  "row1",   列:a,  即cf:a, 值:"value1"

然后通过get查询,结果如下图:

二. 远程访问

“远程”,是指访问的程序不运行于hbase运行的centos中, 换句话说,就是访问程序和hbase运行的vm用的是两个IP。(比如我的win10: 192.168.1.102, vm: 192.168.1.135)

在eclipse里新建java工程,普通的java工程,只使用main()运行。

然后在工程目录下建一个目录: lib,与src同级,将vm中hbase-1.2.6/lib目录下的所有jar,全部复制放到eclipse的lib里,设置eclipse 工程的build路径,添加lib里的所有jar,这个应该搞 java都知道。

工程目录结构:

TestConnection.java

package ex1;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.util.Bytes; public class TestConnection { public static Configuration configuration;
static{
configuration = HBaseConfiguration.create();
configuration.set("hbase.zookeeper.quorum", "192.168.1.135") ;
System.out.println("===============");
} public static void main(String[] args) throws Exception {
Connection conn = ConnectionFactory.createConnection(configuration);
Table table = conn.getTable(TableName.valueOf("test"));
Get get = new Get(Bytes.toBytes("row1"));
get.addColumn(Bytes.toBytes("cf"), Bytes.toBytes("a"));
Result r = table.get(get);
if(r.isEmpty()) {
System.out.println("result is null");
}
System.out.println("result=" + new String(r.value()));
conn.close();
}
}

运行程序前,要改win10的 /etc/hosts文件(C:\Windows\System32\drivers\etc\hosts),添加如下行:

192.168.1.135    docker

改完这个文件后, web ui也可以这样访问了 ->  http://docker:16010

运行结果:

3. 总结:

其实说了这么多, 捞干的说就是: hbase的本地模式使用主机名作为地址

而hbase client(即eclipse中的代码)是通过zookeeper中的地址(就是画红框的那个地方)访问hbase的,如果zookeeper保存的是localhost, 而localhost的ip是127.0.0.1,

那么就变成了访问win10自己了,就不是访问centos了。

改vm的主机名,就是让这个名字仅是个名字,这样才可以关联其它IP,而不是127.0.0.1。

hbase (local mode) remote access的更多相关文章

  1. 500 OOPS: vsftpd: both local and anonymous access

    配置ftp服务器,有如下报错 C:\netos74\bin>ftp 10.20.100.252Connected to 10.20.100.252.500 OOPS: vsftpd: both ...

  2. vpn找不到设备,win7建立新的VPN总时显示错误711,无法启动 Remote Access Connection Manager 及 Remote Access Auto Connection Manager 错误1068

    试试相关服务!一.remote access connection manager是网络连接的服务,它依赖于Technology服务,现在你的这个服务已经启动,而Secure Socket Tunne ...

  3. Ubuntu14.04 开启MySQL的remote access

    一旦开启MySQL的remote access, 即可实现在windows系统下连接ubuntu下的mysql 步骤如下: sudo vim /etc/mysql/my.cnf bind-addres ...

  4. 【转】 Pro Android学习笔记(七六):服务(1):local和remote

    文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowingflying/ Android提供服务,服务是运行在后台的 ...

  5. [GraphQL] Query Local and Remote Data in Apollo Link State

    In this lesson, you will learn how to query local and remote data in Apollo Link State in the same c ...

  6. 3.0 - remote access 基础知识

    RA概述: remote access: 广域网的远程连接,按L1分类: 1:通过电路交换网络实现的专线:(circuit switching) ~~~~~~~~~~~~~~~~~~~~~~~~~~~ ...

  7. [Node.js] Proxy Requests for Local and Remote Service Parity

    High availability apps require that no distinction be made between local and remote services. Attach ...

  8. extjs Combobox动态加载数据问题,mode:local 还是remote

    var fabircTypeDs = new Ext.data.Store({ proxy: new Ext.data.HttpProxy({ url: 'province.do' }), reade ...

  9. Rename a local and remote branch in git

    If you have named a branch incorrectly AND pushed this to the remote repository follow these steps b ...

随机推荐

  1. Android-Dalvik指令集

    转载请标明出处:http://blog.csdn.net/goldenfish1919/article/details/40821777 原文:http://pallergabor.uw.hu/and ...

  2. 单点登录(一)使用Cookie+File实现单点登录

    本文使用Cookies+Filter实现www.taobao.tgb.com 和 www.tianmao.tgb.com的单点登录. 源代码分享:链接: http://pan.baidu.com/s/ ...

  3. myeclipse配置SVN插件

    方法一:link安装  安装subclipse, MyEclipse SVN插件  1.从官网下载最新的site-1.x.x.zip文件,网址是:folderID=2240" target= ...

  4. .NET Core容器化@Docker

    温馨提示:本文适合动手演练,效果更佳.  1. 引言 我们知道. NET Core最大的特性之一就是跨平台,而对于跨平台,似乎大家印象中就是可以在非Windows系统上部署运行.而至于如何操作,可能就 ...

  5. Struts2.5 伪静态的配置

    伪静态 伪静态是相对真实静态来讲的,通常我们为了增强搜索引擎的友好面,都将文章内容生成静态页面,但是有的朋友为了实时的显示一些信息.或者还想运用动态脚本解决一些问题.不能用静态的方式来展示网站内容.但 ...

  6. 自学Zabbix3.6.1-触发器triggers创建

    1. 触发器概念 触发器(triggers)是什么?触发器使用逻辑表达式来评估通过item获取到得数据是处于哪种状态,item一收回数据,讲解任务交给触发器去评估状态,明白触发器是怎么一回事了把?在触 ...

  7. MAC系统里JDK版本切换

    1.首先安装需要的JDK版本 JDK7,JDK8则需要自己到Oracle官网下载安装对应的版本.自己安装的JDK默认路径为:/Library/Java/JavaVirtualMachines/jdk1 ...

  8. Mybatis中的模糊查询

    今天下午做的一个功能,要用到模糊查询,字段是description,刚开始我的写法用的是sql中的模糊查询语句, 但是这个有问题,只有将字段的全部值传入其中,才能查询,所以不是迷糊查询. 后来经过搜索 ...

  9. Django安装与开发虚拟环境搭建01

    Django是一款基于python的MVT的web开发框架(m表示model,主要用于对数据库层的封装  ,v表示view,用于向用户展示结果,c表示controller,是核心,用于处理请求.获取数 ...

  10. 三十天学不会TCP,UDP/IP网络编程-UDP,从简单的开始

    如果对和程序员有关的计算机网络知识,和对计算机网络方面的编程有兴趣,欢迎去gitbook(https://www.gitbook.com/@rogerzhu/)star我的这一系列文章,虽然说现在这种 ...