HandlerSocket client for java——MySql as NoSQL

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

HandlerSocket是日本人 akira higuchi 写的一个MySql的插件,通过这个插件,你可以直接跟MySql后端的存储引擎做key-value式的交互,省去了MySql上层的SQL解释、打开关闭表、创建查询计划等CPU消耗型的开销,按照作者给出的数据可以在数据全部在内存的情况下可以达到75W的QPS查询。具体信息可以看这篇Blog,中文介绍可以看这篇文章《HandlerSocket in action》。

这个东西为什么让我很激动呢?首先性能是程序员的G点,一听高性能你不由地激动,其次,这也解决了缓存跟数据库的一致性问题,因为缓存就在数据库里面,第三,这个东西不仅仅是NoSQL,简单的CRUD你可以通过HandlerSocket,但是复杂的查询你仍然可以走MySql,完全符合我们应用的场景,并且从实际测试来看,性能确实非常优秀。但是呢,这个东西的代价也少不了,例如没有权限检查(未来可能添加);不能启用MySql的查询缓存,否则会导致数据的不一致;协议设计也不合理,使用t做分隔符,使用n做换行符,那么你插入或者更新的字段数据就不能含有这些字符,否则行为将不如预期。

HandlerSocket有一个日本人的java客户端实现,我去尝试了下,结果发现这玩意完全不具实用性,封装的层次非常原始。因此我自己写了个新的客户端,这就是本文要介绍的HandlerSocket Client for Java,简称hs4j,项目放在了googlecode,代码的网络层复用xmemcached,重新实现了协议和上层接口,目前的状态完全可用,也希望有需要的朋友参与测试。

项目地址:http://code.google.com/p/hs4j/

HS4J的使用很简单,所有的操作都通过HSClient这个接口进行,如我们创建一个客户端对象:
[java]
import com.google.code.hs4j.HSClient;
import com.google.code.hs4j.impl.HSClientImpl;

HSClient hsClient = new HSClientImpl(new InetSocketAddress(9999));
[/java]
假设HandlerSocket运行在本地的9999端口,默认的9998是只读的,9999才是允许读和写。HSClient是线程安全的。

在执行操作前需要先open index:
[java]
import com.google.code.hs4j.IndexSession;

IndexSession session = hsClient.openIndexSession(db, table,
"PRIMARY", columns);
[/java]
其中db是数据库名,table是表名,"PRIMARY"表示使用主键索引,columns是一个字符串数组代表你要查询的字段名称。这里没有指定 indexid,默认会产生一个indexid,你也可以指定indexid,返回表示一次open-index会话对象,IndexSession同样是线程安全的。
[java]
IndexSession session = hsClient.openIndexSession(indexid,db, table,
"PRIMARY", columns);
[/java]
查询操作通过find方法:
[java]
import java.sql.ResultSet;

final String[] keys = { "dennis", "killme2008@gmail.com" };
ResultSet rs = session.find(keys);
while(rs.next()){
String name=rs.getString(1);
String mail=rs.getString(2);
}
[/java]
find返回的是java.sql.ResultSet,你完全可以像使用jdbc那样去操作结果集。当然我的简单实现并不符合JDBC规范,只实现了最常见的一些方法,如getStrng、getLong等。find(keys)方法默认使用的op是"="。其他重载方法可以设置其他类型的op,统一封装为枚举类型FindOperator。

更新操作:
[java]
import com.google.code.hs4j.FindOperator;

int result=session.update(keys, new String[] { "1", "dennis",
"test@163.com", "109" }, FindOperator.EQ);
[/java]
keys表示索引的字段列表对应的值数组,通过FindOperator.EQ比较这些值和索引,第二个参数values表示要更新的字段值,这些值跟你在open-index的时候传入的columns一一对应,最后返回作用的记录数。

删除操作:
[java]
int result= session.delete(new String[] { "dennis" },
FindOperator.EQ)
[/java]
HS4J同样支持连接池,可以在构建客户端的时候传入连接池大小:
[java]
//100-connections pool
HSClient hsClient = new HSClientImpl(new InetSocketAddress(9999),100);
[/java]
在open index的时候,会在连接池里所有的连接上都open。并且在连接因为意外情况(如网络错误)断开的时候,HS4J会自动重连,并在重连成功的情况下自动发送已经open的index,保证应用的操作不受重连影响。

因为HS4J是我在两天内写就的一个东西,可能还有不少隐藏的bug,并且HandlerSocket本身也是个新东西,如果有什么问题或者改进建议,随时欢迎告诉我,多谢。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
Java 关系型数据库 MySQL
|
8月前
|
SQL 关系型数据库 Java
Java中使用MySQL详解
在Java中与MySQL交互是常见的任务。本文档涵盖了从安装MySQL Connector/J驱动到配置数据库连接、执行SQL语句、处理结果集、事务管理、使用连接池、最佳实践、错误处理、性能优化和安全性的一系列步骤。示例代码演示了如何建立连接、执行查询和关闭资源。通过学习,开发者可以掌握基础的数据库操作技巧,为进一步深入学习打下基础。
423 0
|
关系型数据库 MySQL
java-JDBC操作Mysql
java-JDBC操作Mysql
38 0
|
存储 关系型数据库 MySQL
Java 最常见的面试题:说一下 mysql 常用的引擎?
Java 最常见的面试题:说一下 mysql 常用的引擎?
|
Java 关系型数据库 MySQL
JAVA与Mysql.
JAVA与Mysql.
62 0
|
SQL Java 关系型数据库
【MySQL】Java-JDBC
其实各种各样的语言都可以操控数据库的
105 0
|
Java 关系型数据库 MySQL
Java连接访问MySQL数据
本文通过mysql-connector-java连接并访问MySQL数据。
295 0
Java连接访问MySQL数据
|
关系型数据库 MySQL Java
Java连接MySQL数据
前提:准备好所用的工具 1) MySQL(您电脑上已经装好的) 2)Navicat数据库管理工具 3)Eclipse
142 0
Java连接MySQL数据
|
存储 SQL 关系型数据库
MySQL与Java对比
当一个查询结果出现非常频繁时,并且该查询结果进行子查询出现的非常频繁,此时可以将一个查询结果保存为一张虚拟的表,来供其他查询使用。
174 0
|
Java 数据库连接
java通过jdbc连接clickhouse
先确认我们的ck服务正常,随便做个查询
6046 0
java通过jdbc连接clickhouse