服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - IDEA远程连接HBase及其Java API实战详解

IDEA远程连接HBase及其Java API实战详解

2021-09-08 10:53唔仄lo咚锵 Java教程

这篇文章主要介绍了IDEA远程连接HBase及其Java API实战详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

IDEA远程连接HBase及其Java API实战详解

开放端口


安全组没开放端口是原罪!!!导致好多bug费时费力。hbase悄悄咪咪的用了好多端口,比如被我抓到的42239,直接搜索报错药不对症。

IDEA远程连接HBase及其Java API实战详解
IDEA远程连接HBase及其Java API实战详解

hbase安装


下载压缩包
可以去官网下载http://hbase.apache.org/downloads.html
也可以去镜像下载历史版本http://archive.apache.org/dist/hbase/
以1.3.2版本为例:

IDEA远程连接HBase及其Java API实战详解

直接下载或者下载到本地再上传都行,看你哪个快。

?
1
2
3
wget http://archive.apache.org/dist/hbase/1.3.2/hbase-1.3.2-bin.tar.gz
tar -zxvf hbase-1.3.2-bin.tar.gz #解压
mv hbase-1.3.2-bin /urs/local/hbase

IDEA远程连接HBase及其Java API实战详解

配置hbase-site.xml

?
1
2
cd /usr/local/hbase/conf
vi hbase-site.xml
?
1
2
3
4
5
6
7
8
9
10
11
12
<property>
        <name>hbase.cluster.distributed</name>
        <value>true</value>
    </property>
    <property>
        <name>hbase.rootdir</name>
        <value>/hbase-data</value>
    </property>
    <property>
        <name>hbase.zookeeper.quorum</name>
        <value>master:2181</value>
    </property>

IDEA远程连接HBase及其Java API实战详解

配置hbase-env.sh

?
1
2
3
4
cd /usr/local/hbase/conf
echo $java_home #若没有安装jdk可百度(偷懒)
vi hbase-env.sh #添加要一致
export java_home=/usr/local/java

IDEA远程连接HBase及其Java API实战详解
IDEA远程连接HBase及其Java API实战详解

运行测试

?
1
2
cd /usr/local/hbase/bin
./start-hbase.sh

IDEA远程连接HBase及其Java API实战详解
IDEA远程连接HBase及其Java API实战详解

ip:16010访问

IDEA远程连接HBase及其Java API实战详解

域名配置


服务器 vi /etc/hosts
私网ip master

IDEA远程连接HBase及其Java API实战详解

本地 c:\windows\system32\drivers\etc\hosts
公网ip master

IDEA远程连接HBase及其Java API实战详解

IDEA远程连接HBase及其Java API实战详解

idea源码


目录结构:

IDEA远程连接HBase及其Java API实战详解

创建一个maven项目并在pom.xml添加依赖:

?
1
2
3
4
5
6
7
8
9
10
<dependency>
            <groupid>org.apache.hbase</groupid>
            <artifactid>hbase-server</artifactid>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupid>org.apache.hbase</groupid>
            <artifactid>hbase-client</artifactid>
            <version>1.3.2</version>
        </dependency>

版本是1.3.2,注意和你自己的一致,可以登录hbase shell时查看。

IDEA远程连接HBase及其Java API实战详解

插播反爬信息 )博主csdn地址:https://wzlodq.blog.csdn.net/

log4j.properties配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
log4j.rootlogger=debug, stdout, r
 
log4j.appender.stdout=org.apache.log4j.consoleappender
log4j.appender.stdout.layout=org.apache.log4j.patternlayout
 
log4j.appender.stdout.layout.conversionpattern=%5p - %m%n
 
log4j.appender.r=org.apache.log4j.rollingfileappender
log4j.appender.r.file=firestorm.log
 
log4j.appender.r.maxfilesize=100kb
log4j.appender.r.maxbackupindex=1
 
log4j.appender.r.layout=org.apache.log4j.patternlayout
log4j.appender.r.layout.conversionpattern=%p %t %c - %m%n
 
log4j.logger.com.codefutures=debug

hbase-site.xml配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl" rel="external nofollow" ?>
<configuration>
    <property>
        <name>hbase.cluster.distributed</name>
        <value>true</value>
    </property>
    <property>
        <name>hbase.rootdir</name>
        <value>/hbase-data</value>
    </property>
    <property>
        <name>hbase.zookeeper.quorum</name>
        <value>master:2181</value>
    </property>
</configuration>

hbasecrud.java

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package ex3;
 
import org.apache.hadoop.conf.configuration;
import org.apache.hadoop.hbase.*;
import org.apache.hadoop.hbase.client.*;
 
import java.io.ioexception;
 
public class hbasecrud {
    private static configuration configuration;
    private static connection connection;
    private static admin admin;
 
    /**
     * 建立连接
     */
    public static void init(){
        configuration=hbaseconfiguration.create();
        configuration.set("hbase.zookeeper.quorum","121.36.240.205"); // 换成你自己的ip
        configuration.set("hbase.zookeeper.property.clientport","2181");
        try{
            connection=connectionfactory.createconnection(configuration);
            admin=connection.getadmin();
        }catch (ioexception e){
            e.printstacktrace();
        }
    }
    /**
     * 关闭连接
     */
    public static void close(){
        try{
            if(admin!=null)
                admin.close();
        }catch (ioexception e){
            e.printstacktrace();
        }
    }
    /**
     * 创建表
     * @param mytablename 表名
     * @param colfamily 列族数组
     * @throws ioexception
     */
    public static void createtable(string mytablename,string[]colfamily)throws ioexception{
        tablename tablename = tablename.valueof(mytablename);
        if(admin.tableexists(tablename)){
            system.out.println("表名已存在!");
        }
        else{
            htabledescriptor htabledescriptor = new htabledescriptor(tablename);
            for(string str:colfamily){  //增加一列
                hcolumndescriptor hcolumndescriptor = new hcolumndescriptor(str);
                htabledescriptor.addfamily(hcolumndescriptor);
            }
            admin.createtable(htabledescriptor); //建表
        }
    }
 
    /**
     * 添加数据
     * @param tablename 表名
     * @param rowkey 行键
     * @param colfamily 列族
     * @param col 列限定符
     * @param val 数据
     * @throws ioexception
     */
    public static void insertdata(string tablename,string rowkey,string colfamily,string col,string val)throws ioexception{
        table table = connection.gettable(tablename.valueof(tablename));//获取表名
        put put = new put(rowkey.getbytes());
        put.addcolumn(colfamily.getbytes(),col.getbytes(),val.getbytes());
        table.put(put);
        table.close();
    }
 
    /**
     * 获取数据
     * @param tablename 表名
     * @param rowkey 行键
     * @param colfamily 列族
     * @param col 列限定符
     * @throws ioexception
     */
    public static void getdata(string tablename,string rowkey,string colfamily,string col)throws ioexception{
        table table = connection.gettable(tablename.valueof(tablename));
        get get = new get(rowkey.getbytes());
        get.addcolumn(colfamily.getbytes(),col.getbytes());
        result result = table.get(get);
        string val = new string(result.getvalue(colfamily.getbytes(),col==null?null:col.getbytes()));
        system.out.println("值为:"+val);
        table.close();
    }
}

client.java

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
package ex3;
 
import org.apache.log4j.basicconfigurator;
 
import java.io.ioexception;
 
public class client {
    public static void main(string[] args) throws ioexception {
        hbasecrud.init();
        //建表
        hbasecrud.createtable("student",new string[]{"score"});
        //插入数据
        hbasecrud.insertdata("student","lisa","score","java","85");
        hbasecrud.insertdata("student","lisa","score","c/c++","80");
        hbasecrud.insertdata("student","lisa","score","mysql","82");
        hbasecrud.insertdata("student","jerry","score","java","65");
        //查询数据
        hbasecrud.getdata("student","lisa","score","java");
        hbasecrud.getdata("student","lisa","score","mysql");
        hbasecrud.getdata("student","jerry","score","java");
        hbasecrud.close();
        system.out.println("记得一键三连~");
    }
}

点击运行后需要点耐心等待,灰色info、debug信息都可不用管,报错的话会是红色字体(评论区交流),有tomcat内味了。

IDEA远程连接HBase及其Java API实战详解

原创不易,请勿转载本不富裕的访问量雪上加霜
博主首页:https://wzlodq.blog.csdn.net/

到此这篇关于idea远程连接hbase及其java api实战的文章就介绍到这了,更多相关idea连接hbase内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_45034708/article/details/115678645

延伸 · 阅读

精彩推荐
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7472021-02-04
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16