Cela fonctionne pour moi en utilisant uniquement le fichier de socket pour le maître de contrôle:
$ ssh -o ControlPath=~/.ssh/<controlfile> -O check <bogus arg>
Exemple
Voici un exemple où j'ai déjà établi une connexion à un serveur distant:
$ ssh -o ControlPath=~/.ssh/master-57db26a0499dfd881986e23a2e4dd5c5c63e26c2 -O check blah
Master running (pid=89228)
$
Et avec cela déconnecté:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O check blah
Control socket connect(/Users/user1/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74): No such file or directory
$
S'il était toujours connecté, cela le forcerait à sortir immédiatement:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O exit blah
Exit request sent.
$
Ce n'est pas clair pour moi, mais il semblerait qu'il s'agisse d'un bogue dans la mesure ssh
où il nécessite un argument supplémentaire à la fin, même si cela blah
n'a pas de sens dans le contexte des commutateurs que j'utilise.
Sans ça me donne ceci:
$ ssh -o ControlPath=~/.ssh/master-57db26a0499dfd881986e23a2e4dd5c5c63e26c2 -O check
usage: ssh [-1246AaCfGgKkMNnqsTtVvXxYy] [-b bind_address] [-c cipher_spec]
[-D [bind_address:]port] [-E log_file] [-e escape_char]
[-F configfile] [-I pkcs11] [-i identity_file]
[-L [bind_address:]port:host:hostport] [-l login_name] [-m mac_spec]
[-O ctl_cmd] [-o option] [-p port]
[-Q cipher | cipher-auth | mac | kex | key]
[-R [bind_address:]port:host:hostport] [-S ctl_path] [-W host:port]
[-w local_tun[:remote_tun]] [user@]hostname [command]
Informations de version
OSX
$ ssh -V
OpenSSH_6.9p1, LibreSSL 2.1.8
CentOS 7.x
$ ssh -V
OpenSSH_7.4p1, OpenSSL 1.0.2k-fips 26 Jan 2017
J'ai confirmé que sur ces deux versions, la nécessité de l'argument supplémentaire faux était nécessaire.
Références
ssh -S none
(peut-être que cela vous aide déjà).