首页  

temporal 多个 worker 实例 测试说明     所属分类 temporal 浏览量 746
worker 注册 workflow 和 activity
然后分别 轮询 workflow 和 activity taskqueue 执行

两个 worker 实例
work1 一个 只有 1个 activity 
work2 一个 有 2个 activity
模拟 生产环境 升级更新 ,代码实现不一致的问题

运行工作流  会得到 3种结果
1个 activity 时的结果
2个 activity 时的结果
错误结果  , 第二个activity 被 work1 取走执行, 报错,因为他根本没有 注册第二个activty

EVENT_TYPE_WORKFLOW_EXECUTION_FAILED
Activity Type  "echo2" is not registered with a worker. Known types are: echo"



注意查看工作流历史事件信息
identity 为具体的执行者

event_id: 13
event_time {
  seconds: 1650952955
  nanos: 778616000
}
event_type: EVENT_TYPE_ACTIVITY_TASK_FAILED
task_id: 25166370
activity_task_failed_event_attributes {
  failure {
    message: "Activity Type \"echo2\" is not registered with a worker. Known types are: echo"
    source: "JavaSDK"
    stack_trace: "
io.temporal.internal.sync.POJOActivityTaskHandler.handle(POJOActivityTaskHandler.java:199)
io.temporal.internal.worker.ActivityWorker$TaskHandlerImpl.handle(ActivityWorker.java:193)
io.temporal.internal.worker.ActivityWorker$TaskHandlerImpl.handle(ActivityWorker.java:151)
io.temporal.internal.worker.PollTaskExecutor.lambda$process$0(PollTaskExecutor.java:73)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
java.lang.Thread.run(Thread.java:748)"

    application_failure_info {
      type: "java.lang.IllegalArgumentException"
    }
  }
  scheduled_event_id: 11
  started_event_id: 12
  identity: "12666@dugang"
  retry_state: RETRY_STATE_MAXIMUM_ATTEMPTS_REACHED
}




可以开启 LocalActivity , activity就不会调度到别的机器上 private final EchoActivities activities = Workflow.newActivityStub(EchoActivities.class, // 超时设置 ActivityOptions.newBuilder().setStartToCloseTimeout(Duration.ofSeconds(TIMEOUT_SECONDS)) // 设置最大重试次数 ,否则会重试直到最大次数 .setRetryOptions(RetryOptions.newBuilder().setMaximumAttempts(1).build()).build()); // LocalActivity , 避免被调度到其他机器上 (被别的worker 拉取到) ,可提升性能 private final EchoActivities activities = Workflow.newLocalActivityStub(EchoActivities.class, // 超时设置 LocalActivityOptions.newBuilder().setStartToCloseTimeout(Duration.ofSeconds(TIMEOUT_SECONDS)) // 设置最大重试次数 ,否则会重试直到最大次数 .setRetryOptions(RetryOptions.newBuilder().setMaximumAttempts(1).build()).build()); 工作流历史事件从 17个变为10个
基本可以断定 数据库 和 temporal-server 不会存 工作流注册信息的 一个worker注册的工作流信息 ,只有他自己知道 任务的路由匹配机制 只基于 名字和 taskqueue , 跟 注册的工作流信息无关
com.dyyx.temporal.demo.echo.EchoWorker com.dyyx.temporal.demo.echo.EchoWorkerOneActivity
完整代码 https://gitee.com/dyyx/hellocode/tree/master/demo/temporal/sdkdemo

上一篇     下一篇
Go检查结构体是否实现了指定接口

temporal worker 线程信息 及 轮询获取工作流关键代码

不使用for和while 实现循环效果

temporal 工作流注册关键代码

PostgreSQL encode 函数

MySQL jdbc 版本问题导致 连接错误