-
-
Notifications
You must be signed in to change notification settings - Fork 3.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
meson: introduce a build option for customizing the install paths of … #29244
meson: introduce a build option for customizing the install paths of … #29244
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The patch doesn't contain much justification, so here is my understanding of why this is useful:
Currently we install "empty" config files in /etc/systemd/
. They serve two purposes:
- the file contains commented-out values that show the default settings
- it is easier to edit the right file if it is already there, the user doesn't have to type in the path correctly, and the basic file structure is already in place so it's easier to edit.
Things that have happened since this approach was put in place:
- we support loading of the main config file from
/usr
and/usr/local
, in addition to/etc
and/run
(or maybe this way always true, maybe we just spruced up the docs), so the actual location of the config file varies. - we started supporting drop-ins for config files, and drop-ins are the recommended way to create local configuration overrides.
- we have
systemd-analyze cat-config
- because of the first two points,
systemd-analyze cat-config
is much better, because it takes care of finding all the drop-ins and figuring out the precedence. Looking at files manually is still possible of course, but not very convenient. - we have
systemctl edit
so the user does not have to specify any file/drop-in name. systemctl edit
shows the (commented out) contents of the existing config, so when a user edits an empty drop-in, they get the correct hints about syntax/option names.
The disadvantages of the current approach with "empty" files in /etc
:
- we clutter up
/etc
so it's harder to see what the local configuration actually is. - if a user edits the file, package updates will not override the file (e.g. systemd.rpm uses
%config(noreplace)
. This means that the "documented defaults" will become stale over time, if the user ever edits the main config file.
Thus, I think that it's reasonable to:
- install the main config file to
/usr/lib
so that it serves as reference for syntax and option names and default values and is properly updated on package upgrades - recommend to users to always use drop-ins for configuration and
systemd-analyze cat-config
to view the documentation.
EDIT: cross out the mention of systemctl edit
as discussed below. We haven't implemented that yet for config files.
With
So this patch seems to behave as expected. |
Makes sense to me - @fbuihuu could you please add the above in the commit message so that it's recorded? |
Thanks for writing this up.
I'm a bit confused here since AFAIK With such command and maybe a way to show the defaults ( |
Indeed. This seems more graceful to me. |
Indeed it's the recommended way because (IMU) using drop-ins exclusively is the only way for packages shipped by downstream to safely customize the defaults without risking to override users' customization. That is the reason why we want to get rid of the main config files (even if they're "empty) and use drop-ins exclusively. |
Imho, if it's all commented out anyway (aka, systemd doesn't derive it's defaults from any files but has them built in) it should really go into |
Because when we change defaults downstream it's very easy to just patch that file and uncomment the line, and then it will automatically work as expected |
until a user creates his own /etc/systemd/xxx.conf (regardless of which setting is overriden). |
But those are two different things. Downstream ought to have a analog to In fact, I propose to get rid of these. The file formats aren't some NIH syndrome format like pipewire is using, so you don't need some giant default config dump so that users can get an idea of how it works. And all the options and their possible values and defaults are clearly documented in their respective manpages, which are also linked from the exe manpage that consumes them. These example configs are just some half-assed cargo cult bs that should stop (especially when dropped into /etc). Iff they contain anything important it should probably be moved into their respective manpage. |
This was a bit of a mental shortcut. We have
I'm not sure. The nice thing about the current approach is that without it works uniformly, without any special functionality. In particular, the distro may provide packaged drop-ins, under /usr/lib/, and those will be automatically and correctly shown. It may also override something in the main config file, and then again, this will be automatically and correctly shown by |
Given that the templates might be located in different directories (/etc vs /usr) or even not shipped at all, having a uniform way to retrieve the defaults for all cases sounds appealing to me. We could even extend
|
See #29553. |
503a464
to
e37e657
Compare
I force-pushed the commit with an updated commit message. |
This would resolve #18420. |
Yes indeed, I wasn't aware that someone already asked for moving the templates in /usr. |
e37e657
to
7fe6301
Compare
This allows distros to install configuration file templates in /usr/lib/systemd for example. Currently we install "empty" config files in /etc/systemd/. They serve two purposes: - The file contains commented-out values that show the default settings. - It is easier to edit the right file if it is already there, the user doesn't have to type in the path correctly, and the basic file structure is already in place so it's easier to edit. Things that have happened since this approach was put in place: - We started supporting drop-ins for config files, and drop-ins are the recommended way to create local configuration overrides. - We have systemd-analyze cat-config which takes care of iterating over all possible locations (/etc, /run, /usr, /usr/local) and figuring out the right file. - Because of the first two points, systemd-analyze cat-config is much better, because it takes care of finding all the drop-ins and figuring out the precedence. Looking at files manually is still possible of course, but not very convenient. The disadvantages of the current approach with "empty" files in /etc: - We clutter up /etc so it's harder to see what the local configuration actually is. - If a user edits the file, package updates will not override the file (e.g. systemd.rpm uses %config(noreplace). This means that the "documented defaults" will become stale over time, if the user ever edits the main config file. Thus, I think that it's reasonable to: - Install the main config file to /usr/lib so that it serves as reference for syntax and option names and default values and is properly updated on package upgrades. - Recommend to users to always use drop-ins for configuration and systemd-analyze cat-config to view the documentation. This setting makes this change opt-in. Fixes systemd#18420. [zjs: add more text to the description]
7fe6301
to
a5cab7b
Compare
We discussed this today during a live meeting and the conclusion was to merge this. |
…the main config files
This allows distros to install configuration file templates in /usr/lib/systemd for example.