Bu benim için sadece kontrol ana için soket dosyasını kullanarak çalışır:
$ ssh -o ControlPath=~/.ssh/<controlfile> -O check <bogus arg>
Örnek
Uzak bir sunucuya zaten bağlantı kurduğum bir örnek:
$ ssh -o ControlPath=~/.ssh/master-57db26a0499dfd881986e23a2e4dd5c5c63e26c2 -O check blah
Master running (pid=89228)
$
Ve bununla bağlantısı kesildi:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O check blah
Control socket connect(/Users/user1/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74): No such file or directory
$
Eğer hala bağlı olsaydı, bu derhal çıkmaya zorlardı:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O exit blah
Exit request sent.
$
Bana göre belirsiz, ancak kullandığım anahtarların bağlamında anlamsız ssh
olsa da blah
, sonunda ek bir tartışma gerektirdiği için potansiyel olarak bir hata olduğu görülüyor .
Bu olmadan bana şunu verir:
$ 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]
Sürüm bilgisi
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
Bu versiyonların her ikisinde de, sahte sahte argümana ihtiyaç duyulduğunu doğruladım.
Referanslar
ssh -S none
(belki bu zaten size yardımcı olur).