![Как правильно открыть SSH-туннель для программы и закрыть его после этого?](https://rvso.com/image/1388801/%D0%9A%D0%B0%D0%BA%20%D0%BF%D1%80%D0%B0%D0%B2%D0%B8%D0%BB%D1%8C%D0%BD%D0%BE%20%D0%BE%D1%82%D0%BA%D1%80%D1%8B%D1%82%D1%8C%20SSH-%D1%82%D1%83%D0%BD%D0%BD%D0%B5%D0%BB%D1%8C%20%D0%B4%D0%BB%D1%8F%20%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D1%8B%20%D0%B8%20%D0%B7%D0%B0%D0%BA%D1%80%D1%8B%D1%82%D1%8C%20%D0%B5%D0%B3%D0%BE%20%D0%BF%D0%BE%D1%81%D0%BB%D0%B5%20%D1%8D%D1%82%D0%BE%D0%B3%D0%BE%3F.png)
Я хочу запустить команду, которой для работы требуется туннель SSH (повторное открытие соединений TCP). После того, как он существует, туннель нужно снова закрыть. Проблемы, с которыми я столкнулся, следующие:
Я могу немедленно запустить команду в фоновом режиме, но тогда у меня нет надежного способа убедиться, что туннель настроен:
#!/bin/bash set -e ssh -N -L lport:server:port host & trap "kill $!" EXIT sleep 1 my program that connects to localhost:lport
Часто бывает, что открытие туннеля занимает больше 1 с. Я мог бы поставить и больше времени, но тогда пользовательский опыт будет не очень хорошим, и все равно это ненадежно.
Я могу разрешить SSH работать в фоновом режиме при открытии соединения, но тогда я не могу найти надежный способ завершить его, поскольку я не знаю PID фонового процесса SSH:
#!/bin/bash set -e ssh -f -N -L lport:server:port host # I'd set up a trap ??? EXIT, but for what? my program that connects to localhost:lport
Есть ли способ определить PID процесса SSH?
Или есть другой, лучший способ решения задачи?
решение1
Видетьhttps://stackoverflow.com/questions/2241063/bash-script-to-setup-a-temporary-ssh-tunnelдля ответов, содержащих Control Socket и ExitOnForwardFailure.