¿Cómo mantengo vivo un túnel ssh usando launchd?

2

Me gustaría mantener vivo un túnel ssh. A continuación, se encuentra mi archivo plist del agente de lanzamiento, pero solo mantiene el túnel arriba por un día o dos como máximo. Estoy usando OS X 10.10.3.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
        <dict>
                <key>Label</key>
                <string>com.my.ssh_tunnel</string>
                <key>ProgramArguments</key>
                <array>
                        <string>/usr/bin/ssh</string>
                        <string>-R 0.0.0.0:22221:localhost:22</string>
                        <string>-NTC</string>
                        <string>-f</string>
                        <string>-o ExitOnForwardFailure=yes</string>
                        <string>-o ServerAliveInterval=60</string>
                        <string>[email protected]</string>
                </array>
                <key>RunAtLoad</key>
                <true/>
                <key>KeepAlive</key>
                <true/>
        </dict>
</plist>
    
pregunta wkmor1 01.05.2015 - 07:59

1 respuesta

1

Creo que necesitas agregar "ServerAliveCountMax". Ya que no lo tiene configurado por defecto en 3. Intente configurarlo en algo más alto que 3 y vea si revive algunos de sus problemas. En su caso, se desconectaría si el servidor no responde durante 180 segundos.

Desde la página de manual de ssh:

 ServerAliveCountMax:

     Sets the number of server alive messages (see below) which may be
     sent without ssh(1) receiving any messages back from the server.
     If this threshold is reached while server alive messages are
     being sent, ssh will disconnect from the server, terminating the
     session.  It is important to note that the use of server alive
     messages is very different from TCPKeepAlive (below).  The server
     alive messages are sent through the encrypted channel and there‐
     fore will not be spoofable.  The TCP keepalive option enabled by
     TCPKeepAlive is spoofable.  The server alive mechanism is valu‐
     able when the client or server depend on knowing when a connec‐
     tion has become inactive.

     The default value is 3.  If, for example, ServerAliveInterval
     (see below) is set to 15 and ServerAliveCountMax is left at the
     default, if the server becomes unresponsive, ssh will disconnect
     after approximately 45 seconds.  This option applies to protocol
     version 2 only.
    
respondido por el tron_jones 01.05.2015 - 15:09

Lea otras preguntas en las etiquetas