Небольшой скрипт, которым я пользуюсь для поднятия прокси-через-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;