前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot整合HBase将数据写入Docker中的HBase

SpringBoot整合HBase将数据写入Docker中的HBase

作者头像
gzq大数据
发布2020-12-25 10:47:29
1.5K0
发布2020-12-25 10:47:29
举报
文章被收录于专栏:大数据那些事大数据那些事

在之前的项目里,docker容器中已经运行了HBase,现将API操作HBase实现数据的增删改查 通过SpringBoot整合Hbase是一个很好的选择 首先打开IDEA,创建项目(project)时选择Spring Initializer

在这里插入图片描述
在这里插入图片描述

选择如下三种来创建工程

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

创建完后的pom文件如下(修改了spring-boot-starter-parent版本),并且加入了HBase的客户端依赖

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.0.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.gzq</groupId>
    <artifactId>springboot-database</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot-database</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.apache.hbase</groupId>
            <artifactId>hbase-client</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

随后写好java代码:

代码语言:javascript
复制
package com.gzq.springbootdatabase;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.*;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import org.junit.Test;

import java.io.IOException;


public class TestHbase {


    @Test
    public void testCreate() throws IOException {
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "xxx");
        Connection connection = ConnectionFactory.createConnection(configuration);

        Admin admin = connection.getAdmin();

        HTableDescriptor test1 = new HTableDescriptor(TableName.valueOf("xx:xxx"));
        HColumnDescriptor firstColumnDescriptor = new HColumnDescriptor("xxx".getBytes());
        HColumnDescriptor secondColumnDescriptor = new HColumnDescriptor("xxx".getBytes());
        HColumnDescriptor thirdColumnDescriptor = new HColumnDescriptor("xxx".getBytes());
        test1.addFamily(firstColumnDescriptor);
        test1.addFamily(secondColumnDescriptor);
        test1.addFamily(thirdColumnDescriptor);

        admin.createTable(test1);
        admin.close();
        connection.close();
    }

    @Test
    public void testCreateNameSpace() throws IOException {
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "xxx");
        Connection connection = ConnectionFactory.createConnection(configuration);

        Admin admin = connection.getAdmin();

        NamespaceDescriptor namespaceDescriptor = NamespaceDescriptor.create("xxx").build();
        admin.createNamespace(namespaceDescriptor);

        admin.close();
        connection.close();
    }

    @Test
    public void testPutData() throws IOException {
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "xxxx");
        Connection connection = ConnectionFactory.createConnection(configuration);


        //获取表对象
        Table table = connection.getTable(TableName.valueOf("xx:xxx"));

        Put put = new Put(Bytes.toBytes("xxx" + System.currentTimeMillis()));

        put.addColumn(Bytes.toBytes("xxx"), Bytes.toBytes("xx"), Bytes.toBytes("xx"));

        table.put(put);

        table.close();
        connection.close();


    }
}

ps:因为是在云服务器上进行操作(如果是在本地操作不需要看如下内容),所以为了安全,在云服务器上开启了防火墙,如果直接执行程序就会报错,无法连接,所以通过管道的方式安全连接,我用的是mobaSSHTunnel(MobaXterm工具下的插件),随后开启相应的端口,并且我的docker也映射了云服务器上的端口:

在这里插入图片描述
在这里插入图片描述

随后在mobaSSHTunnel开启已经配置好的端口映射即可安全的访问,我映射的端口有2181,16000,16020(这三个端口保证都打开很重要)这几个关键的端口,并且有一个坑:在 configuration.set(“hbase.zookeeper.quorum”, “xxx”);这行代码里后面的xxx是你的主机名称,我的HBase里的hbase-site.xml里面的配置对应的是cdata01,那么这个xxx必须是cdata01,但是通过你的管道访问时要连接端口必须通过2181连接,并且在mobaSSHTunnel里的对应的访问域名必须设为cdata01,而这个cdata01在你的windows上的hosts文件里必须映射的是127.0.0.1,(切记不要将你的hosts文件里的cdata01改成云服务器的地址,如果改成就直接访问云服务器了,但是云服务器开了防火墙,你必定连接不上,你唯一的通道是通过Tunnel连接,所以必须将此处的windows的hosts文件里设置为127.0.0.1),在mobaSSHTunnel对应的2181端口映射为下图:

在这里插入图片描述
在这里插入图片描述

hosts文件里:

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-12-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云服务器
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档