環境:
1. hbase是運行在服務器的docker上的(爲啥不直接部署在服務器上?之前在服務器上部署了hadoop+hbase結果被利用hadoop的漏洞注入了挖礦的病毒…不想重新安裝所有服務也沒法完全清除病毒,於是就重裝系統,愉快的下了一個docker…)
2. 本地(mac)代碼連接服務器
主要參考
遇到的問題
-
hbase的版本要和hbase-client版本一致,不一致的話會出現方法的異常。
我的hbase是1.3.2的,所以hbase-client也要是1.3.2。後面代碼裏有體現。 -
地址映射,要在本地(mac)映射服務器上的主機爲myhbase(docker上運行的hbase的主機名,運行容器時的配置,可用
docker inspect 容器名
查看Hostname)
mac用戶請sudo vi /etc/hosts
windows用戶請搜索如何修改本地hosts映射
-
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");
}
}