Skip to content

Commit

Permalink
Merge pull request #668 from jlebon/pr/state-overlays
Browse files Browse the repository at this point in the history
docs/filesystem: document state overlays
  • Loading branch information
cgwalters authored Jul 8, 2024
2 parents 94521ec + 3949ffc commit a13263b
Showing 1 changed file with 23 additions and 3 deletions.
26 changes: 23 additions & 3 deletions docs/src/filesystem.md
Original file line number Diff line number Diff line change
Expand Up @@ -136,15 +136,35 @@ a subdirectory of `/opt` such as `/opt/examplepkg`.
See [building images](building/guidance.md) for recommendations on how to build
container images and adjust the filesystem for cases like this.

However, for some use cases, it may be easier to allow some level of mutability.
There are two options for this, each with separate trade-offs: transient roots
and state overlays.

#### Enabling transient root

However, some use cases may find it easier to enable a fully transient writable rootfs by default.
This feature enables a fully transient writable rootfs by default.
To do this, set the

```toml
[root]
transient = true
```

option in `prepare-root.conf`. In particular this will allow software to write (transiently) to `/opt`,
with symlinks to `/var` for content that should persist.
option in `prepare-root.conf`. In particular this will allow software to
write (transiently, i.e. until the next reboot) to all top-level directories,
including `/usr` and `/opt`, with symlinks to `/var` for content that should
persist.

#### Enabling state overlays

This feature enables a writable overlay on top of `/opt` (or really, any
toplevel or subdirectory baked into the image that is normally read-only).
Changes persist across reboots but during updates, new files from the container
image override any locally modified version. All other files persist.

To enable this feature, simply instantiate the `[email protected]`
unit template on the target path. For example, for `/opt`:

```
RUN systemctl enable [email protected]
```

0 comments on commit a13263b

Please sign in to comment.