Loris,

Your analogy is incorrect, because Slurm doesn't use SSH to launch jobs, it uses it's own communication protocol, which uses munge for authentication. Some schedulers used to use ssh to launch jobs, but most have moved to using their own communications protocol outside of SSH. It's possible that Slurm used SSH in the early days, too. I wouldn't know. I've only been using Slurm for the past 5 years.

In those cases, you usually needed host-based SSH so that the scheduler daemon could launch jobs on the compute nodes. In that situation, you would be able to ssh from one node to another without per-user ssh keys, since they'd already be setup on a per-host basis. Perhaps that's what you are remembering.

Prentice

On 5/25/21 8:09 AM, Loris Bennett wrote:
Hi everyone,

Thanks for all the replies.

I think my main problem is that I expect logging in to a node with a job
to work with pam_slurm_adopt but without any SSH keys.  My assumption
was that MUNGE takes care of the authentication, since users' jobs start
on nodes with the need for keys.

Can someone confirm that this expectation is wrong and, if possible, why
the analogy with jobs is incorrect?

I have a vague memory that this used work on our old cluster with an
older version of Slurm, but I could be thinking of a time before we set
up pam_slurm_adopt.

Cheers,

Loris
Brian Andrus <toomuc...@gmail.com> writes:

Oh, you could also use the ssh-agent to mange the keys, then use 'ssh-add
~/.ssh/id_rsa' to type the passphrase once for your whole session (from that
system).

Brian Andrus


On 5/21/2021 5:53 AM, Loris Bennett wrote:
Hi,

We have set up pam_slurm_adopt using the official Slurm documentation
and Ole's information on the subject.  It works for a user who has SSH
keys set up, albeit the passphrase is needed:

    $ salloc --partition=gpu --gres=gpu:1 --qos=hiprio --ntasks=1 
--time=00:30:00 --mem=100
    salloc: Granted job allocation 7202461
    salloc: Waiting for resource configuration
    salloc: Nodes g003 are ready for job

    $ ssh g003
    Warning: Permanently added 'g003' (ECDSA) to the list of known hosts.
    Enter passphrase for key '/home/loris/.ssh/id_rsa':
    Last login: Wed May  5 08:50:00 2021 from login.curta.zedat.fu-berlin.de

    $ ssh g004
    Warning: Permanently added 'g004' (ECDSA) to the list of known hosts.
    Enter passphrase for key '/home/loris/.ssh/id_rsa':
    Access denied: user loris (uid=182317) has no active jobs on this node.
    Access denied by pam_slurm_adopt: you have no active jobs on this node
    Authentication failed.

If SSH keys are not set up, then the user is asked for a password:

    $ squeue --me
                 JOBID PARTITION     NAME     USER ST       TIME  NODES 
NODELIST(REASON)
               7201647      main test_job nokeylee  R    3:45:24      1 c005
               7201646      main test_job nokeylee  R    3:46:09      1 c005
    $ ssh c005
    Warning: Permanently added 'c005' (ECDSA) to the list of known hosts.
    nokeylee@c005's password:

My assumption was that a user should be able to log into a node on which
that person has a running job without any further ado, i.e. without the
necessity to set up anything else or to enter any credentials.

Is this assumption correct?

If so, how can I best debug what I have done wrong?

Cheers,

Loris


Reply via email to