41 lines
1.2 KiB
Markdown
41 lines
1.2 KiB
Markdown
|
# `/etc` via overlay filesystem {#sec-etc-overlay}
|
||
|
|
||
|
::: {.note}
|
||
|
This is experimental and requires a kernel version >= 6.6 because it uses
|
||
|
new overlay features and relies on the new mount API.
|
||
|
:::
|
||
|
|
||
|
Instead of using a custom perl script to activate `/etc`, you activate it via an
|
||
|
overlay filesystem:
|
||
|
|
||
|
```nix
|
||
|
{
|
||
|
system.etc.overlay.enable = true;
|
||
|
}
|
||
|
```
|
||
|
|
||
|
Using an overlay has two benefits:
|
||
|
|
||
|
1. it removes a dependency on perl
|
||
|
2. it makes activation faster (up to a few seconds)
|
||
|
|
||
|
By default, the `/etc` overlay is mounted writable (i.e. there is a writable
|
||
|
upper layer). However, you can also mount `/etc` immutably (i.e. read-only) by
|
||
|
setting:
|
||
|
|
||
|
```nix
|
||
|
{
|
||
|
system.etc.overlay.mutable = false;
|
||
|
}
|
||
|
```
|
||
|
|
||
|
The overlay is atomically replaced during system switch. However, files that
|
||
|
have been modified will NOT be overwritten. This is the biggest change compared
|
||
|
to the perl-based system.
|
||
|
|
||
|
If you manually make changes to `/etc` on your system and then switch to a new
|
||
|
configuration where `system.etc.overlay.mutable = false;`, you will not be able
|
||
|
to see the previously made changes in `/etc` anymore. However the changes are
|
||
|
not completely gone, they are still in the upperdir of the previous overlay in
|
||
|
`/.rw-etc/upper`.
|