> ## 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.

# Engine

> Configuring and running the iii engine.

## The engine is just a router

Think of the engine like a router, it receives requests, routes them to workers, and routes responses back as needed.

## Engine configuration

The iii engine starts from a `config.yaml` file at your project root. Pass `--config <path>` to
point at a different file, or `--use-default-config` to start with a default set of workers (handy
for first-run and scratch work).

```bash theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
iii --config config.yaml
```

## Configuration file structure

`config.yaml` has a single top-level key, `workers:`, that lists the workers the engine should load.
Each entry has a `name` (a registry slug or local worker name) and a `config` block whose shape is
defined by that worker.

```yaml theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
workers:
  - name: iii-http
    config:
      port: 3111
      host: 127.0.0.1

  - name: iii-state
    config:
      adapter:
        name: kv
        config:
          store_method: file_based
          file_path: ./data/state_store.db
```

Per-worker config schemas live on each worker's Worker Docs page. See
[Worker Registry](./workers-registry) for where to find a worker's config reference.

<Note>
  The engine reads `config.yaml` and launches the worker installations on disk; it does not read
  `iii.lock`. The lockfile is a worker-installation concern, written and consumed by `iii worker
      sync` / `update` / `verify` to make installs reproducible. See [Workers / The lockfile
  (iii.lock)](./workers#the-lockfile-iii-lock) for the full story.
</Note>

<Note>
  Workers do not need to be running alongside iii; configuring them in config.yaml is a convenience. A worker
  can be deployed anywhere and only needs a connection string to the iii instance. See
  [Creating Workers / Connecting to the engine](../creating-workers/workers#connecting-to-the-engine) for more information.
</Note>

## Environment variable expansion

Values in `config.yaml` support `${VAR:default}` syntax. The expansion uses the value of the
environment variable `VAR`, falling back to `default` when the variable is not set. Use this to swap
ports, URLs, and feature flags per environment without forking the config file.

```yaml theme={"theme":{"light":"catppuccin-latte","dark":"dark-plus"}}
workers:
  - name: iii-http
    config:
      port: ${HTTP_PORT:3111}
      host: ${HTTP_HOST:127.0.0.1}
```

## Default configuration

Run `iii --use-default-config` to start the engine with a default set of workers without writing a
`config.yaml`. Useful for first-run and scratch work. Once you need to customize ports, adapters, or
the set of workers, switch to a real `config.yaml`.
