Це працює для мене, використовуючи лише файл сокета для керуючого управління:
$ ssh -o ControlPath=~/.ssh/<controlfile> -O check <bogus arg>
Приклад
Ось приклад, коли я вже встановив з'єднання з віддаленим сервером:
$ ssh -o ControlPath=~/.ssh/master-57db26a0499dfd881986e23a2e4dd5c5c63e26c2 -O check blah
Master running (pid=89228)
$
І з цим відключено:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O check blah
Control socket connect(/Users/user1/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74): No such file or directory
$
Якби все-таки було підключено, це змусить його негайно вийти:
$ ssh -o ControlPath=~/.ssh/master-66496a62823573e4760469df70e57ce4c15afd74 -O exit blah
Exit request sent.
$
Мені це незрозуміло, але, мабуть, це може бути помилка в ssh
тому, що він потребує додаткового аргументу в кінці, хоча blah
це безглуздо в контексті комутаторів, які я використовую.
Без цього мені це дає:
$ 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]
Інформація про версію
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
Я підтвердив, що в обох цих версіях була необхідність додаткового хибного аргументу.
Список літератури
ssh -S none
(можливо, це вам вже допомагає).