From: Alexey Gladkov <legion@altlinux.ru>
To: ALT Linux Team development discussions <devel@lists.altlinux.org>
Subject: Re: [devel] I: sysvinit vs systemd
Date: Wed, 22 Dec 2021 12:01:06 +0100
Message-ID: <20211222110106.lefwkop4rpeimr7q@example.org> (raw)
In-Reply-To: <1aa23f9d-04ad-c558-d9e4-a294e737fd31@ya.ru>
On Wed, Dec 22, 2021 at 11:33:12AM +0700, Антон Мидюков wrote:
> 22.12.2021 03:06, Leonid Krivoshein пишет:
> >
> > 21.12.2021 22:32, Антон Мидюков пишет:
> >> 17.12.2021 19:07, Alexey Gladkov пишет:
> >>> Привет!
> >>>
> >>> В виду нарастающей несовместимости между системами с sysvinit и systemd.
> >>> В sysvinit была добавлена явный конфликт на systemd. Технически они не
> >>> конфликтуют, но без него в системы с sysvinit иногда попадает systemd и
> >>> это приводит к серьёзным проблемам.
> >> Проблема скорее в том, что в hasher попадает sysvinit. А попадает он туда
> >> через треугольник systemd-utils-standalone - startup - systemd-sysctl-common.
> >> Эти пакеты вытягивают друг друга и sysvinit.
> >> startup тянется другими пакетами из-за конфигов, которые в нём.
> >> Можете попробовать установить в только что инициализированный hasher.
> >> А вот как они вытягивают sysvinit, я что-то не пойму. Наверное, это startup.
> >
> > От startup раньше зависел interactive-basesystem, теперь нет. Но раз его убрали из зависимостей, кому-то это могло что-то поломать, так что с марта 2021 startup могли добавить куда-то ещё.
> >
> > А можешь показать cat /etc/apt/pkgpriorities ? Этот файл ведь не установщик может создавать, его могли бы определять конфликтующие иниты, каждый по-своему. Потому что многие инитные зависимости виртуальные, и при обновлении начинается качание весов. Можно оставить его в apt-conf-branch для всех решений, а для пользователей sysvinit переместить в инитный пакет.
> >
>
> Да уже разобрался. startup через зависимость /sbin/halt вытягивает либо sysvinit, либо systemd-sysvinit.
> Исправив startup, починим сборку пакетов.
Насколько я понимаю startup не нужен на системах с systemd. Об этом уже
писал shaba@. Пакет startup нужен только на системах с sysvinit.
Конфликт в sysvinit выявил скрытую проблему:
https://git.altlinux.org/tasks/292438/logs/events.1.1.log
сейчас у нас systemd сам вытягивает startup
Building Dependency Tree...
MI2a: mark libnss-mymachines
MI2a: target systemd-container
MI2a: mark systemd-container
MI2a: target systemd
MI2a: mark systemd
MI2a: target /etc/modules
MI2a: mark startup
^^^^^^^^^^^^^^
MI2a: target libnss-systemd
MI2a: mark libnss-systemd
MI2a: target systemd-boot-efi
MI2a: mark systemd-boot-efi
MI2a: target systemd-sysctl-common
MI2a: mark systemd-sysctl-common
$ rpmquery -pR files/x86_64/RPMS/systemd-249.7-alt5.x86_64.rpm | grep /etc/modules
/etc/modules
$ apt-cache showpkg /etc/modules
Package: /etc/modules
Versions:
Reverse Depends:
systemd,/etc/modules
Dependencies:
Provides:
Reverse Provides:
startup 0.9.9.13-alt1:sisyphus+284270.100.1.1@1630416269
В свою очередь startup хочет утилиты halt, initlog, reboot, shutdown,
telinit. Их предоставляет либо sysvinit, либо systemd-sysvinit.
$ rpm -e --test systemd-sysvinit
error: Failed dependencies:
/sbin/halt is needed by (installed) startup-0.9.9.13-alt1.noarch
/sbin/reboot is needed by (installed) startup-0.9.9.13-alt1.noarch
/sbin/shutdown is needed by (installed) startup-0.9.9.13-alt1.noarch
/sbin/telinit is needed by (installed) startup-0.9.9.13-alt1.noarch
С одной стороны если systemd втащит внутрь systemd-sysvinit, то это
спрячет проблему и sysvinit перестанет появляться в окружении с systemd.
Но это плохое решение.
Другим решением будет доделать перенос легаси конфигов в отдельные пакеты.
Дима предложил порядок действий:
+ В startup ссылки /etc/modules и /etc/sysctl.conf заменяются на
зависимости.
+ Из systemd ссылка /etc/modules-load.d/modules.conf заменяется на
зависимость.
+ В systemd-sysctl-common ссылка /etc/sysctl.d/99-sysctl.conf заменяется
на файл и добавляется ссылка /etc/sysctl.conf.
+ В новом systemd-modules-common добавляется файл
/etc/modules-load.d/modules.conf и ссылка /etc/modules на него.
+ В обоих -common добавляются %pre, которые перемещают заменяемые файлы на
новые места.
После этого startup перестанет появляться на системах с systemd и
вытягивать ненужные зависимости.
--
Rgrds, legion
next prev parent reply other threads:[~2021-12-22 11:01 UTC|newest]
Thread overview: 60+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-12-17 12:07 Alexey Gladkov
2021-12-17 12:09 ` Dmitry V. Levin
2021-12-21 17:25 ` Alexey Shabalin
2021-12-21 17:28 ` Антон Мидюков
2021-12-21 17:54 ` Sergey Y. Afonin
2021-12-22 4:00 ` Антон Мидюков
2021-12-17 12:12 ` Dmitry V. Levin
2021-12-17 12:38 ` Sergey V Turchin
2021-12-17 12:43 ` Alexey Gladkov
2021-12-17 12:56 ` Sergey V Turchin
2021-12-17 12:57 ` Anton Farygin
2021-12-17 14:41 ` Sergey V Turchin
2021-12-17 13:07 ` [devel] rpm-macro systemctl --user (was: sysvinit vs systemd) Sergey V Turchin
2021-12-17 13:22 ` Dmitry V. Levin
2021-12-17 13:35 ` Sergey V Turchin
2021-12-17 18:52 ` Dmitry V. Levin
2021-12-17 20:14 ` Alexey V. Vissarionov
2021-12-18 0:15 ` Sergey V Turchin
2021-12-18 13:22 ` Sergey V Turchin
2021-12-18 18:07 ` Alexey V. Vissarionov
2021-12-18 19:35 ` Sergey V Turchin
2021-12-18 0:06 ` Sergey V Turchin
2021-12-20 8:29 ` [devel] I: sysvinit vs systemd Stanislav Levin
2021-12-20 8:39 ` Andrey Savchenko
2021-12-20 8:48 ` Stanislav Levin
2021-12-20 10:00 ` Andrey Savchenko
2021-12-20 15:25 ` [devel] всё как в апстрме Dmitry V. Levin
2021-12-20 16:16 ` Anton Farygin
2021-12-20 16:35 ` Dmitry V. Levin
2021-12-21 12:45 ` [devel] I: sysvinit vs systemd Paul Wolneykien
2021-12-21 12:46 ` Paul Wolneykien
2021-12-21 12:47 ` Anton Farygin
2021-12-21 19:32 ` Антон Мидюков
2021-12-21 20:06 ` Leonid Krivoshein
2021-12-21 20:15 ` Leonid Krivoshein
2021-12-22 4:33 ` Антон Мидюков
2021-12-22 10:14 ` Sergey V Turchin
2021-12-22 10:37 ` Антон Мидюков
2021-12-22 11:00 ` Sergey V Turchin
2021-12-22 12:30 ` Alexey V. Vissarionov
2021-12-22 12:43 ` Sergey V Turchin
2021-12-22 11:01 ` Alexey Gladkov [this message]
2021-12-23 14:20 ` Dmitry V. Levin
2021-12-23 15:53 ` Alexey Shabalin
2021-12-23 23:26 ` Alexey Gladkov
2021-12-23 23:36 ` Dmitry V. Levin
2021-12-24 0:00 ` Dmitry V. Levin
2021-12-24 0:30 ` Dmitry V. Levin
2021-12-24 17:50 ` Alexey Shabalin
2021-12-24 18:04 ` Dmitry V. Levin
2021-12-25 13:35 ` Dmitry V. Levin
2021-12-24 15:07 ` Alexey Shabalin
2021-12-24 15:32 ` Dmitry V. Levin
2021-12-24 17:28 ` Alexey Shabalin
2021-12-24 17:55 ` Dmitry V. Levin
2021-12-26 8:02 ` Alexey V. Vissarionov
2021-12-23 15:59 ` Anton Farygin
2021-12-23 20:19 ` Dmitry V. Levin
2021-12-23 14:03 ` Sergey V Turchin
2021-12-23 14:15 ` Sergey V Turchin
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=20211222110106.lefwkop4rpeimr7q@example.org \
--to=legion@altlinux.ru \
--cc=devel@lists.altlinux.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
ALT Linux Team development discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
public-inbox-index devel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git