Class: TaskExecutor
executor.TaskExecutor
A high-level module for defining and executing tasks in the golem network
Table of contents
Constructors
Properties
Methods
Constructors
constructor
• new TaskExecutor(options
)
Create a new TaskExecutor object.
Parameters
Name | Type | Description |
---|---|---|
options | ExecutorOptionsMixin | contains information needed to start executor, if string the imageHash is required, otherwise it should be a type of ExecutorOptions |
Defined in
Properties
events
• Readonly
events: EventEmitter
<TaskExecutorEventsDict
, any
>
EventEmitter (EventEmitter3) instance emitting TaskExecutor events.
See
TaskExecutorEventsDict for available events.
Defined in
Methods
create
â–¸ Static
create(options
): Promise
<TaskExecutor
>
Create a new Task Executor
Parameters
Name | Type | Description |
---|---|---|
options | ExecutorOptionsMixin | Task executor options |
Returns
Promise
<TaskExecutor
>
TaskExecutor
Description
Factory Method that create and initialize an instance of the TaskExecutor
Example
Simple usage of Task Executor
The executor can be created by passing appropriate initial parameters such as package, budget, subnet tag, payment driver, payment network etc. One required parameter is a package. This can be done in two ways. First by passing only package image hash or image tag, e.g.
const executor = await TaskExecutor.create("9a3b5d67b0b27746283cb5f287c13eab1beaa12d92a9f536b747c7ae");
or
const executor = await TaskExecutor.create("golem/alpine:3.18.2");
Example
Usage of Task Executor with custom parameters
Or by passing some optional parameters, e.g.
const executor = await TaskExecutor.create({
subnetTag: "public",
payment: { driver: "erc-20", network: "holesky" },
package: "golem/alpine:3.18.2",
});
Defined in
init
â–¸ init(): Promise
<void
>
Initialize executor
Returns
Promise
<void
>
Description
Method responsible initialize all executor services.
Defined in
shutdown
â–¸ shutdown(): Promise
<void
>
Stop all executor services and shut down executor instance.
You can call this method multiple times, it will resolve only once the executor is shutdown.
When shutdown() is initially called, a beforeEnd event is emitted.
Once the executor is fully stopped, an end event is emitted.
Returns
Promise
<void
>
Defined in
getStats
â–¸ getStats(): Object
Returns
Object
Name | Type |
---|---|
retries | number |
providers | number |
agreements | number |
invoicesReceived | number |
invoicesPaid | number |
invoicesUnpaid | number |
invoicesMissing | number |
invoicePaymentRate | number |
Defined in
onActivityReady
â–¸ onActivityReady(worker
): void
Registers a worker function that will be run when an activity is ready. This is the perfect place to run setup functions that need to be run only once per activity, for example uploading files that will be used by all tasks in the activity. This function can be called multiple times, each worker will be run in the order they were registered.
Parameters
Name | Type | Description |
---|---|---|
worker | Worker <unknown > | worker function that will be run when an activity is ready |
Returns
void
Example
const uploadFile1 = async (ctx) => ctx.uploadFile("./file1.txt", "/file1.txt");
const uploadFile2 = async (ctx) => ctx.uploadFile("./file2.txt", "/file2.txt");
executor.onActivityReady(uploadFile1);
executor.onActivityReady(uploadFile2);
await executor.run(async (ctx) => {
await ctx.run("cat /file1.txt /file2.txt");
});
Defined in
run
â–¸ run<OutputType
>(worker
, options?
): Promise
<OutputType
>
Run task - allows to execute a single worker function on the Golem network with a single provider.
Type parameters
Name |
---|
OutputType |
Parameters
Name | Type | Description |
---|---|---|
worker | Worker <OutputType > | function that run task |
options? | TaskOptions | task options |
Returns
Promise
<OutputType
>
result of task computation
Example
await executor.run(async (ctx) => console.log((await ctx.run("echo 'Hello World'")).stdout));
Defined in
cancel
â–¸ cancel(reason
): Promise
<void
>
Parameters
Name | Type |
---|---|
reason | string |
Returns
Promise
<void
>