java api遠程操作hbase

環境:
  ~~ 1. hbase是運行在服務器的docker上的(爲啥不直接部署在服務器上?之前在服務器上部署了hadoop+hbase結果被利用hadoop的漏洞注入了挖礦的病毒…不想重新安裝所有服務也沒法完全清除病毒,於是就重裝系統,愉快的下了一個docker…)
  ~~ 2. 本地(mac)代碼連接服務器

主要參考

  1. http://www.voidcn.com/article/p-ddrdpdpc-bqt.html
  2. https://www.cnblogs.com/jiuyang/p/10728246.html

遇到的問題

  1. hbase的版本要和hbase-client版本一致,不一致的話會出現方法的異常。
    我的hbase是1.3.2的,所以hbase-client也要是1.3.2。後面代碼裏有體現。

  2. 地址映射,要在本地(mac)映射服務器上的主機爲myhbase(docker上運行的hbase的主機名,運行容器時的配置,可用docker inspect 容器名查看Hostname)
    mac用戶請sudo vi /etc/hosts
    windows用戶請搜索如何修改本地hosts映射
    在這裏插入圖片描述

  3. admin的tableExists方法會導致Connection refused異常,解決方法:造輪子2333
    在這裏插入圖片描述

下面給出代碼


maven配置

<?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 
  http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>org.example</groupId>
  <artifactId>hbase</artifactId>
  <version>1.0-SNAPSHOT</version>

  <name>hbase</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>

  <dependencies>
    <dependency>
      <groupId>org.apache.hbase</groupId>
      <artifactId>hbase-client</artifactId>
      <version>1.3.2</version>
    </dependency>
  </dependencies>

  <build>
    <pluginManagement>
      <plugins>
       
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-jar-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-site-plugin</artifactId>
          <version>3.7.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-project-info-reports-plugin</artifactId>
          <version>3.0.0</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>
package org.example;

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Admin;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;

public class Hbase {
    static Configuration conf=null;
    static {
        conf= HBaseConfiguration.create();
        conf.set("hbase.zookeeper.quorum","39.99.156.133");
        conf.set("hbase.zookeeper.property.clientPort","2181");
    }
    public static void show()throws  IOException {
        Connection connection=ConnectionFactory.createConnection(conf);
        Admin admin=connection.getAdmin();
        TableName[] tableNames = admin.listTableNames();
        for (TableName ts : tableNames) {
            System.out.println(ts.toString());
        }
    }
    public static boolean tableExists(String tableName) throws IOException {
        Connection connection=ConnectionFactory.createConnection(conf);
        Admin admin=connection.getAdmin();
        TableName[] tableNames = admin.listTableNames();
        for(TableName ts : tableNames) {
            if(ts.toString().equals(tableName)) {
                return true;
            }
        }
        return false;
    }
    public  static  void delectTable(String tableName) throws IOException {
        Connection connection=ConnectionFactory.createConnection(conf);
        Admin admin=connection.getAdmin();
        if(!tableExists(tableName)) {
            System.out.println("not exist!");
            return;
        }
        admin.disableTable(TableName.valueOf(tableName));
        admin.deleteTable(TableName.valueOf(tableName));
        System.out.println("delected "+ tableName);
    }
    public static void createTable(String tableName,String... families) throws Exception{
        HTableDescriptor tableDescriptor=new HTableDescriptor(TableName.valueOf(tableName));
        try{
            Connection connection=ConnectionFactory.createConnection(conf);
            Admin admin=connection.getAdmin();
            for(String family:families){
                tableDescriptor.addFamily(new HColumnDescriptor(family));
            }
            admin.createTable(tableDescriptor);   
            System.out.println("Create table Success!!!Table Name:["+tableName+"]");
        }catch (IOException e){
            e.printStackTrace();
        }
    }
    public static void main(String[] args) throws Exception {
        Hbase.createTable("tt", "name", "class");
        Hbase.show();
        Hbase.delectTable("tt");
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章