当前位置: 首页 > news >正文

大数据-147 Apache Kudu 常用 Java API 增删改查

点一下关注吧!!!非常感谢!!持续更新!!!

目前已经更新到了:

  • Hadoop(已更完)
  • HDFS(已更完)
  • MapReduce(已更完)
  • Hive(已更完)
  • Flume(已更完)
  • Sqoop(已更完)
  • Zookeeper(已更完)
  • HBase(已更完)
  • Redis (已更完)
  • Kafka(已更完)
  • Spark(已更完)
  • Flink(已更完)
  • ClickHouse(已更完)
  • Kudu(正在更新…)

章节内容

上节我们完成了如下的内容:

  • Apache Kudu 的 Dockerfile
  • Dockerfile 详解
  • Kudu 启动访问

在这里插入图片描述

新建工程

由于重复了太多次,这里直接跳过了。

导入依赖

<dependency><groupId>org.apache.kudu</groupId><artifactId>kudu-client</artifactId><version>1.4.0</version>
</dependency>

创建新表

  • 必须指定表连接到的Master节点主机名
  • 必须定义Schema
  • 必须指定副本数量、分区策略、数量

编写代码

package icu.wzk.kudu;import org.apache.kudu.ColumnSchema;
import org.apache.kudu.Schema;
import org.apache.kudu.Type;
import org.apache.kudu.client.CreateTableOptions;
import org.apache.kudu.client.KuduClient;
import org.apache.kudu.client.KuduException;import java.util.ArrayList;
import java.util.List;public class KuduCreateTable {public static void main(String[] args) throws KuduException {String masterAddress = "localhost:7051,localhost:7151,localhost:7251";KuduClient.KuduClientBuilder kuduClientBuilder = new KuduClient.KuduClientBuilder(masterAddress);KuduClient kuduClient = kuduClientBuilder.build();String tableName = "student";List<ColumnSchema> columnSchemas = new ArrayList<>();ColumnSchema id = new ColumnSchema.ColumnSchemaBuilder("id", Type.INT32).key(true).build();columnSchemas.add(id);ColumnSchema name = new ColumnSchema.ColumnSchemaBuilder("name", Type.STRING).key(false).build();columnSchemas.add(name);Schema schema = new Schema(columnSchemas);CreateTableOptions options = new CreateTableOptions();// 副本数量为1options.setNumReplicas(1);List<String> colrule = new ArrayList<>();colrule.add("id");options.addHashPartitions(colrule, 3);kuduClient.createTable(tableName, schema, options);kuduClient.close();}}

测试运行

控制台未输出内容

运行结果如下图所示:
在这里插入图片描述

查看Kudu

我们查看Kudu的Tables,可以看到刚才创建的表如下:
在这里插入图片描述

删除表

编写代码

package icu.wzk.kudu;import org.apache.kudu.client.KuduClient;
import org.apache.kudu.client.KuduException;public class KuduDeleteTable {public static void main(String[] args) throws KuduException {String masterAddress = "localhost:7051,localhost:7151,localhost:7251,";KuduClient client = new KuduClient.KuduClientBuilder(masterAddress).defaultAdminOperationTimeoutMs(5000).build();client.deleteTable("student");client.close();}}

测试运行

控制台没有输出内容,这里运行截图如下:
在这里插入图片描述

查看Kudu

查看Kudu服务的 Table 页,里边的数据表已经删除了。
在这里插入图片描述

插入数据

  • 获取客户端
  • 打开一张表
  • 创建会话
  • 设置刷新模式
  • 获取插入实例
  • 声明带插入的数据
  • 刷入数据
  • 应用插入实例
  • 关闭会话

创建新表

我们运行刚才的创建新表代码,把student表先生成出来,具体运行这里跳过了。

编写代码

package icu.wzk.kudu;import org.apache.kudu.client.*;public class KuduInsert {public static void main(String[] args) throws KuduException {String masterAddr = "localhost:7051,localhost:7151,localhost:7251";KuduClient client = new KuduClient.KuduClientBuilder(masterAddr).defaultAdminOperationTimeoutMs(5000).build();KuduTable stuTable = client.openTable("student");KuduSession kuduSession = client.newSession();kuduSession.setFlushMode(SessionConfiguration.FlushMode.MANUAL_FLUSH);Insert insert = stuTable.newInsert();insert.getRow().addInt("id", 1);insert.getRow().addString("name", "wzk");kuduSession.flush();kuduSession.apply(insert);kuduSession.close();client.close();}}

在代码中,有一个叫:kuduSession.setFlushMode:

  • AUTO_FLUSH_SYNC(默认):意思是调用KuduSession apply方法后,客户端会在当前刷新到服务器后再返回,这种情况不能够批量插入数据,调用 flush 方法不会起作用,应为此时缓冲区已经被刷新到了服务器。
  • AUTO_FLUSH_BACKGROUD:意思是调用apply方法后,客户端会立即返回,但是写入将在后台发送,可能与来自同一会话的其他写入一起进行批处理。如果没有足够的缓冲空间,KuduSession apply会阻塞,缓冲空间不可用。因为写入操作是在后台进行的,因此任何一个错误都将存储在一个会话本地缓冲区中。注意:这个模式可能会导致插入是乱序的,这是因为在这种模式下,多个写操作可以并发的发送到服务器。且这是一个Kudu的BUG,详细请看:https://issues.apache.org/jira/browse/KUDU-1767https://issues.apache.org/jira/browse/KUDU-1767
  • MANUAL_FLUSH:调用apply后,会非常快的返回,但是写操作不会发送,直到用户使用flush函数,如果缓冲区超过了限制大小,apply就会返回一个错误。

测试运行

控制台无输出内容,运行的截图如下图所示:
在这里插入图片描述

查询数据

编写代码

Kudu的查询数据用Scanner

package icu.wzk.kudu;import org.apache.kudu.client.*;public class KuduSelect {public static void main(String[] args) throws KuduException {String masterAddr = "localhost:7051,localhost:7151,localhost:7251";KuduClient client = new KuduClient.KuduClientBuilder(masterAddr).build();KuduTable kuduTable = client.openTable("user");KuduScanner kuduScanner = client.newScannerBuilder(kuduTable).build();while (kuduScanner.hasMoreRows()) {for (RowResult result : kuduScanner.nextRows()) {int id = result.getInt("id");String name = result.getString("name");int age = result.getInt("age");System.out.println("id: " + id + ", name: " + name + ", age: " + age);}}client.close();}}

测试运行

id: 1, name: wzkProcess finished with exit code 0

运行结果如下图所示:
在这里插入图片描述

更改数据

编写代码

package icu.wzk.kudu;import org.apache.kudu.client.*;public class KuduUpdate {public static void main(String[] args) throws KuduException {String masterAddress = "localhost:7051,localhost:7151,localhost:7251";KuduClient client = new KuduClient.KuduClientBuilder(masterAddress).build();KuduTable stuTable = client.openTable("student");KuduSession kuduSession = client.newSession();kuduSession.setFlushMode(SessionConfiguration.FlushMode.MANUAL_FLUSH);Update update = stuTable.newUpdate();update.getRow().addInt("id", 1);update.getRow().addString("name", "wzk_icu");kuduSession.apply(update);kuduSession.close();client.close();}}

删除指定行

编写代码

package icu.wzk.kudu;import org.apache.kudu.client.*;public class KuduDelete {public static void main(String[] args) throws KuduException {String masterAddress = "localhost:7051,localhost:7151,localhost:7251";KuduClient client = new KuduClient.KuduClientBuilder(masterAddress).build();KuduSession kuduSession = client.newSession();KuduTable stuTable = client.openTable("student");kuduSession.setFlushMode(SessionConfiguration.FlushMode.MANUAL_FLUSH);Delete delete = stuTable.newDelete();PartialRow row = delete.getRow();row.addInt("id", 1);kuduSession.flush();kuduSession.apply(delete);kuduSession.close();client.close();}}

测试运行

控制台没有输出任何内容,运行过程截图如下:
在这里插入图片描述

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 回归阅读第一本:《瓦尔纳宝典》
  • 使用电脑当服务器,来组建局域网是否安全
  • mini-lsm通关笔记Week2Overview
  • IT行业的未来:技术变革与创新的持续推动
  • 肺结节检测-目标检测数据集(包括VOC格式、YOLO格式)
  • 复试经验分享《一、问答题自测》(408、相关前沿技术)
  • 【计算机网络篇】电路交换,报文交换,分组交换
  • echarts 导出pdf空白原因
  • 分析二极管的交流响应(1)——直流分析,Q点的计算
  • 【折腾笔记】雷池WAF社区版自动SSL续签
  • 前端面试题(二)
  • 观测云全面支持 OaC,通过 Terraform 管理您的可观测性
  • 【Pyside】pycharm2024配置conda虚拟环境
  • 我与Linux的爱恋:进程地址空间
  • stable diffusion 神经网络插件 controlnet 的安装,很详细
  • [数据结构]链表的实现在PHP中
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • Flex布局到底解决了什么问题
  • HTTP那些事
  • Javascript设计模式学习之Observer(观察者)模式
  • Java到底能干嘛?
  • k8s 面向应用开发者的基础命令
  • Median of Two Sorted Arrays
  • PHP的Ev教程三(Periodic watcher)
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 包装类对象
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 测试如何在敏捷团队中工作?
  • 订阅Forge Viewer所有的事件
  • 面试总结JavaScript篇
  • 全栈开发——Linux
  • [Shell 脚本] 备份网站文件至OSS服务(纯shell脚本无sdk) ...
  • kubernetes资源对象--ingress
  • 哈罗单车融资几十亿元,蚂蚁金服与春华资本加持 ...
  • ​人工智能书单(数学基础篇)
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • # 数论-逆元
  • #我与Java虚拟机的故事#连载08:书读百遍其义自见
  • $$$$GB2312-80区位编码表$$$$
  • (2024)docker-compose实战 (8)部署LAMP项目(最终版)
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (C语言)球球大作战
  • (HAL库版)freeRTOS移植STMF103
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (每日持续更新)jdk api之FileReader基础、应用、实战
  • (转)linux自定义开机启动服务和chkconfig使用方法
  • (转)程序员疫苗:代码注入
  • (转)大型网站的系统架构
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • .java 指数平滑_转载:二次指数平滑法求预测值的Java代码
  • .NET 解决重复提交问题
  • .Net 垃圾回收机制原理(二)
  • .NET8使用VS2022打包Docker镜像