From: Michael Orlitzky <mjo@gentoo.org>
To: gentoo-dev@lists.gentoo.org
Subject: Re: [gentoo-dev] [PATCH] acct-user.eclass: don't modify existing user by default
Date: Mon, 4 Jan 2021 10:24:23 -0500 [thread overview]
Message-ID: <a616119d-a94b-997f-48c9-7bfde108cd20@gentoo.org> (raw)
In-Reply-To: <cf400822-eba4-aa95-63ef-5f6f857f75b1@gentoo.org>
On 1/4/21 9:46 AM, Thomas Deutschmann wrote:
>
>> So the main problem I see with doing this is that it becomes
>> impossible to reliably make changes to a user in later ebuild
>> revisions.
>
> He is obviously looking for a way to allow maintainers to change users
> afterwards. But if we tell people, "If you need customization, fork the
> user/group ebuild in your overlay" we will disconnect these users from
> future changes.
There's pretty much no reason to change a user's settings unless you've
completely fucked them up the first time around. This is precisely why
the original GLEP had mailing list reviews.
If a package depends on a user having e.g. a specific home directory so
that upgrading the package requires a corresponding revision bump of the
user, then the package is broken. I tried really hard to document this,
and to enforce it back when we had mailing list reviews. It's all in the
devmanual now.
> ...
> When you will get LPIC certification one can expect that you have some
> basic knowledge in Linux stuff allowing you to do common tasks on all
> different Linux systems. Now there comes Gentoo where you aren't allowed
> to use standard Linux tools like 'usermod' when deploying another
> service if you don't want to risk that your service will go down when
> following best practice and do regular world upgrades. Really?
You also can't use the standard linux tools to edit scripts in /usr/bin
without your changes being overwritten. This is no different... some
things need to belong to the package manager if you want package
management to work.
> 3) More important, the idea of forking acct-* packages whenever you need
> to make modifications don't scale. Like I already outlined in February
> 2020, you cannot create overlays for each different user configuration:
>
> I.e. using memcached/redis: You grant permission to socket via group. So
> you put other services belonging to that application you are deploying
> into your user running the key value store. Do you really expect that
> one would create multiple overlays per application using one of these
> services? How would you maintain hundreds of overlays? How would you
> keep track that each box will use the correct overlay to get the
> specific customized acct-* package? How do you deal with scenarios where
> you don't just deploy single instances?
This is literally the example I gave. Our acct-user ebuilds can be added
to additional groups based on USE flags. Every server uses the same
overlay/ebuilds, but different machines get different package.use files,
pushed out by the configuration management tool.
I understand that creating an overlay with acct-user overrides will not
be for everyone, so I have no problem with adding an escape hatch. I do
think it should be off by default though, and that missing future
::gentoo changes will not be a problem unless some other error has been
committed first.
next prev parent reply other threads:[~2021-01-04 15:24 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-04 1:35 [gentoo-dev] [PATCH] acct-user.eclass: don't modify existing user by default Thomas Deutschmann
2021-01-04 2:41 ` Mike Gilbert
2021-01-04 3:17 ` Alec Warner
2021-01-04 3:18 ` Michael Orlitzky
2021-01-04 14:46 ` Thomas Deutschmann
2021-01-04 15:24 ` Michael Orlitzky [this message]
2021-01-04 15:55 ` David Seifert
2021-01-04 16:18 ` Thomas Deutschmann
2021-01-04 16:28 ` Michał Górny
2021-01-04 16:30 ` Thomas Deutschmann
2021-01-04 16:34 ` Thomas Deutschmann
2021-01-04 16:38 ` Michał Górny
2021-01-04 16:50 ` Thomas Deutschmann
2021-01-04 16:56 ` Michał Górny
2021-01-04 16:56 ` Mike Gilbert
2021-01-04 16:54 ` Mike Gilbert
2021-01-04 7:32 ` Robin H. Johnson
2021-01-04 16:45 ` [gentoo-dev] " James Cloos
2021-01-04 18:07 ` Michael Orlitzky
2021-01-04 18:20 ` Michał Górny
2021-01-04 18:38 ` Michael Orlitzky
2021-01-04 18:23 ` Thomas Deutschmann
2021-01-04 18:27 ` Michael Orlitzky
2021-01-04 18:32 ` Thomas Deutschmann
2021-01-04 9:23 ` [gentoo-dev] " Michał Górny
2021-01-04 14:05 ` Thomas Deutschmann
2021-01-04 16:10 ` Mike Gilbert
2021-01-04 16:14 ` Michał Górny
2021-01-04 16:20 ` Thomas Deutschmann
2021-01-08 18:11 ` Fabian Groffen
2021-01-08 18:14 ` Michał Górny
2021-01-08 18:23 ` Thomas Deutschmann
2021-01-08 18:32 ` Michał Górny
2021-01-08 15:48 ` Thomas Deutschmann
2021-01-08 16:03 ` Mike Gilbert
2021-01-08 16:29 ` Thomas Deutschmann
2021-01-08 16:50 ` Mike Gilbert
2021-01-08 17:06 ` Mike Gilbert
2021-01-08 18:10 ` Thomas Deutschmann
2021-01-08 18:31 ` Michał Górny
2021-01-08 19:15 ` Mike Gilbert
2021-01-08 17:16 ` Michał Górny
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=a616119d-a94b-997f-48c9-7bfde108cd20@gentoo.org \
--to=mjo@gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox