第 14 章 在 Data Grid Server 上运行脚本和任务
向 Data Grid 服务器部署中添加任务和脚本,以便从命令行界面(CLI)和 Hot Rod 或 REST 客户端进行远程执行。您可以将任务作为自定义 Java 类实施,或者以 JavaScript 等语言定义脚本。
14.1. 在 Data Grid 服务器部署中添加任务
将自定义服务器任务类添加到 Data Grid Server。
先决条件
如果 Data Grid Server 正在运行,则停止它。
Data Grid 服务器不支持自定义类的运行时部署。
流程
添加
META-INF/services/org.infinispan.tasks.ServerTask
文件,其中包含服务器任务的完全限定域名,例如:example.HelloTask
- 将服务器任务实施打包到 JAR 文件中。
-
将 JAR 文件复制到 Data Grid Server 安装的
$RHDG_HOME/server/lib
目录中。 - 将您的类添加到 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"; } }