แแแแแกแแแแแแแ แงแแแแแก, แแฎแแแฎแแ แฌแแแแแแแฎแ
แแแแแแแแ
แแ แแก TP-Link WDR3500 แ แแฃแขแแ แ แแ Orange Pi Zero H2. แฉแแแ แแแแแแ, แ แแ Orange Pi-แ แฉแแแฃแแแแแกแแแแแ แแแจแแคแ แแก แแแแ แแแแแ แแ แแฃ แ แแแ แแแฎแแแแ, VPN แแแแฃแจแแแแแ แแแแ แฃแแแแแ แ แแฃแขแแ แจแ. แ แแฃแขแแ แแ แงแแแแ firewall แแแ แแแแขแ แ แฃแแแ แแฃแจแแแแแแก แแกแ, แ แแแแ แช แแแ แ. แแ แกแแแ แแแ, แแแแแขแแแแแ แขแแฅแแแแแก แแแแแขแแแ แแแแญแแแ แแแแ แแ แงแแแแแกแแแแก แจแแฃแแฉแแแแแแ แฃแแแ แแงแแก. OpenVPN แแฃแจแแแแก TCP-แแ, TAP แแแแแขแแ แ แฎแแแแก แ แแแแแจแแ (แกแแ แแแ -แฎแแแ).
แแแแแฌแงแแแขแแแแแ
USB-แแ แแแแแแจแแ แแแแก แแแชแแแแ, แแแแแแฌแงแแแขแ แแแแแแแงแแแแแแแ แ แแฃแขแแ แแก แแ แแ แแแ แขแ แแ แแแแแแแแจแแ แ แงแแแแ แฅแแแฅแกแแแ, แ แแแแแกแแช แแฅแแก VPN แฎแแแ Orange Pi-แกแแแ. แแแแแแแก, แ แแ แแแแ แแขแฃแ แ แคแแแแแฃแ แแ แแแแแแแแ แแแแแ แฅแกแแแแแจแ, แ แแแแ แช VPN แกแแ แแแ แ แ แแฃแขแแ แแ. แแแแก แจแแแแแ, แฉแแแ แแแแแกแขแแแแ แแแ แแฃแกแขแแ แแแแแ แกแแ แแแ แแแก Orange Pi-แแ แแ แ แแฃแขแแ แแ แแแงแแแแแ แ แแแแ แกแแฎแแก แแ แแฅแกแ, แ แแแ แแก แงแแแแ แจแแแแแแแแ แแแแจแแ แก แแแแแแแแก แแแ แ แกแแ แแแ แแ, แฎแแแ แแฃ Orange Pi แแแแแแ แแ แแ แแแฃแฌแแแแแแแแ, แแแจแแ แจแแแ แกแแ แแแแ แแ แกแแ แแแ แ. แแ แแแแฆแ HAProxy.
แแกแ แแแแแแแก:
- แแแแแแขแ แฉแแแแแแก
- แแฃ แแแ แ แกแแ แแแ แ แแแฃแฌแแแแแแแแ, แ แแแแ แช แแแ แ, แแแแจแแ แ แแแแแแแก แจแแแ แกแแ แแแ แแ
- แแฃ แจแแกแแซแแแแแแแ, แแแแแแขแ แแแแฆแแแ Orange Pi-แแก แแแแ
- VPN Orange Pi-แแ แจแแคแ แแแก แแแแแขแแแก แแ แแแ แฃแแแแก แแแ แ แแฃแขแแ แจแ
- แ แแฃแขแแ แ แแแ แกแแแฆแแช แแแ แจแ แฃแขแแแก
แแแแฎแแ แชแแแแแแแก แแแแแแแแ
แแกแ แ แแ, แแแฅแแแ, แฉแแแ แแแแฅแแก แแ แ แฅแกแแแ แ แแฃแขแแ แแ - แแแแแแ แ (1) แแ แกแขแฃแแแ แ (2), แแแแแแฃแแ แแแแแแแแกแแแแก แแ แแก OpenVPN แกแแ แแแ แ แแแ แ แแแกแแแแแจแแ แแแแแ.
แฅแกแแแแก แแแแคแแแฃแ แแชแแ
แฉแแแ แแแญแแ แแแแ แแ แแแ แฅแกแแแแก แแแ แจแ แฃแขแแ แแแ แแ แแ แแแ แขแแ, แแแแขแแ แแฅแแแแ 2 VLAN-แก.
แ แแฃแขแแ แแ, Network/Switch แแแแงแแคแแแแแแจแ แจแแฅแแแแแ 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-guest
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-guest
Description="Guest Bridge connection"
Interface=br-guest
Connection=bridge
BindsToInterfaces=(vlan-guest)
IP=dhcp
แฉแแ แแแ แแแขแแแแขแฃแ แ แแแฌแงแแแ แแแฎแแแ แแ แแคแแแแกแแแแก (netctl แฉแแ แแฃแแแ). แแฎแแ แแแแแขแแแ แแแแก แจแแแแแ, Orange Pi แแแแแแแแ แแ แกแแญแแ แ แฅแกแแแแ. แฉแแแ แแแแแแคแแแฃแ แแ แแแ แแแขแแ แคแแแกแแก แแแกแแแแ แแแแก Orange Pi-แแ Static Leases-แจแ แ แแฃแขแแ แแ.
ip addr แจแแฃ
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
แแแแฃแแแกแฎแแแแแ, openvpn แแแจแแแแฃแแ TAP แ แแแแแจแ แแ แกแแ แแแ -แฎแแแ แแแแ แฉแฃแแแแก แแแก แแแขแแ แคแแแกแก แแ แแแฅแขแแฃแ แแ. แแแแกแแแแแก, แ แแ แงแแแแแคแแ แ แแแฃแจแแแก, แแฅแแแ แฃแแแ แแแแแแขแแ แกแแ แแแขแ, แ แแแแแแช แแฃแจแแแแก แแแแจแแ แแก แแแแฅแขแแฃแ แแแแกแแก.
/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 แแแแแแขแแแก แแแแแแแแ แแ แกแแ แแแ แแแแ แแแแแกแชแแแก.
แแแแแแแแ แงแฃแ แแแฆแแแแกแแแแก, แแแกแแกแแแแแแแแแ แฌแแแแแแแแแแแ แแ แจแแกแฌแแ แแแแแ.
แฌแงแแ แ: www.habr.com