Как правильно открыть SSH-туннель для программы и закрыть его после этого?

Как правильно открыть SSH-туннель для программы и закрыть его после этого?

Я хочу запустить команду, которой для работы требуется туннель SSH (повторное открытие соединений TCP). После того, как он существует, туннель нужно снова закрыть. Проблемы, с которыми я столкнулся, следующие:

  1. Я могу немедленно запустить команду в фоновом режиме, но тогда у меня нет надежного способа убедиться, что туннель настроен:

    #!/bin/bash
    set -e
    ssh -N -L lport:server:port host &
    trap "kill $!" EXIT
    sleep 1
    my program that connects to localhost:lport
    

    Часто бывает, что открытие туннеля занимает больше 1 с. Я мог бы поставить и больше времени, но тогда пользовательский опыт будет не очень хорошим, и все равно это ненадежно.

  2. Я могу разрешить 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.

Связанный контент