> ## Documentation Index
> Fetch the complete documentation index at: https://iii.dev/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# Workers

> Using workers in your iii project.

{/* TODO: Add back once worker init is merged. <Note> This page covers using existing workers. For creating new workers (`iii worker init`), registering functions and triggers, and building or publishing worker images, see [Creating Workers / Workers](../creating-workers/workers). </Note> */}

## Workers are sort of like services

Think of workers as iii's version of a self-contained, isolated service that freely interoperates
with every other worker. Any time you're adding functionality that functionality will come in the
form of a worker.

Workers differ from traditional services by not requiring any integration to use. Instead workers
can be installed and managed like npm packages with the command `iii worker add` below. The
difference is that you get complete deployable runtimes rather than a library. See the section on
adding workers below.

## Worker lifecycle

Workers connect to iii over WebSocket. When a worker connects it becomes visible to the entire iii
system and every other worker within it. When a worker disconnects, its functions and triggers stop
being callable until it reconnects.

<Note>
  For the SDK calls that establish the connection from worker code, see [Creating Workers /
  Workers](../creating-workers/workers#connecting-to-the-engine).
</Note>

## Untrusted workers and access control

The default engine listener trusts anything that connects to it, which is fine for workers you run.
A worker you do not control, a browser client or a third party's worker, must not get that same
unrestricted access. For those, connect them through the `iii-worker-manager` worker, which exposes
a separate role-based access control (RBAC) listener:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker add iii-worker-manager
```

The RBAC listener runs an auth function you write on every connection to admit or reject it and to
decide which functions and trigger types that connection may use, so an untrusted worker only ever
sees the surface you grant it. Configuration, the auth and middleware function shapes, and the full
connection flow are documented on the
[iii-worker-manager worker page](https://workers.iii.dev/workers/iii-worker-manager).

## Managing workers

The `iii worker` CLI commands cover the full lifecycle of every worker in your project: finding new
ones in the registry, installing them into `config.yaml` and `iii.lock`, controlling their running
state, inspecting their logs, and removing them when they're no longer needed.

### Finding workers

We maintain a worker registry which you can explore at [workers.iii.dev](https://workers.iii.dev/).
The registry contains many workers that encapsulate common services. See
[Worker Registry](./workers-registry) for more information on the worker registry.

### Adding a worker

<Note>
  You need iii [installed](../install) and [running](./engine) before adding a worker. To spin up a
  temporary iii instance for testing, run `iii --use-default-config` (see [Default
  configuration](./engine#default-configuration)).
</Note>

Workers can be added to your iii instance from three different sources: the iii
[worker registry](./workers-registry), docker and OCI-compatible repositories, or locally developed
workers which you can learn more about in
[Creating Workers / Scaffold a new Worker](../creating-workers/workers#scaffold-a-new-worker).

`iii worker add <name>` installs a worker into your project:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker add iii-state # Downloads and adds a worker from iii registry
iii worker add ./workers/my_worker # Adds a local worker created with `iii worker init`
iii worker add ghcr.io/org/worker:tag # Pulls and adds a worker from a Docker or OCI image registry
```

The worker is added to `config.yaml` and started automatically. To force a redownload of an existing
worker, use `iii worker reinstall <name>` (equivalent to `add --force`).

<Note>
  `iii worker add` downloads worker images from remote repositories (the iii registry or an OCI
  registry) or from a local folder, then runs them in a microVM. A bare reference such as
  `caller-worker:latest` is looked up in those remote repositories; iii does not read images from
  your local Docker daemon, so an image you built locally with `docker build` is not found by name.
  A locally-built Docker image can be run and tested like any other Docker image (`docker run -it
      caller-worker:latest`).
</Note>

#### Pinning worker versions

Registry workers are published with semver versions. For how versions are picked, pinned with
`@<version>`, updated, and recorded in `iii.lock`, see [Versioning](./workers#versioning) and
[Updating a worker](./workers#updating-a-worker) on the Workers page.

### Listing workers

`iii worker list` shows every worker declared in your project's `config.yaml` along with its current
status. This is what you check to see the list of running and stopped workers:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker list
```

### Starting and stopping workers

Added workers start automatically with the engine. To control them manually, use the `start`,
`stop`, and `restart` commands:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker start <name>        # start one worker
iii worker stop -y <name>      # stop one worker (-y skips the confirmation prompt)
iii worker restart <name>      # stop then start
```

<Note>
  These commands manage workers that iii runs for you in its built-in virtualization. However iii
  does not have to run a worker. Any process that uses a iii SDK, calls `registerWorker()`, and
  connects to a iii instance is a worker. This will become more relevant when [creating
  workers](../creating-workers/workers) or [deploying a iii system](./deployment).
</Note>

<Note>
  To call functions inside running workers (directly with `worker.trigger` / `iii trigger`, or by
  binding them to events with optional condition gates), see [Triggers](./triggers).
</Note>

### Inspecting a worker

To check a specific worker's state, follow its logs, or run a command inside the worker's sandbox,
use:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker status <name>             # config, sandbox state, recent logs
iii worker logs <name>               # stream the worker's logs
iii worker exec <name> -- <command>  # run a command inside the worker
```

### Updating a worker

`iii worker update` re-resolves locked workers and writes the new pins back to `iii.lock`. Pass a
worker name to update one, or omit it to update every locked worker:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker update <worker-name>   # one worker
iii worker update                 # every locked worker
```

### Removing a worker

`iii worker remove` drops a worker from `config.yaml` and the engine tears down the running worker
process:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker remove -y <worker-name>   # -y skips the confirmation when the worker is running
```

Downloaded artifacts remain on disk after removal. To delete them too, use
`iii worker clear -y <worker-name>`. Omit the name to clear every worker's artifacts.

## Worker skills

Every worker also ships with skills for Agentic work. Skills are managed by the `skills` worker, an
actively developed content-registry worker added to a project like any other.

Skill bodies load lazily. Top-level entries stay small; agents fetch deeper content via
`iii://<worker>/<leaf>` section URIs only when a function reference resolves to one.

We ship high level skills as well which make it possible for any agent to make immediate use of iii
and its workers.

## Available functions and triggers

Functions and triggers come from connected workers. To use a trigger of a given type, you need the
worker that provides it to be connected. For example if you add `http` triggers via the iii-http
worker then you can now expose endpoints for your function as you would in a web framework like
Express or FastAPI.

## Versioning

iii workers follow semver. A project records the resolved version of every managed worker in
`iii.lock`, which makes installs reproducible across machines and platforms.

### Version pins

Installing without a version specifier picks the latest release. Append `@<version>` to a registry
name to pin a specific release rather than tracking the latest:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker add iii-state@1.2.0
```

The pin is recorded in `iii.lock` and replays on every subsequent install.

### The lockfile (iii.lock)

`iii.lock` is a YAML file at your project root. It pins each managed worker to a specific version
and source so the same worker set installs the same way across machines and platforms. Binary
workers can pin per-platform artifacts (macOS, Linux, Windows) in the same lockfile.

Commit `iii.lock` alongside `config.yaml` for reproducible installs. Two commands operate on the
lockfile directly:

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii worker sync            # install workers exactly from iii.lock
iii worker sync --frozen   # CI form: verify the lockfile without mutating local files
iii worker verify          # report drift between config.yaml and iii.lock
```

[`iii worker update`](#updating-a-worker) is the third lockfile-related command; it re-resolves pins
to the latest permitted versions and writes them back to `iii.lock`.

## Authoring workers

Creating a new worker, registering functions and triggers in worker code, and building or publishing
a worker image are out of scope for this page. See
[Creating Workers / Workers](../creating-workers/workers).
