Közvetlen VPN alagút a számítógépek között a szolgáltatók NAT-jain keresztül (VPS nélkül, STUN szerver és Yandex.disk használatával)

Kiterjesztés Cikk arról, hogyan sikerült megszerveznem egy közvetlen VPN- egy alagút két számítógép között, amelyek a szolgáltatók NAT-jai mögött helyezkednek el. Az előző cikk egy harmadik fél - egy közvetítő (bérelt) - használatával történő kapcsolat létrehozásának folyamatát ismertette. VPS (Ez egyfajta STUN szerverként és adattovábbítóként működik a csomópontok összekapcsolásához.) Ebben a cikkben elmesélem, hogyan boldogultam VPS nélkül, de a közvetítők megmaradtak: a STUN szerver és a Yandex.Disk.
Közvetlen VPN alagút a számítógépek között a szolgáltatói NAT-okon keresztül (VPS nélkül, STUN szerver és Yandex.disk használatával)

Bevezetés

Az előző bejegyzés megjegyzéseinek elolvasása után rájöttem, hogy a megvalósítás fő hátránya egy közvetítő - egy harmadik fél (VPS) használata volt, amely jelezte a csomópont aktuális paramétereit, hol és hogyan kell csatlakozni. Figyelembe véve a STUN használatára vonatkozó ajánlásokat (amelyekből sok van) az aktuális csatlakozási paraméterek meghatározásához. Először is úgy döntöttem, hogy a TCPDump segítségével megnézem a csomagok tartalmát, amikor a STUN szerver kliensekkel dolgozott és teljesen olvashatatlan tartalmat kapott. Googlázva a protokollt, amivel találkoztam a protokollt leíró cikk. Rájöttem, hogy nem tudok egyedül végrehajtani egy kérést a STUN szerverhez, és egy „távoli dobozba” helyeztem az ötletet.

elmélet

Nemrég telepítenem kellett egy STUN szervert a következőre: Debian a csomagból

# apt install stun-server

és a függőségekben láttam a stun-client csomagot, de valahogy nem figyeltem rá. De később eszembe jutott a stun-client csomag, és úgy döntöttem, hogy kitaláljam, hogyan működik, miután gugliztam és keresgéltem a Yandexben, ezt kaptam:

# apt install stun-client
# stun stun.ekiga.net -p 21234 -v

Válaszul ezt kaptam:

STUN kliens verzió 0.97
Megnyílt a 21234-es port az fd 3-mal
Megnyílt a 21235-es port az fd 4-mal
A kábító üzenet kódolása:
ChangeRequest kódolása: 0

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
Fogadott kábító üzenet: 92 bájt
MappedAddress = <Saját IP-cím>:2885
Forráscím = 216.93.246.18:3478
Megváltozott cím = 216.93.246.17:3479
Ismeretlen attribútum: 32800
ServerName = Vovida.org 0.98-CPC
257 id=1 típusú üzenet érkezett
A kábító üzenet kódolása:
ChangeRequest kódolása: 0

Hamarosan elküldi a len 28 üzenetet a 216.93.246.17:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 0

A len 28 üzenetet készül elküldeni a <My IP>:2885 címre
Fogadott kábító üzenet: 28 bájt
ChangeRequest = 0
1 id=11 típusú üzenet érkezett
A kábító üzenet kódolása:
ChangeRequest kódolása: 0

Hamarosan elküldi a len 28 üzenetet a 216.93.246.17:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
Fogadott kábító üzenet: 92 bájt
MappedAddress = <Saját IP-cím>:2885
Forráscím = 216.93.246.17:3479
Megváltozott cím = 216.93.246.18:3478
Ismeretlen attribútum: 32800
ServerName = Vovida.org 0.98-CPC
257 id=10 típusú üzenet érkezett
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 4

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
A kábító üzenet kódolása:
ChangeRequest kódolása: 2

Hamarosan elküldi a len 28 üzenetet a 216.93.246.18:3478 számra
teszt I = 1
teszt II = 0
teszt III = 0
teszt I(2) = 1
nat = 1
leképezett IP azonos = 1
hajtű = 1
konzerváló port = 0
Elsődleges: Független leképezés, portfüggő szűrő, véletlenszerű port, hajtű
A visszatérési érték 0x000006

Karakterlánc értékkel

MappedAddress = <Saját IP-cím>:2885

csak amire szüksége van! A 21234-es helyi UDP-porton jelenítette meg a kapcsolat aktuális állapotát. De ez még csak a siker fele, felmerült a kérdés, hogyan lehet ezeket az adatokat a távoli gazdagépre továbbítani és VPN-kapcsolatot szervezni. A levelezési protokoll, vagy esetleg a Telegram segítségével?! Sok lehetőség van, és úgy döntöttem, hogy a Yandex.disket használom, mivel találkoztam cikk a Curl WebDav-n keresztüli használatáról a Yandex.disk segítségével. Miután végiggondoltam a megvalósítást, a következő sémát találtam ki:

  1. Jelzi, hogy a csomópontok készen állnak a kapcsolat létrehozására egy adott, időbélyeggel ellátott fájl jelenlétével a Yandex.disk-en;
  2. Ha a csomópontok készen állnak, akkor fogadja az aktuális paramétereket a STUN szervertől;
  3. Töltse fel az aktuális beállításokat a Yandex.disk-re;
  4. Ellenőrizze a távoli csomópont jelenlétét és paramétereinek beolvasását a Yandex.disk fájlból;
  5. Kapcsolat létrehozása egy távoli géppel a következő használatával: OpenVPN.

 

Gyakorlat

Kis gondolkodás után, az utolsó cikk tapasztalatait figyelembe véve gyorsan megírtam egy forgatókönyvet. Szükségünk lesz:

# apt install openvpn stun-client curl 

Maga a forgatókönyv:

Kezdeti verzió

# cat vpn8.sh

 

#!/bin/bash
######################## Задаем цветной текст ###
WARN='33[37;1;41m'				#
END='33[0m'					#
RED='33[0;31m'         #  ${RED}		#
GREEN='33[0;32m'      #  ${GREEN}		#
#################################################
####################### Проверяем наличие необходымих приложений #########################################################
al="echo readlink dirname grep awk md5sum shuf nc curl sleep openvpn cat stun"
ch=0
for i in $al; do which $i > /dev/null || echo -e "${WARN}Для работы необходим $i ${END}"; which $i > /dev/null || ch=1; done
if (( $ch > 0 )); then echo -e "${WARN}Ой, отсутствуют необходимые для корректной работы приложения${END}"; exit; fi
#######################################################################################################################

if [[ $1 == '' ]]; then echo -e "${WARN}Введите идентификатор соединения (любое уникальное слово, должно быть одинаковое с двух сторон!) ${END} t
${GREEN}Для запуска в автоматическом режиме при включении компьютера можно прописать в /etc/rc.local строку nohup /<путь к файлу>/vpn8.sh  > /var/log/vpn8.log 2>/dev/hull & ${END}"; exit; fi
ABSOLUTE_FILENAME=`readlink -f "$0"`                                                    # полный путь до скрипта
DIR=`dirname "$ABSOLUTE_FILENAME"`                                                      # каталог в котором лежит скрипт
############################### Проверка наличия секретного ключа ##################################
key="$DIR/secret.key"
if [ ! -f "$key" ]; then
				echo -e "${WARN}Секретный ключ VPN-соединения не найден, для генерации ключа выполните: 
openvpn --genkey --secret secret.key Внимание: ключ используется для авторизации и должен 
быть одинаковым с двух сторон!!!${END}
 # ls -l secret.key
 -rw------- 1 root root 637 ноя 27 11:12 secret.key
 # chmod 600 secret.key";
				exit;
				fi
########################################################################################################################

ABSOLUTE_FILENAME=`readlink -f "$0"`                                                    # полный путь до скрипта
DIR=`dirname "$ABSOLUTE_FILENAME"`                                                      # каталог в котором лежит скрипт
name=$(uname -n | md5sum | awk '{print $1}')
vpn=$(echo $1 | md5sum | awk '{print $1}')
stun="stun.ekiga.net" 	# STUN сервер
username="Yandex"	# Логин от Яндекс.диска	
password="Password"	# Пароль от Яндекс.диска
localport=`shuf -i 20000-65000 -n 1`	# генерация локального порта

echo "$(date) Создаю папку на Яндекс.диске"
curl -X MKCOL --user "${username}:${password}" https://webdav.yandex.ru/vpn-$vpn
echo "$(date) Очищаю папку от всякого мусора"
for i in `curl --silent --user "$username:$password" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></n/g' | grep "d:displayname" | sed 's/d:displayname//g' | sed 's/>//g' | sed 's/<//' | sed 's////g' | grep -v $(date +%Y-%m-%d-%H-%M)`; do
	echo "$(date) Delete: $i"
	curl -X DELETE --user "${username}:${password}" https://webdav.yandex.ru/vpn-$vpn/$i
	done

until [ $c ];do

	until [[ $b ]]; do
		echo "$(date) Проверяю папку"
		date=`date +%Y-%m-%d-%H-%M`
		mydata=`curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></>n</g' | grep $name | grep $date | grep "d:displayname"`
		if [[ -z $mydata ]]; 	then
						echo "$(date) Файл готовности создан"
					        echo "$date" > "/tmp/$date-$name-ready.txt"
					        curl -T "/tmp/$date-$name-ready.txt" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$date-$name-ready.txt
					else
						echo "$(date) Файл готовности уже существует - $date"
					fi
		remote=`curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></>n</g' | grep -v $name | grep $date | grep "d:displayname"`
		if [[ -z $remote ]];	then
						echo -e "$(date) ${RED} Удаленный узел не готов ${END}"
						echo "$(date) Жду"
						sleep 20
					else
						echo -e "$(date) ${GREEN} Удаленный узел готов ${END}"
						b=1
						a=''
					fi
	done

	until [ $a ]; do
		echo "$(date) Подключение и получение данных от STUN сервера: $stun"
                mydata=`stun $stun -p $localport -v 2>&1 | grep MappedAddress | sort | uniq`
                echo -e "$(date) ${GREEN}Мои данные соединения: $mydata${END}"
                echo "$mydata" > "$DIR/mydata"
                echo "$(date) Загрузка данных на Яндекс.диск"
                curl -T "$DIR/mydata" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$name.txt
		echo "$(date) Получение файла данных удаленного узла"
		filename=$(curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></n/g' | grep "d:displayname>" | grep "txt" | grep -v "$name" | grep -v "ready" | sed 's|.*d:displayname>||' | sed 's/</ /g' | awk '{print $1}')
		echo "$(date) Чтение файла данных удаленного узла: $filename"
		address=$(curl --silent --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$filename | sort | uniq | head -n1 | sed 's/:/ /g')
		echo "$(date) Определение IP-адреса и порта"
		ip=$(echo "$address" | awk '{print $3}')
		port=$(echo "$address" | awk '{print $4}')
		if [[ -n "$ip" && -n "$port" ]]; then
			echo -e "$(date) ${GREEN} Соединение $ip $port ${END}"
       		 	openvpn --remote $ip --rport $port --lport $localport 
	       	 	    --proto udp --dev tap --float --auth-nocache --verb 3 --mute 20 
	       	 	    --ifconfig 10.45.54.2 255.255.255.252 
	       		    --secret "$DIR/secret.key" 
	       		    --auth SHA256 --cipher AES-256-CBC 
	        	    --ncp-disable --ping 10  --ping-exit 30 
	        	    --comp-lzo yes
			echo -e "$(date) ${WARN} Соединение разорвано${END}"
			a=1
			b=''
			else
			a=1
			b=''
			fi
	done
done

A szkript működéséhez szüksége van:

  1. Másolja a vágólapra és illessze be a szerkesztőbe, például:
    # nano vpn8.sh 
  2. adja meg a Yandex.disk felhasználónevét és jelszavát.
  3. Az „—ifconfig 10.45.54.(1 vagy 2) 255.255.255.252” mezőben adja meg az interfész belső IP-címét.
  4. teremt titkos kulcs parancsra:
    # openvpn --genkey --secret secret.key 
  5. tedd futtathatóvá a szkriptet:
    # chmod +x vpn8.sh
  6. futtasd a szkriptet:
    # ./vpn8.sh nZbVGBuX5dtturD

    ahol nZbVGBuX5dtturD a generált kapcsolatazonosító itt

A távoli csomóponton mindent ugyanúgy csináljon, kivéve a secret.key és a kapcsolatazonosító létrehozását, ezeknek meg kell egyezniük.

Frissített verzió (a megfelelő működéshez az időt szinkronizálni kell):

cat vpn10.sh

 

#!/bin/bash
stuns="stun.sipnet.ru stun.ekiga.net"   		# Список STUN серверов через пробел
username=" Login "		# Логин от Яндекс.диска
password=" Password "   	# Пароль от Яндекс.диска
intip="10.23.22.1"		# IP-адрес внутреннего интерфейса

WARN='33[37;1;41m'
END='33[0m'
RED='33[0;31m'
GREEN='33[0;32m'
al="ip echo readlink dirname grep awk md5sum openssl sha256sum shuf curl sleep openvpn cat stun"
ch=0
for i in $al; do which $i > /dev/null || echo -e "${WARN}Для работы необходим $i ${END}"; which $i > /dev/null || ch=1; done
if (( $ch > 0 )); then echo -e "${WARN}Ой, отсутствуют необходимые для корректной работы приложения${END}"; exit; fi
if [[ $1 == '' ]];
	then
		echo -e "${WARN}Введите идентификатор соединения (любое уникальное слово, должно быть одинаковое с двух сторон!) ${END} t
		${GREEN}Для запуска в автоматическом режиме при включении компьютера можно прописать в /etc/rc.local строку nohup /<путь к файлу>/vpn10.sh  > /var/log/vpn10.log 2>/dev/hull & ${END}"
		exit
fi
ABSOLUTE_FILENAME=`readlink -f "$0"`                                                    # полный путь до скрипта
DIR=`dirname "$ABSOLUTE_FILENAME"`                                                      # каталог в котором лежит скрипт
key="$DIR/secret.key"
until [[ -n "$iftosrv" ]]
	do
		echo "$(date) Определяю сетевой интерфейс"; iftosrv=`ip route get 8.8.8.8 | head -n 1 | sed 's|.*dev ||' | awk '{print $1}'`
		sleep 5
done
timedatectl
name=$(uname -n | md5sum | awk '{print $1}')
vpn=$(echo $1 | md5sum | awk '{print $1}')
echo "$(date) Создаю папку на Яндекс.диске"
curl -X MKCOL --user "${username}:${password}" https://webdav.yandex.ru/vpn-$vpn
echo "$(date) ID на диске: $vpn"
until [ $c ];do
	echo "$(date) Очищаю папку от всякого мусора"
	for i in `curl --silent --user "$username:$password" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></n/g' | grep "d:displayname" | sed 's/d:displayname//g' | sed 's/>//g' | sed 's/<//' | sed 's////g' | grep -v $(date +%Y-%m-%d-%H-%M)`
               do
               echo -e "$(date)${RED} Удаляю старый файл: $i${END}"
               curl -X DELETE --user "${username}:${password}" https://webdav.yandex.ru/vpn-$vpn/$i
               done
	echo "$(date) ID на диске: $vpn"
        openvpn --genkey --secret "$key"
        passwd=`echo "$vpn-tt" | sha256sum | awk '{print $1}'`
        openssl AES-256-CBC -e -in "$key" -out "$DIR/file.enc" -k "$passwd" -base64
        curl -T "$DIR/file.enc" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/key.enc
        rm "$DIR"/file.enc
	echo -e "$(date) ${GREEN}Фаза 1 - Получение готовности удаленного узла${END}"
	go=3
	localport=`shuf -i 20000-65000 -n 1`    # генерация локального порта
	start=''
	remote=''
	timeout1=''
	nextcheck=''
	timestart=''
	until [[ $b ]]
		do
		echo "$(date) Проверяю папку"
		date=`date +%s`
		timeout1=60
		echo "$(date) Создание файла готовности $date"
		echo "$date" > "/tmp/ready-$date-$name.txt"
		curl -T "/tmp/ready-$date-$name.txt" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/ready-$name.txt
		readyfile=`curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></>n</g' | grep -v $name | grep "ready" | grep "d:displayname" | sed 's/<d:displayname>//g' | sed 's/</d:displayname>//g'`
		if [[ -z $readyfile ]]
			then
				echo -e "$(date) ${RED} Удаленный узел не готов ${END}"
				echo "$(date) Жду 60 секунд"
				sleep $timeout1
			else
				remote=$(curl --silent --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$readyfile)
				echo -e "$(date) ${GREEN} Удаленный узел готов ${END}"
				start=`curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></>n</g' | grep "start" | grep "d:displayname" | sed 's/-/ /g' | awk '{print $2}'`
				if [[ -z $start ]]
					then
                                                let nextcheck=$timeout1-$date+$remote
						let timestart=$date+$timeout1-$nextcheck
						go=$nextcheck
						echo "$timestart" > "/tmp/start-$date-$name.txt"
						curl -T "/tmp/start-$date-$name.txt" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/start-$date-$name.txt
					else
						echo "$(date) жду $go секунд"
						sleep $go
						b=1
						a=''

					fi

			fi
	done
echo -e "$(date) ${GREEN}Фаза 2 - Обмен данными и установка соединения${END}"
mydata=''
filename=''
address=''
myip=''
ip=''
port=''
ex=0
	until [ $a ]; do
                until [[ -n "$mydata" ]]; do
				k=`echo "$stuns" | wc -w`
				x=1
				z=`shuf -i 1-$k -n 1`
				for st in $stuns; do
					if [[ $x == $z ]]; then
						stun=$st;
					fi;
					(( x++ ));
				done
                                echo "$(date) Подключение и получение данных от STUN сервера: $stun"
				sleep 5 && for pid in $(ps xa | grep "stun "$stun" 1 -p "$localport" -v" | grep -v grep | awk '{print $1}'); do kill $pid; done &
                                mydata=`stun "$stun" 1 -p "$localport" -v 2>&1 | grep "MappedAddress" | sort | uniq`
                done
			echo -e "$(date) ${GREEN}Мои данные соединения: $mydata${END}"
               	 	echo "$(date) Загрузка данных на Яндекс.диск"
			echo "$mydata" > "$DIR/mydata"
			echo "IntIP $intip" >> "$DIR/mydata"
			curl -T "$DIR/mydata" --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$name-ipport.txt
			rm "$DIR/mydata"
			sleep 5
			echo "$(date) Получение файла данных удаленного узла"
			filename=$(curl --silent --user "${username}:${password}" -X PROPFIND -H "Depth: 1" https://webdav.yandex.ru/vpn-$vpn/ | sed 's/></n/g' | grep "d:displayname>" | grep "ipport" | grep -v "$name" |  sed 's|.*d:displayname>||' | sed 's/</ /g' | awk '{print $1}')
			if [[ -n "$filename" ]]
				then
					echo "$(date) Чтение файла данных удаленного узла: $filename"
					address=$(curl --silent --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$filename | grep "MappedAddress" | head -n1 | sed 's/:/ /g')
					intip2=$(curl --silent --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/$filename | grep "IntIP" | head -n1 | awk '{print $2}')
					echo "$(date) Определение IP-адреса и порта: $address $sesid2 $tunid2"
					ip=$(echo "$address" | awk '{print $3}')
					port=$(echo "$address" | awk '{print $4}')
					myip=`ip route get "$ip" | head -n 1 | sed 's|.*src ||' | awk '{print $1}'`
					if [[ -n "$ip" && -n "$port" && -n "$myip" && -n "$localport" ]];
						then
							echo -e "$(date) ${GREEN} Соединение $ip $port ${END}"
							echo -e  "`date` ${GREEN} $myip:$localport -> $ip:$port ${END}"
	                	        		curl --silent --user "$username:$password" https://webdav.yandex.ru/vpn-$vpn/key.enc > "$DIR/secret.enc"
	                        			openssl AES-256-CBC -d -in "$DIR/secret.enc" -out "$key" -k "$passwd" -base64
	                        			chmod 600 "$key"
	                        			rm "$DIR/secret.enc"
	                        			openvpn --remote $ip --rport $port --lport $localport 
	                        			--proto udp --dev tun --float --auth-nocache --verb 3 --mute 20 
	                        			--ifconfig "$intip" "$intip2" 
	                        			--secret "$key" 
	                        			--auth SHA256 --cipher AES-256-CBC 
	                        			--ncp-disable --ping 10 --ping-exit 20 
	                        			--comp-lzo yes
							a=1
							b=''
                                         fi
						else
							if (( $ex >= 5 ))
								then
									echo "$(date) Сброс"
									a=1
									b=''
							fi
							(( ex++ ))
					sleep 5
			fi
		done
done

A szkript működéséhez szüksége van:

  1. Másolja a vágólapra és illessze be a szerkesztőbe, például:
    # nano vpn10.sh 
  2. adja meg a bejelentkezési azonosítót (2. sor) és a Yandex.disk jelszavát (3. sor).
  3. adja meg az alagút belső IP-címét (4. sor).
  4. tedd futtathatóvá a szkriptet:
    # chmod +x vpn10.sh
  5. futtasd a szkriptet:
    # ./vpn10.sh nZbVGBuX5dtturD

    ahol nZbVGBuX5dtturD a generált kapcsolatazonosító itt

A távoli csomóponton tegye ugyanezt, adja meg a megfelelő belső IP-cím alagút és kapcsolat azonosítója.

A szkript automatikus futtatásához, amikor be van kapcsolva, a /etc/ fájlban található „nohup /<a szkript elérési útja>/vpn10.sh nZbVGBuX5dtturD > /var/log/vpn10.log 2>/dev/null &” parancsot használom. rc.local

Következtetés

A szkript működik, tesztelve lett Ubuntu (18.04, 19.10, 20.04) és Debian 9. Bármely más szolgáltatást is használhatsz adóként, de a kísérlethez a Yandex.Disk-et használtam.
A kísérletek során kiderült, hogy bizonyos típusú NAT-szolgáltatók nem teszik lehetővé a kapcsolat létrehozását. Főleg mobilszolgáltatóktól, ahol a torrentek le vannak tiltva.

A következőkben tervezek fejlődni:

  • A secret.key automatikus generálása minden indításkor, titkosítás és másolás a Yandex.disk-re távoli csomópontra való átvitel céljából (Figyelembe véve a frissített verzióban)
  • Az interfészek IP-címeinek automatikus hozzárendelése
  • Az adatok titkosítása a Yandex.disk webhelyre való feltöltés előtt
  • Kód optimalizálás

Legyen IPv6 minden otthonban!

Frissítve! A legújabb fájlok és a DEB csomag itt - yandex.disk

Forrás: will.com

Vásároljon megbízható tárhelyet DDoS védelemmel, VPS VDS szerverekkel rendelkező webhelyekhez 🔥 Vásároljon megbízható weboldal tárhelyet DDoS védelemmel, VPS VDS szerverekkel | ProHoster