์๋
ํ์ธ์ ์ฌ๋ฌ๋ถ, ์ต๊ทผ์ ์ฝ์์ต๋๋ค
ํ์คํฌ
TP-Link WDR3500 ๋ผ์ฐํฐ์ Orange Pi Zero H2๊ฐ ์์ต๋๋ค. ์ฐ๋ฆฌ๋ Orange Pi๊ฐ ์ผ๋ฐ ๋ชจ๋์์ ํฐ๋์ ์ํธํํ๊ธฐ๋ฅผ ์ํ๋ฉฐ, ๋ฌธ์ ๊ฐ ๋ฐ์ํ๋ฉด VPN ์ฒ๋ฆฌ๊ฐ ๋ผ์ฐํฐ๋ก ๋ค์ ๋์๊ฐ๋๋ค. ๋ผ์ฐํฐ์ ๋ชจ๋ ๋ฐฉํ๋ฒฝ ์ค์ ์ ์ด์ ๊ณผ ๋์ผํ๊ฒ ์๋ํด์ผ ํฉ๋๋ค. ๊ทธ๋ฆฌ๊ณ ์ผ๋ฐ์ ์ผ๋ก ์ถ๊ฐ ์ฒ ์กฐ๊ฐ์ ์ถ๊ฐํ๋ ๊ฒ์ ๋ชจ๋ ์ฌ๋์๊ฒ ํฌ๋ช ํ๊ณ ๋์ ๋์ง ์์์ผํฉ๋๋ค. OpenVPN์ ๋ธ๋ฆฌ์ง ๋ชจ๋(์๋ฒ-๋ธ๋ฆฌ์ง)์์ TCP, TAP ์ด๋ํฐ๋ฅผ ํตํด ์๋ํฉ๋๋ค.
๊ฒฐ์
USB๋ฅผ ํตํด ์ฐ๊ฒฐํ๋ ๋์ ๋ผ์ฐํฐ์ ํ ํฌํธ๋ฅผ ์ฌ์ฉํ๊ณ VPN ๋ธ๋ฆฌ์ง๊ฐ ์๋ ๋ชจ๋ ์๋ธ๋ท์ Orange Pi์ ์ฐ๊ฒฐํ๊ธฐ๋ก ๊ฒฐ์ ํ์ต๋๋ค. ์ฒ ์กฐ๊ฐ์ด ๋ผ์ฐํฐ์ VPN ์๋ฒ์ ๋์ผํ ๋คํธ์ํฌ์ ๋ฌผ๋ฆฌ์ ์ผ๋ก ๋งค๋ฌ๋ ค ์๋ ๊ฒ์ผ๋ก ๋ํ๋ฌ์ต๋๋ค. ๊ทธ๋ฐ ๋ค์ Orange Pi์์ ์ ํํ ๋์ผํ ์๋ฒ๋ฅผ ์ฌ๋ฆฌ๊ณ ๋ผ์ฐํฐ์์ ์ผ์ข ์ ํ๋ก์๋ฅผ ์ค์ ํ์ฌ ๋ค์ด์ค๋ ๋ชจ๋ ์ฐ๊ฒฐ์ ์ธ๋ถ ์๋ฒ๋ก ๋ณด๋ด๊ณ Orange Pi๊ฐ ์ฃฝ๊ฑฐ๋ ์ฌ์ฉํ ์ ์๋ ๊ฒฝ์ฐ ๋ด๋ถ ํด๋ฐฑ ์๋ฒ. HAProxy๋ฅผ ์ฌ์ฉํ์ต๋๋ค.
๋ค์๊ณผ ๊ฐ์ด ๋ฐํ์ก์ต๋๋ค.
- ๊ณ ๊ฐ ๋์ฐฉ
- ์ธ๋ถ ์๋ฒ๋ฅผ ์ฌ์ฉํ ์ ์๋ ๊ฒฝ์ฐ - ์ด์ ๊ณผ ๊ฐ์ด ๋ด๋ถ ์๋ฒ๋ก ์ฐ๊ฒฐ๋ฉ๋๋ค.
- ๊ฐ๋ฅํ ๊ฒฝ์ฐ ํด๋ผ์ด์ธํธ๋ Orange Pi์์ ์๋ฝํฉ๋๋ค.
- Orange Pi์ VPN์ ํจํท์ ํด๋ ํ๊ณ ๋ผ์ฐํฐ๋ก ๋ค์ ๋ณด๋ ๋๋ค.
- ๋ผ์ฐํฐ๋ ๊ทธ๋ค์ ์ด๋๊ฐ๋ก ๋ผ์ฐํ ํฉ๋๋ค.
๊ตฌํ ์
๋ฐ๋ผ์ ๋ผ์ฐํฐ์ ๋ ๊ฐ์ ๋คํธ์ํฌ๊ฐ ์๋ค๊ณ ๊ฐ์ ํด ๋ณด๊ฒ ์ต๋๋ค. main(1) ๋ฐ guest(2), ๊ฐ๊ฐ ์ธ๋ถ์์ ์ฐ๊ฒฐํ๊ธฐ ์ํ OpenVPN ์๋ฒ๊ฐ ์์ต๋๋ค.
๋คํธ์ํฌ ๊ตฌ์ฑ
ํ๋์ ํฌํธ๋ฅผ ํตํด ๋ ๋คํธ์ํฌ๋ฅผ ํต๊ณผํด์ผ ํ๋ฏ๋ก 2๊ฐ์ VLAN์ ์์ฑํฉ๋๋ค.
๋ผ์ฐํฐ์ ๋คํธ์ํฌ/์ค์์น ์น์ ์์ VLAN(์: 1 ๋ฐ 2)์ ๋ง๋ค๊ณ ์ํ๋ ํฌํธ์์ ํ๊ทธ ๋ชจ๋๋ก ์ผ๊ณ ์๋ก ๋ง๋ eth0.1 ๋ฐ eth0.2๋ฅผ ์ ์ ํ ๋คํธ์ํฌ์ ์ถ๊ฐํฉ๋๋ค(์: ์๋ฅผ ๋ค์ด brigde์ ์ถ๊ฐ).
Orange Pi์์ ๋ ๊ฐ์ VLAN ์ธํฐํ์ด์ค๋ฅผ ์์ฑํฉ๋๋ค(์ ๋ Archlinux ARM + netctl์ด ์์ต๋๋ค).
/etc/netctl/vlan-main
Description='Main VLAN on eth0'
Interface=vlan-main
Connection=vlan
BindsToInterfaces=eth0
VLANID=1
IP=no
/etc/netctl/vlan-๊ฒ์คํธ
Description='Guest VLAN on eth0'
Interface=vlan-guest
Connection=vlan
BindsToInterfaces=eth0
VLANID=2
IP=no
๊ทธ๋ฆฌ๊ณ ์ฆ์ ๋ ๊ฐ์ ๋ธ๋ฆฌ์ง๋ฅผ ๋ง๋ญ๋๋ค.
/etc/netctl/br-main
Description="Main Bridge connection"
Interface=br-main
Connection=bridge
BindsToInterfaces=(vlan-main)
IP=dhcp
/etc/netctl/br-๊ฒ์คํธ
Description="Guest Bridge connection"
Interface=br-guest
Connection=bridge
BindsToInterfaces=(vlan-guest)
IP=dhcp
4๊ฐ ํ๋กํ ๋ชจ๋์ ๋ํด ์๋ ์์์ ํ์ฑํํฉ๋๋ค(netctl enable). ์ด์ ์ฌ๋ถํ ํ Orange Pi๋ ๋ ๊ฐ์ ํ์ ๋คํธ์ํฌ์์ ์ค๋จ๋ฉ๋๋ค. Orange Pi์ ์ธํฐํ์ด์ค ์ฃผ์๋ ๋ผ์ฐํฐ์ ์ ์ ์๋์์ ๊ตฌ์ฑ๋ฉ๋๋ค.
IP ์ฃผ์ ํ์
4: vlan-main@eth0: <BROADCAST,MULTICAST,PROMISC,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-main state UP group default qlen 1000
link/ether 02:42:f0:f8:23:c8 brd ff:ff:ff:ff:ff:ff
inet6 fe80::42:f0ff:fef8:23c8/64 scope link
valid_lft forever preferred_lft forever
5: vlan-guest@eth0: <BROADCAST,MULTICAST,PROMISC,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-guest state UP group default qlen 1000
link/ether 02:42:f0:f8:23:c8 brd ff:ff:ff:ff:ff:ff
inet6 fe80::42:f0ff:fef8:23c8/64 scope link
valid_lft forever preferred_lft forever
6: br-main: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
link/ether 52:c7:0f:89:71:6e brd ff:ff:ff:ff:ff:ff
inet 192.168.1.3/24 brd 192.168.1.255 scope global dynamic noprefixroute br-main
valid_lft 29379sec preferred_lft 21439sec
inet6 fe80::50c7:fff:fe89:716e/64 scope link
valid_lft forever preferred_lft forever
7: br-guest: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
link/ether ee:ea:19:31:34:32 brd ff:ff:ff:ff:ff:ff
inet 192.168.2.3/24 brd 192.168.2.255 scope global br-guest
valid_lft forever preferred_lft forever
inet6 fe80::ecea:19ff:fe31:3432/64 scope link
valid_lft forever preferred_lft forever
VPN ์ค์
๊ทธ๋ฐ ๋ค์ OpenVPN ์ค์ ๊ณผ ๋ผ์ฐํฐ์ ํค๋ฅผ ๋ณต์ฌํฉ๋๋ค. ์ค์ ์ ์ผ๋ฐ์ ์ผ๋ก ๋ค์์์ ๊ฐ์ ธ์ฌ ์ ์์ต๋๋ค. /tmp/etc/openvpn*.conf
๊ธฐ๋ณธ์ ์ผ๋ก TAP ๋ชจ๋์ server-bridge์์ ์คํ๋๋ openvpn์ ์ธํฐํ์ด์ค๋ฅผ ๋นํ์ฑ ์ํ๋ก ์ ์งํฉ๋๋ค. ์๋ํ๊ฒ ํ๋ ค๋ฉด ์ฐ๊ฒฐ์ด ํ์ฑํ๋ ๋ ์คํ๋๋ ์คํฌ๋ฆฝํธ๋ฅผ ์ถ๊ฐํด์ผ ํฉ๋๋ค.
/etc/openvpn/main.conf
dev vpn-main
dev-type tap
client-to-client
persist-key
persist-tun
ca /etc/openvpn/main/ca.crt
cert /etc/openvpn/main/main.crt
cipher AES-256-CBC
comp-lzo yes
dh /etc/openvpn/main/dh2048.pem
ifconfig-pool-persist /etc/openvpn/ipp_main.txt
keepalive 10 60
key /etc/openvpn/main/main.key
port 443
proto tcp
push "redirect-gateway"
push "dhcp-option DNS 192.168.1.1"
server-bridge 192.168.1.3 255.255.255.0 192.168.1.200 192.168.1.229
status /tmp/openvpn.main.status
verb 3
setenv profile_name main
script-security 2
up /etc/openvpn/vpn-up.sh
/etc/openvpn/vpn-up.sh
#!/bin/sh
ifconfig vpn-${profile_name} up
brctl addif br-${profile_name} vpn-${profile_name}
๊ฒฐ๊ณผ์ ์ผ๋ก ์ฐ๊ฒฐ์ด ๋ฐ์ํ๋ ์ฆ์ vpn-main ์ธํฐํ์ด์ค๊ฐ br-main์ ์ถ๊ฐ๋ฉ๋๋ค. ๊ฒ์คํธ ๊ทธ๋ฆฌ๋์ ๊ฒฝ์ฐ ์๋ฒ ๋ธ๋ฆฌ์ง์ ์ธํฐํ์ด์ค ์ด๋ฆ ๋ฐ ์ฃผ์๊น์ง ์ ์ฌํฉ๋๋ค.
์ธ๋ถ ์์ฒญ ๋ผ์ฐํ ๋ฐ ํ๋ก์
์ด ๋จ๊ณ์์ Orange Pi๋ ์ด๋ฏธ ์ฐ๊ฒฐ์ ์๋ฝํ๊ณ ํด๋ผ์ด์ธํธ๋ฅผ ์ํ๋ ๋คํธ์ํฌ๋ก ํ์ฉํ ์ ์์ต๋๋ค. ๋ผ์ฐํฐ์์ ๋ค์ด์ค๋ ์ฐ๊ฒฐ์ ํ๋ก์ฑ์ ๊ตฌ์ฑํด์ผ ํฉ๋๋ค.
๋ผ์ฐํฐ VPN ์๋ฒ๋ฅผ ๋ค๋ฅธ ํฌํธ๋ก ์ ์กํ๊ณ ๋ผ์ฐํฐ์ HAProxy๋ฅผ ์ค์นํ๊ณ ๋ค์์ ๊ตฌ์ฑํฉ๋๋ค.
/etc/haproxy.cfg
global
maxconn 256
uid 0
gid 0
daemon
defaults
retries 1
contimeout 1000
option splice-auto
listen guest_vpn
bind :444
mode tcp
server 0-orange 192.168.2.3:444 check
server 1-local 127.0.0.1:4444 check backup
listen main_vpn
bind :443
mode tcp
server 0-orange 192.168.1.3:443 check
server 1-local 127.0.0.1:4443 check backup
์ฆ๊ธฐ๋ค
๋ชจ๋ ๊ฒ์ด ๊ณํ๋๋ก ์งํ๋๋ฉด ํด๋ผ์ด์ธํธ๋ Orange Pi๋ก ์ด๋ํ๊ณ ๋ผ์ฐํฐ ํ๋ก์ธ์๋ ๋ ์ด์ ๊ฐ์ด๋์ง ์์ผ๋ฉฐ VPN ์๋๋ ํฌ๊ฒ ์ฆ๊ฐํฉ๋๋ค. ๋์์ ๋ผ์ฐํฐ์ ๋ฑ๋ก๋ ๋ชจ๋ ๋คํธ์ํฌ ๊ท์น์ ๊ด๋ จ์ฑ์ ์ ์งํฉ๋๋ค. Orange Pi์์ ์ฌ๊ณ ๊ฐ ๋ฐ์ํ๋ฉด ๋จ์ด์ง๊ณ HAProxy๋ ํด๋ผ์ด์ธํธ๋ฅผ ๋ก์ปฌ ์๋ฒ์ ๋ํํฉ๋๋ค.
๊ด์ฌ์ ๊ฐ์ ธ ์ฃผ์
์ ๊ฐ์ฌํฉ๋๋ค. ์ ์ ๋ฐ ์์ ์ ํ์ํฉ๋๋ค.
์ถ์ฒ : habr.com