ãã®èšäºã§ã¯ãè€æ°ã®ããŒã LANãšãVPNã䜿çšãããããã¯ãŒã¯ãªãœãŒã¹ã®ééçãªå
±æãçµã¿åãããããšã«çŠç¹ãåœãŠãŠããŸãã VPNã®å®è£
ã¯
openvpnã«ãã£ãŠè¡ãã
ãŸã ã ã¯ã©ã€ã¢ã³ããšopenvpnãµãŒããŒã¯ãããŒã ãããã¯ãŒã¯ã«ãŒã¿ãŒãç¹å®ã®å Žåã§ã¯asus wl500ãã¡ããªãŒã«ãŒã¿ãŒã«ã€ã³ã¹ããŒã«ãããŸããããã®ããã¥ã¢ã«ã¯ãOSã«ã¢ã¯ã»ã¹ã§ããä»ã®ã«ãŒã¿ãŒã«é©çšã§ããopenvpnãã€ã³ã¹ããŒã«ã§ããŸãã
ãã®ãããªã€ã³ã¿ãŒãããäžã®ããã¥ã¢ã«ã¯1ããŒã¹ã§ãããããŒã ã·ã¹ãã ã«ãŒã¿ãŒã®ãŠãŒã¶ãŒã¯äž»ã«ããã«ãŒã§ã¯ãªããéåžžã®ãŠãŒã¶ãŒã§ãããLinuxã³ãã³ãã©ã€ã³ãåããŠèŠããšãã«ã* nixã·ã¹ãã ã§è±å¯ãªçµéšãæã€ç®¡çè
åãã«æžãããŠããŸããã«ãŒã¿ãŒèªäœã 誰ããã¯ã£ãããšãããããã«æžããŸãã
ããããã®æçŽã奜ãã§ã¯ãªã人ã®ããã«ãç§ãã¡ãã«ããã®äžã§è©±ããŠããããšãæ確ã«ãªãããã«ãç§ã¯åçãæã£ãŠãã

ããã§ãããäžåºŠãåé¡ã圢åŒåããŸãã ã«ãŒã¿ãŒãä»ããŠã€ã³ã¿ãŒãããã«ã¢ã¯ã»ã¹ã§ããè€æ°ã®ãããã¯ãŒã¯ããããæå·åãããã€ã³ã¿ãŒããããã³ãã«ãä»ããŠçžäºã®ãããã¯ãŒã¯ãªãœãŒã¹ãžã®ã¢ã¯ã»ã¹ãæäŸããå¿
èŠããããŸãã
ããã§å¿
èŠãªãã®
- Asus wl500ãã¡ããªãŒã«ãŒã¿ãŒ
- ã«ãŒã¿ã«ã¯ãã©ãã·ã¥ãšRAMãã»ãšãã©ãªããéåžžã«å€ããžã£ã³ã¯ïŒ9MbæªæºïŒãé€ããã©ãã§ãååã«é©åãããããã«ãŒã¿ã«usbãã©ãã·ã¥ãã©ã€ããè£
åããããšãéåžžã«æãŸããã§ãã æ°ãããã©ãã·ã¥ãã©ã€ãã䜿çšããçç±ã¯äœã§ããïŒ :)
- å°ãªããšã1ã€ã®ã«ãŒã¿ãŒãå®éã®IPã¢ãã¬ã¹ã§ã€ã³ã¿ãŒãããã«ã¢ã¯ã»ã¹ãããããã¹ãŠã®ã«ãŒã¿ãŒããããã€ããŒã®ããŒã«ã«ãããã¯ãŒã¯ã®åãã»ã°ã¡ã³ãã«ååšããå¿
èŠããããŸãã
- ã«ãŒã¿ãŒã®èåŸã®ãããã¯ãŒã¯ã«ã¯ç°ãªãã¢ãã¬ã¹ç¯å²ãå¿
èŠã§ã
- ããã€ãã®æéãšè³
ã«ãŒã¿ãŒãäžç·ã«æ§æããå¿
èŠããããããåæã«ãããã«ã¢ã¯ã»ã¹ããããšããå§ãããŸãã ããã¢ããŒãããå¥ã®ã¢ããŒãã«ç§»åããã®ã¯ç¹ã«äŸ¿å©ã§ã¯ãªãã®ã§ãã€ã³ã¿ãŒãããããã«ãŒã¿ãŒã®èåŸã«ããã³ã³ãã¥ãŒã¿ãŒãžã®ã¢ã¯ã»ã¹ãæäŸãããïŒç§ãããããã«ïŒãåã«ã¢ããŒãã®ã«ãŒã¿ãŒãåéããŠã¯ã©ã€ã¢ã³ãã«ã«ãŒã¿ãŒãæ¥ç¶ããŸã圌ãã®çµ¶ãéãªãä»äºã¯ãopenvpnãµãŒããŒã®ã¢ãã¬ã¹ãå€æŽããã ãã§ãã
çè«
ã·ã¹ãã ãã©ã®ããã«æ©èœããããç°¡åã«èããŠã¿ãŸãããã ãããã¯ãŒã¯ã¯ããµãŒããŒïŒå³ã§ã¯ç«æã«ãŒã¿ãŒïŒãšEarthããã³Mercuryã¯ã©ã€ã¢ã³ãã§æ§æãããŠããŸãã ãµãŒããŒã¯ããããããã¯ãŒã¯ããå¥ã®ãããã¯ãŒã¯ãžã®ä»®æ³ãããã¯ãŒã¯æäœããã©ãã£ãã¯æå·åãããã³ãã±ããã«ãŒãã£ã³ã°ãæäŸããŸãã
ãµãŒããŒæäœã®è©³çŽ°ã次ã®å³ã«ç€ºããŸãïŒå³ã¯éåžžã«æ¡ä»¶ä»ãã§ãããäžè¬çãªç解ã®ã¿ãç®çãšããŠãããããã°ã©ã ã³ã³ããŒãã³ãã¯åæ ããŠããŸããïŒã ã¯ã©ã€ã¢ã³ãã¢ãŒãã§ã¯ãopenvpnã¯ãŸã£ããåãããã«æ©èœããŸãããã«ãŒãã£ã³ã°ã¯æäŸããŸããã

ãããã£ãŠãæåã®ã«ãŒã¿ãŒïŒMarsïŒã®èåŸã«ããã¢ãã¬ã¹ç¯å²192.168.1.1-192.168.1.255ãšãEarthã«ãŒã¿ãŒã®èåŸã«ããç¯å²192.168.2.1-192.168.2.255ã®ãããã¯ãŒã¯ããããŸãã OpenVPNã¯ç¹å¥ãªä»®æ³ãããã¯ãŒã¯ã«ãŒãtun0ãäœæããããã«å°çãããã±ããã¯åŸ©å·åããããµãŒããŒïŒããŒã«ã«ã§ã¯ãµãŒããŒã³ã³ãã¥ãŒã¿ãŒãã€ã³ã¿ãŒãããçµç±ã§KlinetskyïŒã«éä¿¡ãããããã§åŸ©å·åãããŠå¿
èŠãªãã³ãã«ãä»ããŠå®å
ã«éä¿¡ãããŸãã
ããšãã°ãPhobosã³ã³ãã¥ãŒã¿ãŒããMoonã³ã³ãã¥ãŒã¿ãŒãžã®ãã±ããã®ééãèããŠã¿ãŸãããã ãã©ãã¹ããã®ãã±ããã¯ããã©ã«ãã²ãŒããŠã§ã€ã«éä¿¡ãããŸã-ç«æãã«ãŒãã£ã³ã°ããŒãã«ã§ãtun0ãã³ãã«ã«éä¿¡ããå¿
èŠããããšèšãããopenvpnã«å°éããŸããããã¯ãMoonãå
¥ã£ãŠãããããã¯ãŒã¯ã®ãã±ãããå°çãžã®ãã³ãã«ã«éä¿¡ãããããšãæ¢ã«ç¥ã£ãŠããŸãã å°çã«å°çãããšããã±ããã¯ããŒã¯ã©ã¯ã«æ¥ç¶ãããæã«å®å
šã«éä¿¡ãããŸãã
ç·Žç¿ãã
ã«ãŒã¿ãOlegã®ãã¡ãŒã ãŠã§ã¢ã§ãã©ãã·ã¥ããikpgãé
眮ããŸãã å€ãã®ãŠãŒã¶ãŒããã®æé ãç¥ã£ãŠããwl500yhã ãšæããŸãã
http://wl500g.info/showthread.php?t=3171ã«éåžžã«è©³çŽ°ã«èšè¿°ãããŠã
ãŸã ã æé 1ã4ãå®éã®ãã¡ãŒã ãŠã§ã¢ãããã³7ãè¿œå ããã±ãŒãžã®ã€ã³ã¹ããŒã«ãå¿
èŠã§ãã
ãã¹ãŠã®æºåãæŽã£ãããipkg install <ããã±ãŒãžå>ã³ãã³ãã§ããã±ãŒãžãã€ã³ã¹ããŒã«ããŸã
- openvpn-ããã¯æšæž¬ããããã§ã:)
- vim-ããã¹ããšãã£ã¿ãŒïŒã·ã§ã«ã«çµã¿èŸŒãŸããŠãããã®ã¯ãäœã«ãå®å
šã«é©ããªãïŒ
- wget-ssl-ãµãŒããŒã«åçå€éšIPãããå Žåãdnsã®ãšã³ããªãæŽæ°ããããã«å¿
èŠã§ãã
ããã±ãŒãžã®ã€ã³ã¹ããŒã«äžã«ãLinuxããå°ãè±ç·ããvpnæ¥ç¶ã®ããŒãçæããŸãã Windowsã§ãããè¡ãæ¹æ³ïŒLinuxoidããããã¯ã§ãã§ã«:)ïŒã¯
Haberã§ãã§ã«è©³çŽ°
ã«è°è«ã
ããŠããŸã
ãããããç¹°ãè¿ãããšã¯æå³ããããŸãã.ca.keyãè¿œå ããå¿
èŠãããã ãã§ããããšãã°ãäžèŠãªãã©ãã·ã¥ãã©ã€ãã«æžã蟌ãŸãããªã©ãããã«ã©ããã«åé€ããå¿
èŠããããŸã ca.crtãšca.keyãç¥ã£ãŠããã®ã§ããŒã ãããã¯ãŒã¯ã«å®å
šã«æ¥ç¶ã§ããã®ã§
ããã©ãã·ã¥ãã©ã€ãã33ã®ããã¯ã®äžã®èžã«å
¥ããŸããããã¯æããã«èšç»ã®äžéšã§ã¯ãããŸããã
蚌ææžãæå
ã«ããå ŽåããµãŒããŒãšãªãã«ãŒã¿ãŒã«èšŒææžãé
眮ããå¿
èŠããããŸãããããã¯éåžžã®ããã¹ããã¡ã€ã«ãªã®ã§ãã«ãŒã¿ãŒã®ããã¹ããšãã£ã¿ãŒã«ã³ããŒããã ãã§ãã
ããšãã°ãtelnetã§ã«ãŒã¿ãŒã«æ¥ç¶ããŸã
CïŒ\> telnet 192.168.1.1
ããã«ïŒ
$ vim /opt/etc/openvpn/keys/ca.crt
次ã«ãiãã¿ã³ãæŒããŠãca.crtãã¡ã€ã«ã®å
容ãæ¿å
¥ããŸãã dh2048.pemãmars.crtãããã³mars.keyãã¡ã€ã«ã§ãåãããšãè¡ããŸãã
ãã®åŸãopenvpnæ§æãã¡ã€ã«ãäœæããå¿
èŠããããŸããå«ãŸããŠãããã¡ã€ã«ã¯ç Žæ£ããŠã次ã®ããã«æ¿å
¥ã§ããŸãã
$ rm /opt/etc/openvpn/openvpn.conf
$ vim /opt/etc/openvpn/openvpn.conf
éçºè
tls-server
ãµãŒããŒ192.168.255.0 255.255.255.0
ifconfig 192.168.255.1 192.168.255.2
client-config-dir ccd
route 192.168.255.0 255.255.255.0 #VPNã®IPç¯å²
route 192.168.2.0 255.255.255.0ïŒå°çã®IPç¯å²
ãã«ãŒã192.168.1.0 255.255.255.0ããæŒããŸã
#Marsã192.168.1.0/24 LANãæã£ãŠããã¯ã©ã€ã¢ã³ãã«èšã
#keys
dh /opt/etc/openvpn/keys/dh1024.pem
ca /opt/etc/openvpn/keys/ca.crt
cert /opt/etc/openvpn/keys/home2.crt
ããŒ/opt/etc/openvpn/keys/home2.key
ïŒäœãããŠãããããããªãéãå€æŽããªãã§ãã ãã
ã¯ã©ã€ã¢ã³ãé
ããŒã1194
ãããUDP
ãŠãŒã¶ãŒãªã
ã°ã«ãŒããªã
comp-lzo
æç¶ãã
æ°žç¶ããŒ
åè©3
log-append /opt/var/log/openvpn/openvpn.log
status /opt/var/log/openvpn/status.log
ããŒãã¢ã©ã€ã10 60
ã¯ã©ã€ã¢ã³ãã®æ§æãé
眮ããããã£ã¬ã¯ããªãäœæããŸã
$ mkdir / opt / etc / openvpn / ccd /
ãã®ãã£ã¬ã¯ããªã«ãçµ±åããããããã¯ãŒã¯ãé
眮ãããã¯ã©ã€ã¢ã³ãã®ãã¡ã€ã«ãäœæããå¿
èŠããããŸãã ç§ãã¡ã®å Žåãããã¯Earthã¯ã©ã€ã¢ã³ãã§ãããEarthãã¡ã€ã«ãäœæããŸã
$ vim / opt / etc / openvpn / ccd / Earth
1è¡ã ãã«ããŸã
iroute 192.168.2.0 255.255.255.0
ãã®è¡ã¯ã192.168.2.0 / 24ãããã¯ãŒã¯ã®ãã±ããã®éä¿¡å
ãopenvpnã«æ瀺ããŸãã
ãã®ãããopenvpnãèµ·åãããŸã§ãèµ·åã¹ã¯ãªãã/opt/etc/init.d/S20openvpnã埮調æŽããããããè¡ãªã¿ãŒã³0ãåé€ããã ãã§ãã
ããã ãã§ããopenvpnãå®è¡ããŸã
/opt/etc/init.d/S20openvpn
ãã¹ãŠåé¡ãªããã°ãnetstat -ul | grep 1194ã¯ã¹ããããçºè¡ããå¿
èŠããããŸã
udp 0 0 *:1194 *:*
ãŸãããã¡ã€ã«/opt/var/log/openvpn/openvpn.logã«ããµãŒããŒãæ£åžžã«èµ·åãããšãããšã³ããªããããŸãã
ãµãŒããŒãæ©èœããŠããã®ã§ããã±ããããã¡ã€ã¢ãŠã©ãŒã«ãééã§ããããã«ããå¿
èŠããããŸãã
ãããè¡ãã«ã¯ïŒ
$iptables -I INPUT -p udp --dport 1194 -j ACCEPT
$iptables -I FORWARD -i br0 -o tun0 -j ACCEPT
$iptables -I FORWARD -i tun0 -o br0 -j ACCEPT
$iptables -I INPUT -i tun0 -p tcp --dport 80 -j ACCEPT
æ¯åã«ãŒã«ãé©çšããã«ã¯ããã¡ã€ã«ã/ usr / local / sbin / post-firewallã«è¿œå ãã/ opt / etc / init.d / S20openvpnã®è¡ãpost-mountã«è¿œå ããŠãã«ãŒã¿ãŒãèµ·åãããã³ã«ãµãŒããŒãèµ·åããããã«ããå¿
èŠããããŸãïŒ$ã¯ã³ãã³ãã©ã€ã³ããã³ããã®å Žåããã¡ã€ã«ã«è¿œå ããå¿
èŠã¯ãããŸããïŒïŒã
ïŒflashfsãžã®å€æŽãæžã蟌ãã®ãå¿ããŸãããïŒïŒ
ããã§ããµãŒããŒã®ã»ããã¢ããã¯ã»ãŒå®äºããŸããã å¯äžã®ããšã¯ããµãŒããŒã«åçIPãããå Žåãã¯ã©ã€ã¢ã³ãããµãŒããŒã«çŸåšã©ã®IPãæã£ãŠãããã確èªããå¿
èŠããããšããããšã§ãã ãã®ããã«ãDDNSãã€ãŸãåçDNSãªã©ããããŸãã Asusã«ã¯ãäžéšã®DDNSãããã€ããŒãçµã¿èŸŒãŸããŠããŸããããã¹ãŠã§ã¯ãããŸããïŒããšãã°
mineãªã©ïŒ ã ãã®ãããã«ãŒã¿ãŒã®IPãå€æŽãããå Žåã«IPãDNSã«æŽæ°ããç°¡åãªã¹ã¯ãªãããäœæããŸããã
#!/bin/sh
IFACE="ppp0"
TMPFILE="/tmp/oldip.txt"
/sbin/ifconfig $IFACE > /dev/null 2>&1
if [ "$?" -ne "0" ]
then
logger "update_ip.sh: Interface $IFACE is down, exiting..."
exit 1
fi
new=`/sbin/ifconfig $IFACE|grep inet\ addr|sed -e 's/.*\ addr:\([0-9\.]*\).*/\1/'`
if [ -f $TMPFILE ]
then
old=`cat $TMPFILE`
else
touch $TMPFILE
old=" "
fi
if [ "$new" != "$old" ]
then
/opt/bin/wget --no-check-certificate "https://dynamicdns.park-your-domain.com/update?host=mars&domain=yourdomain&password=PASSWORD" > /dev/null 2>&1
logger "update_ip.sh: New ip $new detected"
echo $new > $TMPFILE
fi
cronã®ã€ã³ã¹ããŒã«ããã³èšå®æ¹æ³ã«ã€ããŠã¯ã
wl500g.info /
showpost.phpïŒp = 52524ïŒpostcount = 1ã§è©³ãã説æããŠããŸãã
ããã§ãã¯ã©ã€ã¢ã³ãã«æž¡ããŸãã ã¯ã©ã€ã¢ã³ãã®ã€ã³ã¹ããŒã«ã¯ãµãŒããŒãšãŸã£ããåãã§ããå¯äžã®ããšã¯ãã¯ã©ã€ã¢ã³ãããŒïŒca.crtãEarth.crtãEarth.keyãå¿
èŠïŒããã³å¥ã®æ§æãã¡ã€ã«ãè¿œãè¶ãããšã§ãã èµ·åã¹ã¯ãªããã埮調æŽããããšãå¿ããªãã§ãã ããã
ã¯ã©ã€ã¢ã³ãèšå®ããªã¢ãŒããã£ãŒã«ãã«ãµãŒããŒã¢ãã¬ã¹ãæ¿å
¥ããå¿
èŠããããŸã
client
dev tun
proto udp
remote mars.yourdomain 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca /opt/etc/openvpn/keys/ca.crt
cert /opt/etc/openvpn/keys/Earth.crt
key /opt/etc/openvpn/keys/Eartth.key
ns-cert-type server
comp-lzo
verb 3
log-append /opt/var/log/openvpn/openvpn.log
status /opt/var/log/openvpn/status.log
åæ§ã«ãiptablesã«ãŒã«ãé©çšããŸãã
$iptables -I FORWARD -i br0 -o tun0 -j ACCEPT
$iptables -I FORWARD -i tun0 -o br0 -j ACCEPT
$iptables -I INPUT -i tun0 -p tcp --dport 80 -j ACCEPT
ã¯ã©ã€ã¢ã³ãã§openvpnãèµ·åããŸãããµãŒããŒã«æ¥ç¶ããŠç掻ã楜ãã¿ãŸãã æ ç»ãåçãèŠãããšãã§ããLANã®ãããªã²ãŒã ã«åãå»ãããšãã§ããŸãã
ç§ãã§ããªãã£ãããšã¯ãå
éšDNSãµãŒããŒãåæããããšã ãã§ããããã®ãããIPãä»ããŠãããã¯ãŒã¯éã®ã³ã³ãã¥ãŒã¿ãŒã«ã¢ã¯ã»ã¹ããå¿
èŠããããŸãã
ãŸããããã誰ãã«åœ¹ç«ã€ããšãé¡ã£ãŠããŸããç§ã¯ãã®å£®å€§ãªããã¥ã¢ã«ãæžãã®ã«ããããããŠããŸãã
宿é¡ãšããŠãMercuryã³ã³ãã¥ãŒã¿ãŒãæ¥ç¶ããŠãããšãã°gprãå
Œ
±ã®wifiãªã©ãã©ãããã§ãããŒã«ã«ãªãœãŒã¹ã«ã¢ã¯ã»ã¹ã§ããããã«ããŸãã
é«åºŠãªå®¿é¡ãšããŠãæ°Žéãããããã¯ãŒã¯ã«æ¥ç¶ããæ©èœãåãé€ããŠãç«æã®æ§æã®ã¿ãå€æŽããŸãã
ïŒCïŒã€ãŽã¡ã³ãªã»ã³ã³ã2009