12.3. hot Rod Client boostments


12.3.1. 支持交易

Java、C++ 和 C114 Hot Rod 客户端现在可以启动并参与事务。

Java Hot Rod 客户端支持 FULL_XANON_XA 事务模式。C++ 和 C114 Hot Rod 客户端只支持 NON_XA 事务模式。

如需更多信息,请参阅 Hot Rod Transactions

12.3.2. JMX 中的 Java Hot Rod 客户端统计信息

ServerStatistics 接口现在通过 JMX 公开 Java Hot Rod 客户端的统计信息。

您必须在 Hot Rod 客户端实现中启用 JMX 统计信息,如下例所示:

ConfigurationBuilder builder = new ConfigurationBuilder();
builder.addServer()
        	.host("127.0.0.1")
        	.port(11222)
        	.statistics()
        	.enable()
        	.jmxEnable();
  • enabled () 允许您收集客户端统计信息。
  • jmxEnabled () 通过 JMX 公开统计信息。

如需更多信息,请参阅 Java 文档中的 ServerStatistics

12.3.3. Java Hot Rod 客户端配置增强

此发行版本使用 hotrod-client.properties 文件改进了 Java Hot Rod 客户端的配置。您可以配置最接近的缓存设置、跨站点(xsite)属性、控制身份验证和加密等设置。

如需更多信息,请参阅 Hot Rod 客户端配置概述

12.3.4. 新的 Java Hot Rod 客户端实施基于 Netty

Hot Rod Java 客户端使用 Netty 框架构建,从而提高了通过同一连接同时执行操作的性能和支持。

在以前的版本中,应用程序执行的操作是同步进行的,或委派给专用线程池。

在本发行版本中,操作异步执行,响应会在 HotRod-client-async-pool 线程池中处理。操作可以通过同一连接进行多路复用,这需要较少的连接。

注意

自定义 marshallers 不得依赖于调用它们的任何特定线程进行 unmarshallers。

如需更多信息,请参阅 Java 文档:

12.3.5. JSON 对象的 JavaScript Hot Rod 客户端支持

Node.js Hot Rod 客户端添加了对原生 JSON 对象的支持,作为键和值。在以前的版本中,客户端只支持 String 键和值。

要使用原生 JSON 对象,您必须配置客户端,如下所示:

var infinispan = require('infinispan');
var connected = infinispan.client(
    {port: 11222, host: '127.0.0.1'}
    , {
        dataFormat : {
            keyType: 'application/json',
            valueType: 'application/json'
        }
    }
);
connected.then(function (client) {
  var clientPut = client.put({k: 'key'}, {v: 'value'});
  var clientGet = clientPut.then(
      function() { return client.get({k: 'key'}); });
  var showGet = clientGet.then(
      function(value) { console.log("get({k: 'key'})=" + JSON.stringify(value)); });
  return showGet.finally(
      function() { return client.disconnect(); });
}).catch(function(error) {
  console.log("Got error: " + error.message);
});

您可以单独为键和值配置数据类型。例如,您可以将键配置为 String,并将值配置为 JSON

注意

脚本目前不支持原生 JSON 对象。

12.3.6. 检索缓存名称 Through Hot Rod

此发行版本包括 getCacheNames () 方法,它返回以声明性或编程方式定义的缓存名称集合,以及通过 RemoteCacheManager 在运行时创建的缓存。

Hot Rod 协议现在还包含 @@cache@names admin 任务,它将缓存名称返回为字符串的 JSON 数组,如 ["cache1", "cache2"]。

如需更多信息,请参阅:

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.