Liking cljdoc? Tell your friends :D

temporal.client.worker

Methods for managing a Temporal worker instance

Methods for managing a Temporal worker instance
raw docstring

startclj

(start client options)
(start client {:keys [task-queue] :as options} factory-options)

Starts a worker processing loop.

Arguments:

(start {:task-queue ::my-queue :ctx {:some "context"}})
Starts a worker processing loop.

Arguments:

- `client`:             WorkflowClient instance returned from [[temporal.client.core/create-client]]
- `options`:            Worker start options (See [[worker-options]])
- `factory-options`:    WorkerFactory options (See [[worker-factory-options]])

```clojure
(start {:task-queue ::my-queue :ctx {:some "context"}})
```
sourceraw docstring

stopclj

(stop {:keys [factory] :as instance})

Stops a running worker.

Arguments:

  • instance: Result returned from original call to (start)
(let [instance (start {:task-queue ::my-queue})]
   ...
   (stop instance))
Stops a running worker.

Arguments:

- `instance`: Result returned from original call to ([[start]])

```clojure
(let [instance (start {:task-queue ::my-queue})]
   ...
   (stop instance))
```
sourceraw docstring

worker-factory-optionsclj

Options for configuring the worker-factory (See start)

ValueDescriptionTypeDefault
:enable-logging-in-replay booleanfalse
:max-workflow-thread-countMaximum number of threads available for workflow execution across all workers created by the Factory.int600
:worker-interceptorsCollection of WorkerInterceptorsWorkerInterceptor
:workflow-cache-sizeTo avoid constant replay of code the workflow objects are cached on a worker. This cache is shared by all workers created by the Factory.int600
:using-virtual-workflow-threadsUse Virtual Threads for all workflow threads across all workers created by this factory. This option is only supported for JDK >= 21. If set then :max-workflow-thread-count is ignored.booleanfalse
Options for configuring the worker-factory (See [[start]])

| Value                                          | Description                                                        | Type             | Default |
| ------------                                   | ----------------------------------------------------------------- | ---------------- | ------- |
| :enable-logging-in-replay                      |                                                                    | boolean | false       |
| :max-workflow-thread-count                     | Maximum number of threads available for workflow execution across all workers created by the Factory. | int | 600 |
| :worker-interceptors                           | Collection of WorkerInterceptors                                   | [WorkerInterceptor](https://javadoc.io/doc/io.temporal/temporal-sdk/latest/io/temporal/common/interceptors/WorkerInterceptor.html) | |
| :workflow-cache-size                           | To avoid constant replay of code the workflow objects are cached on a worker. This cache is shared by all workers created by the Factory. | int | 600 |
| :using-virtual-workflow-threads                | Use Virtual Threads for all workflow threads across all workers created by this factory. This option is only supported for JDK >= 21. If set then :max-workflow-thread-count is ignored. | boolean | false       |
sourceraw docstring

worker-optionsclj

Options for configuring workers (See start)

ValueMandatoryDescriptionTypeDefault
:task-queueyThe name of the task-queue for this worker instance to listen on.String / keyword
:ctx An opaque handle that is passed back as the first argument of temporal.workflow/defworkflow and temporal.activity/defactivity, useful for passing state such as database or network connections.<any>nil
:dispatch An optional map explicitly setting the dispatch tableSee belowAll visible activities/workers are automatically registered
:max-concurrent-activity-task-pollers Number of simultaneous poll requests on activity task queue. Consider incrementing if the worker is not throttled due to MaxActivitiesPerSecond or MaxConcurrentActivityExecutionSize options and still cannot keep up with the request rate.int5
:max-concurrent-activity-execution-size Maximum number of activities executed in parallel.int200
:max-concurrent-local-activity-execution-size Maximum number of local activities executed in parallel.int200
:max-concurrent-workflow-task-pollers Number of simultaneous poll requests on workflow task queue.int2
:max-concurrent-workflow-task-execution-size Maximum number of simultaneously executed workflow tasks.int200
:default-deadlock-detection-timeout Time period in ms that will be used to detect workflow deadlock.long1000
:default-heartbeat-throttle-interval Default amount of time between sending each pending heartbeat.Duration30s
:max-heartbeat-throttle-interval Maximum amount of time between sending each pending heartbeat.Duration60s
:local-activity-worker-only Worker should only handle workflow tasks and local activities.booleanfalse
:max-taskqueue-activities-per-second Sets the rate limiting on number of activities per second.double0.0 (unlimited)
:max-workers-activities-per-second Maximum number of activities started per second.double0.0 (unlimited)

dispatch-table

ValueDescription
:activitiesVector of temporal.activity/defactivity symbols to register
:workflowsVector of temporal.workflow/defworkflow symbols to register
(defactivity my-activity ...)
(defworkflow my-workflow ...)

(let [worker-options {:dispatch {:activities [my-activity] :workflows [my-workflow]}}]
   ...)
Options for configuring workers (See [[start]])

| Value                                          | Mandatory   | Description                                                       | Type             | Default |
| ------------                                   | ----------- | ----------------------------------------------------------------- | ---------------- | ------- |
| :task-queue                                    | y           | The name of the task-queue for this worker instance to listen on. | String / keyword |         |
| :ctx                                           |             | An opaque handle that is passed back as the first argument of [[temporal.workflow/defworkflow]] and [[temporal.activity/defactivity]], useful for passing state such as database or network connections.  | <any> | nil |
| :dispatch                                      |             | An optional map explicitly setting the dispatch table             | See below        | All visible activities/workers are automatically registered |
| :max-concurrent-activity-task-pollers          |             | Number of simultaneous poll requests on activity task queue. Consider incrementing if the worker is not throttled due to `MaxActivitiesPerSecond` or `MaxConcurrentActivityExecutionSize` options and still cannot keep up with the request rate. | int | 5 |
| :max-concurrent-activity-execution-size        |             | Maximum number of activities executed in parallel.                | int              | 200     |
| :max-concurrent-local-activity-execution-size  |             | Maximum number of local activities executed in parallel.          | int              | 200     |
| :max-concurrent-workflow-task-pollers          |             | Number of simultaneous poll requests on workflow task queue.      | int              | 2       |
| :max-concurrent-workflow-task-execution-size   |             | Maximum number of simultaneously executed workflow tasks.         | int              | 200     |
| :default-deadlock-detection-timeout            |             | Time period in ms that will be used to detect workflow deadlock.  | long             | 1000    |
| :default-heartbeat-throttle-interval           |             | Default amount of time between sending each pending heartbeat.    | [Duration](https://docs.oracle.com/javase/8/docs/api//java/time/Duration.html) | 30s |
| :max-heartbeat-throttle-interval               |             | Maximum amount of time between sending each pending heartbeat.    | [Duration](https://docs.oracle.com/javase/8/docs/api//java/time/Duration.html) | 60s |
| :local-activity-worker-only                    |             | Worker should only handle workflow tasks and local activities.    | boolean          | false   |
| :max-taskqueue-activities-per-second           |             | Sets the rate limiting on number of activities per second.        | double           | 0.0 (unlimited) |
| :max-workers-activities-per-second             |             | Maximum number of activities started per second.                  | double           | 0.0 (unlimited) |

#### dispatch-table

| Value        | Description                                                       |
| ------------ | ----------------------------------------------------------------- |
| :activities  | Vector of [[temporal.activity/defactivity]] symbols to register   |
| :workflows   | Vector of [[temporal.workflow/defworkflow]] symbols to register   |

```clojure
(defactivity my-activity ...)
(defworkflow my-workflow ...)

(let [worker-options {:dispatch {:activities [my-activity] :workflows [my-workflow]}}]
   ...)
```
sourceraw docstring

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close