
У меня есть следующие правила маршрутизации, которые нужно применить, как только появится tun0 (это туннель openvpn). Эти правила помогают вывести некоторых клиентов в моей сети за пределы VPN и напрямую в Интернет. Как лучше всего их применить?
Обновление: Запуск Ubuntu 18.04.
ip route add default via 192.168.8.1 table novpn
ip route add 192.168.1.0/24 dev enp4s0 table novpn
ip rule add from 192.168.1.220 table novpn
iptables -t nat -A POSTROUTING -m iprange --src-range 192.168.1.210-192.168.1.220 -o enp5s0 -j MASQUERADE
решение1
Вы можете запустить команды из конфигурации OpenVPN, например:
script-security 2
up /path/to/routing/script
down /path/to/routing/downscript
из man openvpn:
--up cmd Run command cmd after successful TUN/TAP device open (pre --user UID change). cmd consists of a path to script (or executable program), op‐ tionally followed by arguments. The path and arguments may be single- or double-quoted and/or escaped using a backslash, and should be separated by one or more spaces. The up command is useful for specifying route commands which route IP traffic destined for private subnets which exist at the other end of the VPN connection into the tunnel. For --dev tun execute as: cmd tun_dev tun_mtu link_mtu ifconfig_local_ip ifconfig_re‐ mote_ip [ init | restart ]
решение2
Вы можете попробовать это (добавить в /etc/rc.local
)
ip route add default via 192.168.8.1 table novpn
ip route add 192.168.1.0/24 dev enp4s0 table novpn
ip rule add from 192.168.1.220 table novpn
iptables -t nat -A POSTROUTING -m iprange --src-range 192.168.1.210-192.168.1.220 -o enp5s0 -j MASQUERADE