NixOs: Dienste auf Nicht-Nixos-Betriebssystemen nutzen, ggf. nur mit Benutzerrechten

NixOs: Dienste auf Nicht-Nixos-Betriebssystemen nutzen, ggf. nur mit Benutzerrechten

Ich möchte wissen, wie man einen beschriebenen Dienst ausführt, z. B. in einem Modul auf einem Nicht-Nix-Betriebssystem. Nehmen wir beispielsweise an, ich habe die Datei:

{config, pkgs, ... }:
{
  systemd.user.services.mytestservice = {
    description = "Mytestservice";
    script = "while true; do echo 'YES'; sleep 1; done";
    wantedBy = [ "default.target" ];
 };
}

(oder eventuell ohne den Benutzer: systemd.services.mytestservice =)

Wie kann ich es kompilieren und auf einem Nicht-Nixos-Betriebssystem ausführen, ggf. auch von Nicht-Root-Benutzern?

Antwort1

Danksagung: Vielen Dank cleverfür alle Erklärungen!

Schreiben wir zunächst die Konfigurationsdatei in myconfiguration.nix:

{config, pkgs, ... }:

{
  # You can actually remove the user, and still use it
  # as a user if you link it in ~/.config/systemd/user/
  # (do not forget to remove the `user` it in anything.nix
  # as well)
  systemd.user.services.mytestservice = {
   description = "Mytestservice";
   script = "while true; do echo 'YES'; sleep 1; done";
   # Or:
   # serviceConfig = {
   #   ExecStart = "${pkgs.bash}/bin/bash -c \"while true; do echo 'YES'; sleep 1; done\"";
   # };
   wantedBy = [ "default.target" ];
 };
}

Dann können Sie verschiedene Dinge tun:

  • kompilieren
  • es installieren

Um nur zu kompilieren, können Sie Folgendes tun:

nix-build '<nixpkgs/nixos>' -I nixos-config=myconfiguration.nix -A 'config.systemd.user.units."mytestservice.service".unit'

Die Idee ist, dass dies die Datei default.nixin den Ordner lädt /your/nixpkgs/copy/nixos/(um den Pfad zu erhalten nixpkgs, überprüft es die Variable NIX_PATH, die mehrere "Unterschlüssel" wie : enthält NIX_PATH=nixpkgs=/your/nixpkgs/copy/:othervar=thepath), die online verfügbar istHier. Diese Datei erfordert auch <nixos-config>, damit wir der Umgebungsvariable -Ieinen Nixos-Konfigurationseintrag hinzufügen können. Ohne wird dann versucht, ein vollständiges Nixos zu erstellen, also geben wir einfach an, dass wir nur diese Serviceeinheit möchten.NIX_PATH-A

Dadurch wird eine Datei erstellt mytestservice.service, die wie folgt aussieht:

$ cat result/mytestservice.service 
[Unit]
Description=Mytestservice

[Service]
Environment="LOCALE_ARCHIVE=/nix/store/zzhablipzgpv8mvlcvagqjnham6lr944-glibc-locales-2.27/lib/locale/locale-archive"
Environment="PATH=/nix/store/bv1lw6a2kw0mn2y3lxhi43180idx6sp9-coreutils-8.31/bin:/nix/store/s1n4vl1f3in3nacalrc3xam0vyzpsfvs-findutils-4.6.0/bin:/nix/store/7d9bi31h40hky30f5scqx7r6wn311ain-gnugrep-3.3/bin:/nix/store/qg4qbkbca7qapfzpa8p991yjf944fc3w-gnused-4.7/bin:/nix/store/6bvd29jny80ka8df9prr5hrl5yz7d98k-systemd-239.20190219/bin:/nix/store/bv1lw6a2kw0mn2y3lxhi43180idx6sp9-coreutils-8.31/sbin:/nix/store/s1n4vl1f3in3nacalrc3xam0vyzpsfvs-findutils-4.6.0/sbin:/nix/store/7d9bi31h40hky30f5scqx7r6wn311ain-gnugrep-3.3/sbin:/nix/store/qg4qbkbca7qapfzpa8p991yjf944fc3w-gnused-4.7/sbin:/nix/store/6bvd29jny80ka8df9prr5hrl5yz7d98k-systemd-239.20190219/sbin"
Environment="TZDIR=/nix/store/20wmykp8fj2izxdj8lic8ggcfpdid5ka-tzdata-2019a/share/zoneinfo"



ExecStart=/nix/store/1f0wk7l4p7xv257dci8xxqz1k8nai9va-unit-script-mytestservice-start 

Wenn Sie es jetzt aufrufen möchten, müssen Sie es installieren:

nix-env -f '<nixpkgs/nixos>' -I nixos-config=myconfiguration.nix -iA 'config.systemd.user.units."mytestservice.service".unit'

Dadurch wird das mytestservice.servicein verknüpft ~/.nix-profile/mytestservice.service. Aber systemctl erwartet, dass es in ist ~/.config/systemd/user/, also verknüpfen wir es:

ln -s ~/.nix-profile/mytestservice.service ~/.config/systemd/user/

Dann müssen wir den Daemon neu laden und können versuchen, damit zu spielen:

systemctl --user daemon-reload
systemctl --user start mytestservice.service

Beachten Sie jedoch, dass die Build-/Install-Befehle kompliziert sind und lange einzutippen sind. Wir können daher beispielsweise eine Datei erstellen, anything.nixdie alles für uns erstellt:

let
  eval = import <nixpkgs/nixos> {
    configuration = ./myconfiguration.nix;
  };
  pkgs = import <nixpkgs>{};
in pkgs.buildEnv {
  name = "things";
  paths = [
    eval.config.systemd.user.units."mytestservice.service".unit
  ];
}

Jetzt können Sie mit folgendem kompilieren:

nix-build anything.nix

und installieren Sie mit

nix-env -f anything.nix -i things

Beachten Sie, dass Sie beim ersten Mal möglicherweise die Datei entfernen müssen, die wir mit der anderen Methode installiert haben. Verwenden Sie dazu etwas wie:

nix-env --query
nix-env --uninstall unit-mytestservice.service

Schließlich scheinen beide Codes systemd.servicesmit systemd.services.usersdieser Methode verwendbar zu sein :D

verwandte Informationen