From: ludo@gnu.org (Ludovic Courtès)
To: Ricardo Wurmus <ricardo.wurmus@mdc-berlin.de>
Cc: 20381@debbugs.gnu.org
Subject: bug#20381: Interacting with a remote daemon
Date: Fri, 10 Jul 2015 19:48:50 +0200 [thread overview]
Message-ID: <87h9pbaoot.fsf@gnu.org> (raw)
In-Reply-To: <idj7fq847ke.fsf@bimsb-sys02.mdc-berlin.net> (Ricardo Wurmus's message of "Fri, 10 Jul 2015 12:42:57 +0200")
Ricardo Wurmus <ricardo.wurmus@mdc-berlin.de> skribis:
> I just tried the socat idea[1] with some success.
>
> On the guix-builder host where guix-daemon is running and the NFS share
> holding ‘/gnu’ (with $localstatedir set to ‘/gnu/var’) is mounted as
> read-write I executed this:
>
> /root/.guix-profile/bin/socat TCP4-LISTEN:9999 UNIX:/gnu/var/guix/daemon-socket/socket
>
> On a cluster node where /gnu is mounted read-only I ran this:
>
> socat UNIX-LISTEN:/home/rwurmus/foo TCP4:guix-builder:9999 &
> export GUIX_DAEMON_SOCKET=$HOME/foo
>
> At this point I could use
>
> guix build hello
> guix environment hello
>
> which is really great!
Excellent, thanks for testing!
> To make the “guix” command available on cluster nodes I just installed
> it into my default user profile as ‘~/.guix-profile/bin/guix’. The
> problem with this is that profile commands don’t work as the regular
> “guix” package as installed with $localstatedir set to ‘/var’. This can
> be fixed, of course, (e.g. by creating a slightly different “guix”
> package with the appropriate configure flags set) but it’s still a minor
> annoyance.
What about installing Guix in /gnu/bin (say) and sharing it over NFS?
I would avoid installing Guix in a profile, because if things go wrong,
you may find yourself unable to do anything. In practice, you can
always roll-back by hand (it’s simply a matter of switching the
profiles/per-user/$USER symlink), but still.
> It would be great if $localstatedir could be overridden at runtime or
> if it could default to whatever the daemon uses.
Actually it can be overridden via the intentionally-undocumented
NIX_STATE_DIR environment variable (see (guix config).)
> This would probably work fine if I limited the socket forwarding to just
> the cluster nodes, because only there user ids are guaranteed to be
> correct (not on workstations). On workstations that are not centrally
> managed this will not work, as the user ids could be arbitrary and it
> would thus allow anyone to change anyone else’s profile by creating a
> local account with the appropriate uid.
The only problem would be with ‘guix package’, which you haven’t
mentioned yet. :-) For ‘guix package’ to work,
/gnu/var/guix/profiles/per-user must be shared read-write (over NFS)
with correct UID mapping.
> I prefer the socat approach over just running “guix” remotely through an
> SSH connection, because with socat the “guix” command can actually be
> used to spawn a new local shell with “guix environment”, which is very
> useful. I don’t think this would work if “guix” were just run
> remotely. (Please correct me if I’m wrong about this.)
Indeed, that would only allow you to spawn a shell on the machine where
the ‘guix’ command is executed (which, in your case, is not a compute
node AIUI.)
I think we should have a “Cluster Setup” section in the manual to
explain all this. Would you like to give it a try?
Ludo’.
next prev parent reply other threads:[~2015-07-10 17:50 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-04-20 12:47 bug#20381: Interacting with a remote daemon Ludovic Courtès
2015-07-10 10:42 ` Ricardo Wurmus
2015-07-10 17:48 ` Ludovic Courtès [this message]
2015-07-10 20:24 ` Ricardo Wurmus
2017-04-25 10:24 ` Ludovic Courtès
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=87h9pbaoot.fsf@gnu.org \
--to=ludo@gnu.org \
--cc=20381@debbugs.gnu.org \
--cc=ricardo.wurmus@mdc-berlin.de \
/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.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.