Небольшой скрипт, которым я пользуюсь для поднятия прокси-через-ssh. Висит в автозагрузке, постоянно проверяет при помощи курла доступность гугла, в случае недоступности — прибивает нужное ssh-соединение и открывает его снова.
ЗЫ: свой собственный прокси с шифрованием трафика средствами ssh — рекомендации лучших собаководов )
#!/bin/sh # establishes an SSH Socks proxy and reconnects if it fails. socksPort=8376 server=example.com user=myproxyuser key=~/.ssh/id_rsa_myproxyuser while true do timeout 20 curl --retry-max-time 1 --retry 5 --retry-delay 1 -x socks5://127.0.0.1:${socksPort} http://google.com/ > /dev/null 2>&1 if [ $? -ne 0 ] then echo $(date) reconnect... while ps -eo pid,cmd | grep ssh | grep ${socksPort} do kill $(ps -eo pid,cmd | grep ssh | grep ${socksPort} | awk '{print $1}' | head -n 1) done; ssh -D ${socksPort} -f -q -N -i "${key}" ${user}@${server} else sleep 10 fi done;
Вариант для cygwin
#!/bin/sh # establishes an SSH Socks proxy and reconnects if it fails. socksPort=8376 server=example.com user=myproxyuser key=~/.ssh/id_rsa_myproxyuser while true do timeout 20 curl -x socks5://127.0.0.1:${socksPort} http://google.com/ > /dev/null 2>&1 if [ $? -ne 0 ] then while ps -e | grep ssh; do # /bin/kill - is important! /bin/kill -f $(grep -a "ssh" /proc/*/cmdline | grep -a ${socksPort} | awk -F '/' '{print $3}' | head -n 1) done; echo $(date) reconnect ssh -D ${socksPort} -fNq -i "${key}" ${user}@${server} else sleep 10 fi done;