Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2012-11-12 17:55:18

  karol - Użytkownik

karol
Użytkownik
Zarejestrowany: 2010-03-04

prośba o pomoc w przerobieniu skryptu

Witam,
potrzebuje utrzymywać połączenie vpn za wszelką cenę znalazłem w sieci skrypt który przynajmniej na oko wygląda dobrze jednak był napisany pod BSD i na Debianie wysypuje się podczas testowania adresu IP. Prośba o pomoc w dostosowaniu skryptu pod basha

Kod:

#!/bin/ksh

# This script was developed on OpenBSD with ksh as the primary shell.

# set INT_SERVER to a list of 5 ping-able machines behind your vpn gateway
# ip addresses can be repeated if you have less than five machines.

##chyba poniższa linia jest wadliwa 
set -A INT_SERVER 192.168.1.16 192.168.1.201 192.168.1.205 192.168.1.230 192.168.1.129

# this script expects vpnc to be properly configured beforehand with a working profile.
# this script only handles detecting a dropped tunnel and re-establishing the tunnel.
VPNC=/usr/sbin/vpnc
DISC=/usr/sbin/vpnc-disconnect
TUN=tun0

debug=0 # automatically tuned if vpnc fails...

while [ 1 -eq 1 ]; do # main loop

        echo "Connecting to vpn gateway at `date`...";
        [ $debug -gt 3 ] && debug=3
        $VPNC --debug $debug
        [ $? -gt 0 ] && { echo "connection failed!"; debug=`expr $debug + 1`; $DISC; ifconfig $TUN destroy; sleep 1; continue; } || echo "Connected!"

        sleep 1; # let the VPN "settle" before testing connectivity

        checks=0
        while [ $checks -lt 5 ]; do

                server=${INT_SERVER[$checks]}
                checks=`expr $checks + 1`
                success=0

                while ping -c 1 -w $checks -i $checks $server >/dev/null 2>&1; do

                        sleep $checks
                        success=`expr $success + 1`
                        [ $success -gt 60 -a $checks -gt 4 ] && { checks=0; echo "Resetting failure count."; }

                done

                echo "Failed check #$checks - $server"
        done

        echo "Tunnel dropped at `date`...resetting!"
        $DISC 2>/dev/null;
        ifconfig $TUN destroy;
        sleep 1;
done

Offline

 

#2  2012-11-12 18:45:45

  Jacekalex - Podobno człowiek...;)

Jacekalex
Podobno człowiek...;)
Skąd: /dev/random
Zarejestrowany: 2008-01-07

Re: prośba o pomoc w przerobieniu skryptu

Jakie połączenie VPN? Jest kilka różnych rodzajów tunelów VPN.
Np OpenVPN nie zrywa bez powodu połączenia, w ssh można ustawić podtrzymywanie połączenia w konfiguracji.

Jeśli to natomiast chodzi o  Cisco VPN, to spróbuj tego:
https://github.com/dcantrell/vpncwatch

Ostatnio edytowany przez Jacekalex (2012-11-12 18:55:01)


W demokracji każdy naród ma taką władzę, na jaką zasługuje ;)
Si vis pacem  para bellum  ;)       |       Pozdrawiam :)

Offline

 

#3  2012-11-13 15:14:34

  karol - Użytkownik

karol
Użytkownik
Zarejestrowany: 2010-03-04

Re: prośba o pomoc w przerobieniu skryptu

Dziękuje za pomoc problem rozwiązany za pomocą vpncwatch

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Nas ludzie lubią po prostu, a nie klikając w przyciski ;-)