Удаленное включение по локальной сети за 2 маршрутизаторами

Удаленное включение по локальной сети за 2 маршрутизаторами

Я искал решение своих проблем последние 3 дня, но пока ничего не помогло.

Цель

Мне нужно иметь возможность будить мой домашний компьютер удаленно. Теперь WOL работает локально: я могу включить машину с моего телефона на Android. Мне нужно, чтобы она работала, даже если я не дома.

Мои настройки сети

У меня два маршрутизатора, основной маршрутизатор подключен к интернет-провайдеру, работает на фирменном программном обеспечении, которое поддерживает переадресацию портов, но не имеет функциональности WOL. Вторичный маршрутизатор подключен к первому через кабель Ethernet и работает на DD-WRT. Мой домашний компьютер подключен к вторичному маршрутизатору через кабель Ethernet и имеет статический IP-адрес. Я также настроил динамический DNS, ссылающийся на основной маршрутизатор, благодаря no-ip.

Решения, которые я пробовал

Первое решение, которое я попробовал, было перенаправить UDP-трафик, поступающий на порт 7 основного маршрутизатора, на порт 7 вторичного маршрутизатора. Затем перенаправить UDP, поступающий на порт 7 вторичного маршрутизатора, на мой домашний компьютер. Это не сработало. Даже настройка статического входа в таблице ARP для моего домашнего компьютера не сработала.

Второе решение, которое мне кажется наиболее безопасным, заключается в том, что dd-wrt проверяет файлы журнала на предмет запросов к моему домашнему компьютеру, и если он их находит, dd-wrt выдает команду wol, пробуждая компьютер. Я нашел этот скрипт:

#!/bin/sh
#Enable JFFS2 and place script in /jffs/ then run on startup in web interface.
#You can check the log from http://192.168.2.1/user/wol.html

INTERVAL=1
PINGTIME=1
OLD=""
PORT=32400
WOLPORT=9
TARGET=192.168.2.4
BROADCAST=192.168.2.255
MAC=00:1f:5b:32:c6:0c
WOL=/usr/sbin/wol
LOGFILE="/tmp/www/wol.html"

echo "<meta http-equiv=\"refresh\" content=\"10\">" > $LOGFILE
echo "AUTO WOL Script started at" `date` "<br>" >> $LOGFILE

while sleep $INTERVAL;do
NEW=`dmesg | awk '/ACCEPT/ && /DST='"$TARGET"'/ && /DPT='"$PORT"'/ {print }' | tail -1`
SRC=`dmesg | awk -F'[=| ]' '/ACCEPT/ && /DST='"$TARGET"'/ && /DPT='"$PORT"'/ {print $7}' | tail -1`
LINE=`dmesg | awk '/ACCEPT/ && /DST='"$TARGET"'/ && /DPT='"$PORT"'/'`

if [ "$NEW" != "" -a "$NEW" != "$OLD" ]; then                                               
   if ping -qw $PINGTIME $TARGET >/dev/null; then                                                 
      echo "NOWAKE $TARGET was accessed by $SRC and is already alive at" `date` "<br>">> $LOGFILE    
   else                                                                                        
      echo "WAKE $SRC causes wake on lan at" `date` "<br>">> $LOGFILE                         
      $WOL -i $BROADCAST -p $WOLPORT $MAC >> $LOGFILE                                             
      echo "<br>" >> $LOGFILE                                                                  
      sleep 1                                                                                 
   fi                                                                                          
   OLD=$NEW                                                                                  
fi                                                                                                                                                                               
done

Я настроил скрипт, журнал, сохраненный в, /tmp/www/wol.htmlсодержит только вывод двух команд echo перед циклом while в скрипте.

Я думаю, что это проблема логов dd-wrt, я проверил их, и, похоже, они не содержат никакой информации об IP-адресах или портах:

Sep  1 16:58:00 DD-WRT user.info : dhcpfwd : dhcp forwarder daemon successfully started
Sep  1 17:00:00 DD-WRT user.info : dhcpfwd : dhcp forwarder daemon successfully started
Sep  1 17:02:01 DD-WRT user.info : dhcpfwd : dhcp forwarder daemon successfully started
Sep  1 17:04:00 DD-WRT user.info : dhcpfwd : dhcp forwarder daemon successfully started
Sep  1 17:06:00 DD-WRT user.info : dhcpfwd : dhcp forwarder daemon successfully started
Sep  1 17:06:39 DD-WRT daemon.info hostapd: ath0: STA ac:cf:85:a1:f0:1b IEEE 802.11: disassociated due to inactivity
Sep  1 17:06:40 DD-WRT daemon.info hostapd: ath0: STA ac:cf:85:a1:f0:1b IEEE 802.11: deauthenticated due to inactivity (timer DEAUTH/REMOVE)
Sep  1 17:06:45 DD-WRT daemon.info hostapd: ath0: STA fc:3f:7c:8b:0c:71 IEEE 802.11: disassociated due to inactivity
Sep  1 17:06:46 DD-WRT daemon.info hostapd: ath0: STA fc:3f:7c:8b:0c:71 IEEE 802.11: deauthenticated due to inactivity (timer DEAUTH/REMOVE)
Sep  1 17:07:08 DD-WRT auth.info login[1874]: root login on 'pts/0'

Кто-нибудь знает, почему скрипт не работает? Есть ли у вас альтернативное решение?

решение1

Хорошо, я наконец нашел решение.

На основном маршрутизаторе я пересылаю UDP-трафик, поступающий на порт 9, на вторичный маршрутизатор.

Я включил ведение журнала syslogd и брандмауэра в dd-wrt для второго маршрутизатора, эти журналы сохраняются в файле: /proc/net/ip_conntrack

Я добавил этот скрипт запуска в dd-wrt:

#! /bin/sh 

WOL=/usr/sbin/wol 
MAC_VMC=cd:6e:a2:32:87:6v 
BCAST=192.168.2.255 
LOGFILE="/tmp/www/wol.html"

echo "AUTO WOL Script started at" `date` "<br>" >> $LOGFILE

while sleep 5 ; do 
 if [ `egrep -c udp.+dport=9 /proc/net/ip_conntrack` -gt 0 ] ; then 
  echo "Sending Magic Packet at" `date` >> $LOGFILE
  $WOL -i $BCAST -p 7 $MAC_VMC 
  sleep 120
 fi 
done

Он просматривает файл журнала трафика и, когда видит UDP-трафик на порту 9, пробуждает мой домашний компьютер с помощью команды dd-wrt wol.

Работает отлично даже удаленно, единственное, что меня беспокоит — это безопасность.

Связанный контент