Systemd/User Services/ru: Difference between revisions

Unabomberlive (talk | contribs)
Created page with "<syntaxhighlight lang="nix"> systemd.user.services.my-cool-user-service = { enable = true; after = [ "network.target" ]; wantedBy = [ "default.target" ]; description = "Мой Классный Пользовательский Сервис"; serviceConfig = { Type = "simple"; ExecStart = ''/my/cool/user/service''; }; }; </syntaxhighlight>"
FuzzyBot (talk | contribs)
Updating to match new version of source page
 
(10 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<div lang="en" dir="ltr" class="mw-content-ltr">
{{Systemd/breadcrumb}}
Systemd supports running a separate instance of systemd for a given user, allowing the user to control their own services. See here for more information: https://wiki.archlinux.org/title/Systemd/User
 
</div>
Systemd поддерживает запуск отдельного экземпляра systemd для конкретного пользователя, позволяя ему управлять своими собственными службами.
<div lang="en" dir="ltr" class="mw-content-ltr">
 
In NixOS, a user service can be expressed with {{ic|systemd.user.services.<name>}}, as documented here: https://search.nixos.org/options?query=systemd.user.services
В NixOS пользовательский сервис может быть выражен с помощью {{ic|systemd.user.services.<name>}}, как описано здесь: https://search.nixos.org/options?query=systemd.user.services.
</div>
 
<div lang="en" dir="ltr" class="mw-content-ltr">
Это может быть полезно, если вы хотите, чтобы пользователь мог запускать, останавливать и перезапускать свой собственный экземпляр службы без необходимости делать его sudoer.
This may be useful if you want a user to be able to start, stop, and restart their own instance of a service without needing to make the user a sudoer.
 
</div>
Пример сервиса:
<div lang="en" dir="ltr" class="mw-content-ltr">
 
Here is an example:
</div>
<syntaxhighlight lang="nix">
<syntaxhighlight lang="nix">
systemd.user.services.my-cool-user-service = {
systemd.user.services.my-cool-user-service = {
Line 16: Line 14:
   after = [ "network.target" ];
   after = [ "network.target" ];
   wantedBy = [ "default.target" ];
   wantedBy = [ "default.target" ];
   description = "Мой Классный Пользовательский Сервис";
   description = "My Cool User Service";
   serviceConfig = {
   serviceConfig = {
       Type = "simple";
       Type = "simple";
Line 23: Line 21:
};
};
</syntaxhighlight>
</syntaxhighlight>
По умолчанию пользовательские сервисы будут остановлены, когда пользователь выйдет из системы, и запустятся снова, когда пользователь снова войдет в систему, благодаря тому, что мы установили {{ic|<nowiki>wantedBy = ["default.target" ]</nowiki>}} в примере.
<span id="Keeping_user_services_running_after_logout"></span>
== Продолжение работы пользовательских служб после выхода из системы ==
Если вам нужно, чтобы пользовательский сервис продолжал работать после выхода пользователя из системы, вам нужно включить "[https://search.nixos.org/options?channel=unstable&show=users.users.%3Cname%3E.linger&from=0&size=50&sort=relevance&type=packages&query=users.users.%3Cname%3E.linger lingering]", установив {{ic|<nowiki>users.users.<username>.linger = true;</nowiki>}}.
Вы также, вероятно, захотите изменить {{ic|<nowiki>wantedBy = ["multi-user.target" ];</nowiki>}}, чтобы служба запускалась во время загрузки.
<div lang="en" dir="ltr" class="mw-content-ltr">
== Enabling a service for specific users ==
</div>
<div lang="en" dir="ltr" class="mw-content-ltr">
By default, enabling a user service enables it for every user for which systemd spawns a service manager. If you wish for the service to be run only for specific users (say, {{ic|<nowiki>UserA</nowiki>}} and {{ic|<nowiki>UserB</nowiki>}}), use {{ic|<nowiki>ConditionUser</nowiki>}} ({{ic|<nowiki>man 5 systemd.unit</nowiki>}}):
</div>
<syntaxhighlight lang="nix">
systemd.user.services.my-cool-user-service = {
  unitConfig.ConditionUser = "UserA|UserB";
};
</syntaxhighlight>
<div lang="en" dir="ltr" class="mw-content-ltr">
Likewise, you can also disable a service for a specific user:
</div>
<syntaxhighlight lang="nix">
systemd.user.services.my-cool-user-service = {
  unitConfig.ConditionUser = "!root";
};
</syntaxhighlight>
<div lang="en" dir="ltr" class="mw-content-ltr">
<div lang="en" dir="ltr" class="mw-content-ltr">
By default, user services will be stopped when the user logs out and will start again when the user logs back in due to us setting {{ic|<nowiki>wantedBy = [ "default.target" ]</nowiki>}} in the example.
== Usage ==
</div>
</div>
<div lang="en" dir="ltr" class="mw-content-ltr">
<div lang="en" dir="ltr" class="mw-content-ltr">
== Keeping user services running after logout ==
To interact with user-specific systemd services, use the <code>--user</code> flag with the <code>systemctl</code> command. For example, to check the status of a user service:
</div>
</div>
<syntaxhighlight lang="console"> $ systemctl --user status my-cool-user-service </syntaxhighlight>
<div lang="en" dir="ltr" class="mw-content-ltr">
<div lang="en" dir="ltr" class="mw-content-ltr">
If you need a user service to stay running after a user logs out, you need to enable "[https://search.nixos.org/options?channel=unstable&show=users.users.%3Cname%3E.linger&from=0&size=50&sort=relevance&type=packages&query=users.users.%3Cname%3E.linger lingering]" by setting {{ic|<nowiki>users.users.<username>.linger = true;</nowiki>}}
To view logs for a specific user service, use <code>journalctl</code> with the <code>--user-unit</code> option:
</div>
</div>
<syntaxhighlight lang="console"> $ journalctl --user-unit my-cool-user-service </syntaxhighlight>
<div lang="en" dir="ltr" class="mw-content-ltr">
<div lang="en" dir="ltr" class="mw-content-ltr">
You'll also likely want to change to {{ic|<nowiki>wantedBy = [ "multi-user.target" ];</nowiki>}} so the service starts at boot time.
To list all active user units:
</div>
</div>
<syntaxhighlight lang="console"> $ systemctl --user list-units </syntaxhighlight>
<div lang="en" dir="ltr" class="mw-content-ltr">
[[Category:systemd]]
[[Category:systemd]]
</div>