[devel] обновления пакетов с поддержкой systemd
Alexey Shabalin
a.shabalin на gmail.com
Сб Май 21 12:42:31 UTC 2011
>> >>> Надо запустить что-то типа
>> >>> if chkconfig foobar ; then
>> >>> chkconfig foobar on
>> >>> fi
>> >>> (если сервис включен, включить его ещё раз - в этот раз уже с
>> >>> перенаправлением на systemd)
>> >> [...]
>> >>> Я пока придумал только модифицировать post_service:
>> >>>
>> >>> --- post_service.def 2011-03-17 01:41:42.000000000 +0300
>> >>> +++ post_service 2011-05-17 07:02:27.640147135 +0400
>> >> [...]
>> >>> @@ -14,5 +30,9 @@
>> >>> /sbin/chkconfig --add "$1"
>> >>> else
>> >>> /sbin/chkconfig "$1" resetpriorities ||:
>> >>> + [ -f "$SYSTEMD_SERVICE_DIR/$1.service" ] &&
>> >>> + systemd_is_active &&
>> >>> + /sbin/chkconfig --no-redirect "$1" &&
>> >>> + /sbin/chkconfig "$1" on
>> >>> /sbin/service "$1" condrestart ||:
>> >>> fi
>> >>
>> >> Я бы предпочел, чтобы либо chkconfig resetpriorities выполнял эту
>> >> синхронизацию, либо появился еще один режим в chkconfig для синхронизации.
>> >> Вариант с resetpriorities предпочтительнее, поскольку тогда не придется
>> >> трогать пользователей chkconfig'а.
>> >
>> > Боюсь, что я этого не осилю. Максимум, что могу - сделать всегда
>> > включение сервиса при resetpriorities :)
>>
>> В общем у меня получилось следущее:
>>
>> return setService(name, type, where, 0);
>> } else if (!strcmp(state, "reset"))
>> return setService(name, type, where, -1);
>> - else if (!strcmp(state, "resetpriorities"))
>> + else if (!strcmp(state, "resetpriorities")) {
>> + if (!noRedirectItem && isOn(name, level)) {
>> + forwardSystemd(name, type, "enable");
>> + }
>> return setService(name, type, where, -2);
>> + }
>> else
>> usage(EXIT_FAILURE);
>> }
>>
>> Если используется systemd и если раньше сервис был включён, то при
>> запуске с resetpriorities ещё запускается systemctl enable для
>> сервиса.
>> Так устроит?
>
> Судя по описанию, да.
>
> P.S. код я не смотрел.
Чёрт, с этим исправлением возникает другая проблема.
В ALTLinux много имён init-скриптов не соответствуют названиям из upstream.
Например udev -> udevd, bluetooth -> bluetoothd.service и т.п.
(добавляется d в конце имени).
Для работы с systemd на такие имена сделаны симлинки
# ls -l /lib/systemd/system/udevd.service
lrwxrwxrwx 1 root root 12 Май 21 17:39
/lib/systemd/system/udevd.service -> udev.service
[root на shabalin-nb ~]# ls -l /lib/systemd/system/bluetoothd.service
lrwxrwxrwx 1 root root 17 Май 21 17:39
/lib/systemd/system/bluetoothd.service -> bluetooth.service
Это работает для start|stop (systemctl start|stop foo.service или
service foo start|stop ),
но не работает для enable|disable ( systemctk enable|disable
foo.service или chkconfig foo enable|disable)
Ругается что это symlink и хочет правильное имя.
Как это объезжать?
- привести имена init-скриптов к апстримному виду
- привести имена .service файлов к ALTLinux виду
- научить systemd делать enable|disable для симлинков (а симлинк может
быть и на /dev/null - для systemd это нормальный способ выключить или
замаскировать сервис).
--
Alexey Shabalin
Подробная информация о списке рассылки Devel