文档章节

使用Apache Ignite构建C++版本的分布式应用

李玉珏
 李玉珏
发布于 01/27 23:06
字数 1189
阅读 289
收藏 5

本文会介绍Apache Ignite的C++ API(称为Ignite C++),主要面向C/C++开发者。

Ignite和Ignite C++

  • Ignite C++构建于Ignite之上;
  • Ignite C++在同一个进程中启动JVM,并且通过JNI与之通信;
  • .NET、C++和Java节点可以加入同一个集群,使用相同的缓存,并且使用通用的二进制协议进行互操作;
  • Java计算作业可以在任意节点上执行(Java、.NET和C++)。

入门

因为Ignite是一个分布式平台,所以开始就要先启动一个节点,这方面如果使用ignite::Ignition类是非常简单的:

好了,在C++环境中已经使用默认的配置启动了第一个Ignite节点!其中Ignite类是访问集群的主要入口点。

数据操作

暴露数据操作API的主要Ignite C++组件是ignite::cache::Cache<K,V>。它包含了基本的数据操作方法集。由于缓存本质上是作为分布式哈希表的接口,因此基本上可以像处理简单容器(map或者unordered_map)那样与它进行交互。

Ignite主要是用Java开发的,Ignite组件的实现也使用了很多Java的特性,比如,对象的序列化/反序列化就用在了磁盘存储和对象的网络传输上。

在Ignite C++中,这个特性通过ignite::binary::BinaryType<T>模板限定来实现:,不管是普通的客户端还是瘦客户端,都是用的这个方式,对于上面提到的Person类,大致如下:

这里除了序列化/反序列化方法BinaryType<Person>::WriteBinaryType<Person>::Read外,还有其它的一些方法,它们用于向平台说明,如何在其它语言中处理自定义C++类型,尤其是在Java中,下面会详细探讨这些方法:

  • GetTypeName():返回类型名。该类型名在所有使用这个类型的平台中都应该是一致的,如果只在Ignite C++中使用这个类型,那么这个命名就没有强制要求;
  • GetTypeId():返回跨平台的唯一类型ID。要想在所有平台上都有正确的行为,那么所有的实现都必须使用相同的计算方法。GetBinaryStringHashCode(TypeName)在任意平台的默认实现,都会返回相同的类型ID,因此这种实现方式在任意平台上都能保证该类型的正确使用;
  • GetFieldId():返回字段名的唯一ID。不过要保证跨平台,要使用GetBinaryStringHashCode()方法;
  • IsNull():检查类实例是否为空,该方法用于NULL值的正确序列化,对于类实例用处不大,不过如果用户想处理智能指针以及定义比如BinaryType< std::unique_ptr<Person>>这样的限定,则可能会比较方便;
  • GetNull():如果要反序列化NULL值,会调用它。关于IsNull()的说法,也适用于GetNull()

SQL

与传统数据库类似,可以将缓存视为数据库模式,并且该模式只有一个表名为类型名的表。除了缓存模式之外,还有一个名为PUBLIC的公共模式,在该模式中,可以使用标准DDL指令(如CREATE TABLEDROP TABLE等)创建/删除任意数量的表。通常,如果只想将Ignite用作分布式数据库,则可以通过ODBC/JDBC连接到PUBLIC模式。

Ignite支持完整的SQL查询,包括DML和DDL。通过MVCC,SQL事务也是支持的,不过还处于测试阶段。

要通过SQL处理缓存数据,必须在缓存配置中显式指定将在SQL查询中使用哪些对象字段。配置在XML文件中进行了描述,之后将在节点启动时指定配置文件的路径:

该配置会由Java来解析,因此其中的基本类型在Java中也要指定,配置文件建好之后,就可以启动一个节点,获取一个缓存实例,进而处理SQL:

这时候就可以执行INSERT、UPDATE、CREATE TABLE以及其它查询了,当然,跨缓存查询也是支持的。不过这种情况下要注意,需要给查询中的缓存名上加上引号,作为模式名,比如这样不行:

要这样写:

好了,暂时就写这么多,Apache Ignite功能强大,C++ API目前也仍在全力开发中,所以请继续关注未来的更新。

© 著作权归作者所有

李玉珏

李玉珏

粉丝 357
博文 77
码字总数 161083
作品 0
沈阳
架构师
私信 提问
Apache Ignite 1.9.0 发布,内存数据组织平台

Apache Ignite 内存数组组织框架是一个高性能、集成和分布式的内存计算和事务平台,用于大规模的数据集处理。Ignite 为应用和不同的数据源之间提供一个高性能、分布式内存中数据组织管理的框...

王练
2017/03/07
1K
2
Apache Ignite 1.6.0 发布,内存数据组织平台

Apache Ignite 内存数据组织平台 1.6.0 版本发布: --------------------------------------- Ignite .NET: * 新增:为缓存的SQl查询提供了 LINQ Provider; * 新增: 原生的配置机制 (C#, a...

李玉珏
2016/05/23
3.8K
9
Apache Ignite 1.7.0 发布,内存数据组织平台

Apache Ignite 1.7.0 发布了。Apache Ignite 内存数组组织框架是一个高性能、集成和分布式的内存计算和事务平台,用于大规模的数据集处理。Ignite 为应用和不同的数据源之间提供一个高性能、...

李玉珏
2016/08/06
5.5K
9
Apache Ignite 2.1.0 版本发布,全新的持久化存储

社区宣布,Apache Ignite 2.1.0版本正式发布。 这个版本包括了一个捐赠来的全新特性-Ignite持久化存储,他具有完全的内存持久化架构,使得应用同时具有基于内存的高性能以及基于磁盘的持久化...

李玉珏
2017/07/28
1K
6
Apache Ignite 1.5.0-final 发布,内存数据组织平台

Apache Ignite 1.5.0-final 发布,此版本更新内容如下: * Ignite.NET: 第一版. * Ignite C++: 第一版. * 缓存操作和SQL查询的重要性能改进. * 增加了新的二进制对象的编组实现. * 增加了新的...

李玉珏
2016/01/05
2.1K
1

没有更多内容

加载失败,请刷新页面

加载更多

局域网能互相ping通,ubuntu虚拟机不能上外网

【问题】 桥接模式老是无法上网,查看本机IP发现被分配了一个私网地址,猜测应该是虚拟DHCP服务器没有打开,于是查看Ubuntu的网络配置: /etc/network/interfaces 发现没有dhcp配置的信息,只...

tahiti_aa
46分钟前
1
0
以太坊助记词PHP开发包简介

以太坊助记词PHP开发包用来为PHP以太坊应用增加助记词和层级确定密钥支持能力。下载地址:以太坊助记词php开发包 。 1、开发包概述 以太坊助记词PHP开发包主要包括以下特性: 生成符合BIP39...

汇智网教程
昨天
2
0
系统监控-分布式调用链Skywalking

1. 为什么要使用分布式调用链技术? 随着公司业务的高速发展,公司服务之间的调用关系愈加复杂,如何理清并跟踪它们之间的调用关系就显的比较关键。线上每一个请求会经过多个业务系统,并产生...

秋日芒草
昨天
4
0
告诉自己的一些建议

摆脱学生心态 尽快发挥自己价值,让公司感知自己的存在,才是王道 选择比努力重要 自己附着的平台的经济体要是一个快速崛起的行业 转行趁早,年龄越大选择成本越高 趁早大量试错,学习新领域...

林怡丰
昨天
3
0
Windows下安装Redis

下载地址: 3.0老版已不维护更新:https://github.com/MicrosoftArchive/redis/releases 4.0版 https://github.com/tporadowski/redis/releases 中文官网:http://www.redis.net.cn/ https:......

Aeroever
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部