Скрипт для поднятия SOCKS-прокси посредством ssh с проверкой его работоспособности

Небольшой скрипт, которым я пользуюсь для поднятия прокси-через-ssh. Висит в автозагрузке, постоянно проверяет при помощи курла доступность гугла, в случае недоступности — прибивает нужное ssh-соединение и открывает его снова.

ЗЫ: свой собственный прокси с шифрованием трафика средствами ssh — рекомендации лучших собаководов )

proxy.sh
 
#!/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

proxy_cygwin.sh
 
#!/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;