分享知识-快乐自己:HBase编程
HBase编程:
-----------------------------------------------------------------
HBase JavaAPI概述:
1.HBase使用Java语言编写的,自然支持Java编程
2.支持CRUD操作:create read update delete
3.JavaAPI包含了所有HBase的shell,甚至更多
4.JavaAPI是访问HBase的最快方式
JavaAPI程序设计:
1、创建一个Configuration
Configuration conf = HbaseConfiguration.create();
Configuration对象包含了连接到HBase服务的信息:zookeeper的位置,连接时间等
HbaseConfiguration.create()内部逻辑:
从CLASSPATH下加载hbase-default.xml和hbase-site.xml文件需将hbase-site.xml放入到CLASSPATH下 hbase-site.xml将覆盖hbase-default.xml的同名属性
自定义配置文件,使用Configuration加载
Configuration newConf = Configuration.create(existingConf);
用户自定义的配置文件将在已有配置文件之后加载将覆盖hbase-default.xml和 hbase-site.xml中的配置
自定义参数值:
Configuration conf=HbaseConfiguration.create();
conf.set("hbase.zookeeper.quorum", "admin-01,admin-02");
通常不推荐这么做!
2、创建HTable句柄
提供Configuration对象和待访问Table名称 HTable table = new HTable(conf, tableName);
一个table对应一个HTbale句柄:
提供了CRUD操作
设计简单、使用方便
提供行级事务
不支持多行事务或者表级别的事务
严格的行一致性
并发读、顺序写
创建HTable句柄代价很大 扫描.META.表等;
创建一次,以后尽可能复用;
如果需要创建多个Htable句柄,使用 HTablePool;
HTable并非线程安全的 一个线程创建一个即可
Htable支持CRUD批处理
非线程安全,仅是为了提高性能
3、执行相应的CRUD操作
执行put、get、delete、scan等操作
table.getTableName();
4、关闭HTable句柄
将内存数据刷新到磁盘上 释放各种资源
table.close();
前期工作:
将虚拟主机当中的hbase-site.xml和hdfs-site.xml文件复制到项目下的classpath下

修改windows真机的hosts文件,添加三台机器的映射

导入POM文件:
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-common</artifactId>
<version>2.8.0</version>
</dependency> <dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-hdfs</artifactId>
<version>2.8.0</version>
</dependency> <dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-client</artifactId>
<version>2.8.0</version>
</dependency> <dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-client</artifactId>
<version>1.3.1</version>
</dependency> <dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-server</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-common</artifactId>
<version>1.3.1</version>
</dependency>
HBase_API 操作:
package com.gdbd; import java.io.IOException;
import java.util.Scanner; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.ZooKeeperConnectionException;
import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.util.Bytes; /**
* Hello world!
*
*/
public class App { public static void main(String[] args) throws IOException { do {
System.out.println("\n\n*********************HBase_API***神码操作平台*********************");
System.out.println("1、创建表");
System.out.println("2、向表中添加数据");
System.out.println("3、查询表中所有数据");
System.out.println("4、查询表中指定RowKey的所有数据");
System.out.println("5、删除指定列族的指定列");
System.out.println("6、删除指定列族");
System.out.println("7、删除表中指定RowKey的所有数据删除表中指定RowKey的所有数据");
System.out.println("8、删除表");
Scanner input = new Scanner(System.in);
System.out.println("请输入......");
int num = input.nextInt();
switch (num) {
case 1:
demo01();
break;
case 2:
demo02();
break;
case 3:
cat();
break;
case 4:
catRows();
break;
case 5:
delFamilyColumn();
break;
case 6:
delFamily();
break;
case 7:
delRow();
break;
case 8:
delTable();
break;
}
} while (true);
} /***
* 创建表
*
* @throws MasterNotRunningException
* @throws ZooKeeperConnectionException
* @throws IOException
*/
private static void demo01() throws MasterNotRunningException, ZooKeeperConnectionException, IOException {
System.out.println("正在 创建表...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
/**
* 创建HBaseAdmin对象 此对象 提供了 建表,创建列族,检查表是否存在,修改表和列族结构,删除表等功能 HBaseAdmin实例的生命周期不宜太长
*/
HBaseAdmin admin = new HBaseAdmin(configuration);
if (admin.tableExists("hbase_demo")) {
System.out.println("表已经存在!!!");
} else { // 证明表不存在
HTableDescriptor table = new HTableDescriptor("hbase_demo"); // 创建表的描述对象
// new HColumnDescriptor对象:设置列族的特性
table.addFamily(new HColumnDescriptor("grade"));
table.addFamily(new HColumnDescriptor("course"));
// 定义好了表名和列族 可以创建表
admin.createTable(table);
System.out.println("表创建成功!!!");
}
} /***
* 向表中添加数据
*
* @throws IOException
*/
private static void demo02() throws IOException {
System.out.println("正在 向表中添加数据...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建put对象
Put put = new Put("xiaohei".getBytes()); // xiaohei是 row key
put.addColumn("course".getBytes(), "java".getBytes(), "90".getBytes()); // course是列族
put.addColumn("course".getBytes(), "sql".getBytes(), "99".getBytes()); // java 和sql 都是列
put.addColumn("grade".getBytes(), "one".getBytes(), "1".getBytes());
// 向表中增加数据
table.put(put);
// 关闭table
table.close();
System.out.println("插入成功......");
} /***
* 查询表数据
*
* @throws IOException
*/
private static void cat() throws IOException {
System.out.println("正在 查询表数据...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建ResultScanner对象
ResultScanner rs = table.getScanner(new Scan());
for (Result r : rs) {
System.out.println("***************************Result Start***************************");
for (Cell cell : r.rawCells()) {
System.out.println("=======================start============================");
System.out.println("RowKey(行键)===>" + Bytes.toString(r.getRow()));
System.out.println("family(列族)===>" + Bytes.toString(CellUtil.cloneFamily(cell)));
System.out.println("column(列)===>" + Bytes.toString(CellUtil.cloneQualifier(cell)));
System.out.println("value(值)===>" + Bytes.toString(CellUtil.cloneValue(cell)));
System.out.println("=========================END==========================");
}
System.out.println("****************************Result END****************************");
}
// 关闭table
table.close();
System.out.println("表数据查询成功...");
} /***
* 查询表中指定RowKey的所有数据
*
* @throws IOException
*/
private static void catRows() throws IOException {
System.out.println("正在 查询表中指定RowKey的所有数据...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建get对象 获取所有rowkey是xiaohei的所有数据
Get get = new Get(Bytes.toBytes("xiaohei"));
Result result = table.get(get);
for (Cell cell : result.rawCells()) {
System.out.println("=======================start============================");
System.out.println("RowKey(行键)===>" + Bytes.toString(result.getRow()));
System.out.println("family(列族)===>" + Bytes.toString(CellUtil.cloneFamily(cell)));
System.out.println("column(列)===>" + Bytes.toString(CellUtil.cloneQualifier(cell)));
System.out.println("value(值)===>" + Bytes.toString(CellUtil.cloneValue(cell)));
System.out.println("=========================END==========================\n");
}
// 关闭table
table.close();
System.out.println("成功 查询表中指定RowKey的所有数据");
} /***
* 删除表中指定RowKey的所有数据
*
* @throws IOException
*/
private static void delRow() throws IOException {
System.out.println("正在删除表中指定RowKey的所有数据...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建delete对象
Delete delete = new Delete(Bytes.toBytes("xiaohei"));
table.delete(delete);
// 关闭table
table.close();
System.out.println("成功删除表中指定RowKey的所有数据...");
} /***
* 删除指定列族的指定列
*
* @throws IOException
*/
private static void delFamilyColumn() throws IOException {
System.out.println("正在 删除指定列族的指定列...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建delete对象
Delete delete = new Delete(Bytes.toBytes("xiaobaibai"));// 指定的
delete.addColumn(Bytes.toBytes("course"), Bytes.toBytes("java"));
table.delete(delete);
// 关闭table
table.close();
System.out.println("成功 删除指定列族的指定列...");
} /***
* 删除指定列族的
*
* @throws IOException
*/
private static void delFamily() throws IOException {
System.out.println("正在 删除指定列族...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HTable对象
HTable table = new HTable(configuration, "hbase_demo");
// 创建delete对象
Delete delete = new Delete(Bytes.toBytes("xiaobaibai"));// 指定的
delete.addFamily("course".getBytes());
table.delete(delete);
// 关闭table
table.close();
System.out.println("成功 删除指定列族...");
} /***
* 删除表
*
* @throws MasterNotRunningException
* @throws ZooKeeperConnectionException
* @throws IOException
*/
private static void delTable() throws MasterNotRunningException, ZooKeeperConnectionException, IOException {
System.out.println("正在 删除表...\n");
// 创建一个Configuration对象
Configuration configuration = HBaseConfiguration.create();
// 创建HAdmin对象
HBaseAdmin admin = new HBaseAdmin(configuration);
admin.disableTable("hbase_demo");// 禁用表
admin.deleteTable("hbase_demo");// 删除表
// 关闭admin对象
admin.close();
System.out.println("成功 删除表...");
} }
分享知识-快乐自己:HBase编程的更多相关文章
- 分享知识-快乐自己:揭秘HBase
揭秘HBase: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce 六):揭秘HBa ...
- HBase编程 API入门系列之create(管理端而言)(8)
大家,若是看过我前期的这篇博客的话,则 HBase编程 API入门系列之put(客户端而言)(1) 就知道,在这篇博文里,我是在HBase Shell里创建HBase表的. 这里,我带领大家,学习更高 ...
- 分享知识-快乐自己:揭秘HDFS
揭秘HDFS: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce 六):揭秘HBas ...
- 分享知识-快乐自己:Liunx-大数据(Hadoop)初始化环境搭建
大数据初始化环境搭建: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce 六):揭秘 ...
- 分享知识-快乐自己:运行(wordcount)案例
运行 wordcount 案例: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce ...
- 分享知识-快乐自己:大数据(hadoop)环境搭建
大数据 hadoop 环境搭建: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce ...
- HBase编程实例
摘要:在前文中安装了Hbase,通过Hbase shell能够进行一些操作.可是和实际的编程实例联系起来不方便,因此本文介绍有关Hbase编程的实例. 一.使用Eclipse开发HBase应用程序 1 ...
- HBase编程 API入门系列之delete(客户端而言)(3)
心得,写在前面的话,也许,中间会要多次执行,连接超时,多试试就好了. 前面的基础,如下 HBase编程 API入门系列之put(客户端而言)(1) HBase编程 API入门系列之get(客户端而言) ...
- HBase编程 API入门系列之get(客户端而言)(2)
心得,写在前面的话,也许,中间会要多次执行,连接超时,多试试就好了. 前面是基础,如下 HBase编程 API入门系列之put(客户端而言)(1) package zhouls.bigdata.Hba ...
随机推荐
- 【数据挖掘】分类之decision tree(转载)
[数据挖掘]分类之decision tree. 1. ID3 算法 ID3 算法是一种典型的决策树(decision tree)算法,C4.5, CART都是在其基础上发展而来.决策树的叶子节点表示类 ...
- Linux中终端和控制台区别
Linux中终端和控制台区别: 终端:英文名叫terminal 控制台:英文名叫console 两者区别要从以前的多人使用的计算机开始 以前,由于计算机很昂贵,所用一台计算机一般由多个人同时使用.这样 ...
- Android控件ListView获取item中EditText值
能够明白,如今没有直接方法能够获得ListView中每一行EditText的值. 解决方式:重写BaseAdapter,然后自行获取ListView中每行输入的EditText值. 大概算法:重写Ba ...
- Argparse 命令行解析模块常用参数
Argparse模块可以轻松编写用户友好的命令行界面.该程序定义了它需要的参数,argparse 并将找出如何解析这些参数sys.argv.该argparse 模块还会自动生成帮助和用法消息,并在用户 ...
- Windows 7 里进程管理器里面的各列是什么含义?主要是和内存有关的内存-专用工作集,内存-工作集,内存-提交大小???
内存 - 工作集:私人工作集中的内存数量与进程正在使用且可以由其他进程共享的内存数量的总和. 内存 - 峰值工作集:进程所使用的工作集内存的最大数量. 内存 - 工作集增量:进程所使用的工作集内存中的 ...
- qb64手记(2)
传值与传引用 PRINT mymax(12, 111) x1 = 55x2 = 66myswapPRINT x1 FUNCTION mymax (x, y)IF x > y THEN my ...
- 使用CSDN CODE来存放OPENSTACK位于GITHUB上的源代码
use CSDN CODE to pull openstack codes 2014-11-20 Author:Hyphen 问题 直接从GITHUB上获代替码,常常是没保障,特别是用DEVSTACK ...
- Struts中类型转换踩的坑
出现的异常: 当我输入的数据很大时候,转换后如上,这并不是我想要的, 出现问题的原因: Struts2对常用的数据类型如String.Integer.Double等都添加了转换器进行对应的转换操作. ...
- 【python】-- 类的实例化过程、特征、共有属性和私有属性
实例化过程 1.类的定义和语法 class dog(object): #用class定义类 "dog class" #对类的说明 def __init__(self,name): ...
- 我的Android进阶之旅------>Android实现用Android手机控制PC端的关机和重启的功能(三)Android客户端功能实现
我的Android进阶之旅------>Android实现用Android手机控制PC端的关机和重启的功能(一)PC服务器端(地址:http://blog.csdn.net/ouyang_pen ...