Działa to dla mnie przy użyciu tylko pliku gniazda dla wzorca sterowania:
$ ssh -o ControlPath=~/.ssh/<controlfile> -O check <bogus arg>
Przykład
Oto przykład, w którym nawiązałem już połączenie ze zdalnym serwerem:
$ ssh -o ControlPath=~/.ssh/master-57db26a0499dfd881986e23a2e4dd5c5c63e26c2 -O check blah
Master running (pid=89228)
$
A przy odłączonym:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O check blah
Control socket connect(/Users/user1/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74): No such file or directory
$
Jeśli nadal byłby podłączony, zmusiłoby go to do natychmiastowego wyjścia:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O exit blah
Exit request sent.
$
Nie jest to dla mnie jasne, ale wydaje się, że to potencjalnie błąd ssh
, ponieważ wymaga dodatkowego argumentu na końcu, mimo że blah
jest bez znaczenia w kontekście przełączników, których używam.
Bez tego daje mi to:
$ 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]
Informacje o wersji
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
Potwierdziłem, że w obu tych wersjach wymagana była dodatkowa nieprawdziwa argumentacja.
Bibliografia
ssh -S none
(być może to już ci pomaga).