mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-30 08:44:31 +00:00
nixos/etc: add manual section
This commit is contained in:
parent
60f529fc82
commit
dbd8cb9d46
36
nixos/doc/manual/development/etc-overlay.section.md
Normal file
36
nixos/doc/manual/development/etc-overlay.section.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
# `/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`.
|
@ -56,4 +56,5 @@ explained in the next sections.
|
|||||||
unit-handling.section.md
|
unit-handling.section.md
|
||||||
activation-script.section.md
|
activation-script.section.md
|
||||||
non-switchable-systems.section.md
|
non-switchable-systems.section.md
|
||||||
|
etc-overlay.section.md
|
||||||
```
|
```
|
||||||
|
Loading…
Reference in New Issue
Block a user