chisel
chisel copied to clipboard
add timeout for keepalive reply
The sshConn.Send Request will send message and block wait the reply. The keepalive will not work in some special condition. For example, when the server use memory snapshot to hibernate and did not close the socket normally and there is a websocket middware like Cloudflare to proxy the websocket, when the server hibernate with memory snapshot, Cloudflare will not close the websocket connection during a very long time(this maybe a issue of Cloudflare), in the mean while, the keepalive block wait the reply(there will not have a reply as server hibernated), as a result, the ssh connection will not close until the Cloudflare close the websocket(very long time above 10min). So I add a reply timeout for the keepalive. A timeout error will raise when wait the keepalive reply too long, and then close the ssh connetion.
Thanks this is a good change - will try get a sec to test it soon
Hey, Is this going to merge anytime soon? Thanks!!
@jpillora We are experiencing the same issues described here, and this PR will resolve them. Could you please review and merge the PR?