第 14 章 在 Data Grid Server 上运行脚本和任务


向 Data Grid 服务器部署中添加任务和脚本,以便从命令行界面(CLI)和 Hot Rod 或 REST 客户端进行远程执行。您可以将任务作为自定义 Java 类实施,或者以 JavaScript 等语言定义脚本。

14.1. 在 Data Grid 服务器部署中添加任务

将自定义服务器任务类添加到 Data Grid Server。

先决条件

  • 如果 Data Grid Server 正在运行,则停止它。

    Data Grid 服务器不支持自定义类的运行时部署。

流程

  1. 添加 META-INF/services/org.infinispan.tasks.ServerTask 文件,其中包含服务器任务的完全限定域名,例如:

    example.HelloTask
  2. 将服务器任务实施打包到 JAR 文件中。
  3. 将 JAR 文件复制到 Data Grid Server 安装的 $RHDG_HOME/server/lib 目录中。
  4. 将您的类添加到 Data Grid 配置中的反序列化允许列表中。或者,使用系统属性设置 allow 列表。

14.1.1. Data Grid Server 任务

Data Grid Server 任务是扩展 org.infinispan.tasks.ServerTask 接口的类,通常包括以下方法调用:

setTaskContext()
允许访问执行上下文信息,包括任务参数、执行哪些任务的缓存引用等。在大多数情况下,实施会将此信息存储在本地,并在实际执行任务时使用这些信息。使用 SHARED 实例化模式时,任务应使用 ThreadLocal 存储 TaskContext 进行并发调用。
getName()
返回任务的唯一名称。客户端使用这些名称调用任务。
getExecutionMode()

返回任务的执行模式。

  • TaskExecutionMode.ONE_NODE 仅处理请求的节点执行脚本。虽然脚本仍然可以调用集群操作。这是默认值。
  • TaskExecutionMode.ALL_NODES Data Grid 使用集群执行器在节点间运行脚本。例如,调用流处理的服务器任务需要在单一节点上执行,因为流处理被分发到所有节点。
getInstantiationMode()

返回用于任务的实例化模式。

  • TaskInstantiationMode.SHARED 创建一个单个实例,用于同一服务器上的每个任务执行。这是默认值。
  • TaskInstantiationMode.ISOLATED 为每个调用创建一个新实例。
call ()
计算结果。此方法在 java.util.concurrent.Callable 接口中定义,并通过服务器任务调用。
重要

服务器任务实施必须遵循服务加载程序模式要求。例如,实现必须具有零参数构造器。

以下 HelloTask 类实施提供了具有一个参数的示例任务。它还演示了使用 ThreadLocal 存储 TaskContext 以进行并发调用。

package example;

import org.infinispan.tasks.ServerTask;
import org.infinispan.tasks.TaskContext;

public class HelloTask implements ServerTask<String> {

   private static final ThreadLocal<TaskContext> taskContext = new ThreadLocal<>();

   @Override
   public void setTaskContext(TaskContext ctx) {
      taskContext.set(ctx);
   }

   @Override
   public String call() throws Exception {
      TaskContext ctx = taskContext.get();
      String name = (String) ctx.getParameters().get().get("name");
      return "Hello " + name;
   }

   @Override
   public String getName() {
      return "hello-task";
   }

}
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.