nixos/etc: add manual section

nikstur dbd8cb9d 60f529fc

Changed files
+37
nixos
+36
nixos/doc/manual/development/etc-overlay.section.md
···
+
# `/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`.
+1
nixos/doc/manual/development/what-happens-during-a-system-switch.chapter.md
···
unit-handling.section.md
activation-script.section.md
non-switchable-systems.section.md
+
etc-overlay.section.md
```