IPsec/IKEv2-based VPN software for Linux
# sudo brctl addbr br0
# sudo brctl addif eth0 # sudo ip addr add 192.168.0.100/24 brd + dev br0 # sudo ip -6 addr add 2001:db8::100/64 dev br0 # sudo ip route add default via 192.168.0.10 # sudo ip -6 route add default via 2001:db8::10 |
# sudo ip addr add 10.0.0.1/24 brd + dev eth0
# sudo ip -6 addr add 2001:db8:10::1/64 dev eth0 # sudo ip addr add 192.168.0.10/24 brd + dev eth1 # sudo ip -6 addr add 2001:db8::10/64 dev eth1 # sudo sysctl net.ipv4.ip_forward=1 # sudo sysctl net.ipv6.conf.all.forwarding=1 Forward packets destinated to 10.0.0.1:500(Router1) to 192.168.0.100:500(VPN Gateway). # sudo iptables -t nat -A PREROUTING -p udp --dst 10.0.0.1 --dport 500 -j DNAT --to-destination 192.168.0.100:500 Forward packets destinated to 10.0.0.1:4500(Router1) to 192.168.0.100:4500(VPN Gateway). # sudo iptables -t nat -A PREROUTING -p udp --dst 10.0.0.1 --dport 4500 -j DNAT --to-destination 192.168.0.100:4500 Forward packets destinated to [2001:db8:10::1]:500(Router1) to [2001:db8::1]:500(VPN Gateway). # sudo ip6tables -t nat -A PREROUTING -p udp --dst 2001:db8:10::1 --dport 500 -j DNAT --to-destination [2001:db8::100]:500 Forward packets destinated to [2001:db8:10::1]:4500(Router1) to [2001:db8::1]:4500(VPN Gateway). # sudo ip6tables -t nat -A PREROUTING -p udp --dst 2001:db8:10::1 --dport 4500 -j DNAT --to-destination [2001:db8::100]:4500 |
# sudo ip addr add 10.0.0.10/24 brd + dev eth0
# sudo ip -6 addr add 2001:db8:10::10/64 dev eth0 # sudo ip addr add 192.168.2.1/24 brd + dev eth1 # sudo ip -6 addr add 2001:db8:2::1/64 dev eth1 # sudo sysctl net.ipv4.ip_forward=1 # sudo sysctl net.ipv6.conf.all.forwarding=1 Exec NAPT for packets from private network(192.168.2.0/24). # sudo iptables -t -nat -A POSTROUTING -o eth0 -j MASQUERADE --random -s 192.168.2.0/24 Exec NAPT for packets from private network(2001:db8:2::/64). # sudo ip6tables -t -nat -A POSTROUTING -o eth0 -j MASQUERADE --random -s 2001:db8:2::/64 |
# sudo apt-get install radvd
# sudo touch /etc/radvd.conf # sudo vi /etc/radvd.conf |
interface eth1
{ AdvSendAdvert on; MaxRtrAdvInterval 60; prefix 2001:0db8:2::/64 { }; }; |
# sudo /etc/init.d/radvd restart |
# sudo ip addr add 192.168.0.101/24 brd + dev eth0
# sudo ip -6 addr add 2001:db8::101/64 dev eth0 |
auto eth0
iface eth0 inet manual up ip link set dev eth0 promisc on auto br0 iface br0 inet static address 192.168.0.100 network 192.168.0.0 netmask 255.255.255.0 gateway 192.168.0.10 broadcast 192.168.0.255 bridge_ports eth0 bridge_stp off bridge_maxwait 10 iface br0 inet6 static address 2001:db8::100 netmask 64 gateway 2001:db8::10 |
- VPN Configuration[Tab] > Edit VPN Realm(Save, Add, etc.)[Left-Tree]: Click this tree node and show Edit VPN Realm(Save, Add, Remove, or Load) pane.
- Click Add VPN Realm button.
- Add a VPN Realm[Dialog]: Enter the following, then click OK button.
Realm ID: 10
Realm Name: "Example VPN"
Description: "Config for Example VPN."
Mode: Bridge
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> VPN Interface[Left-Tree]:
Click this tree node and show VPN
Tunnel/TAP Interface pane.
- Enter or select the following.
Internal Address Type: Unnumbered(for bridging)
Linked Bridge Name: br0
- If Remote Access Client communicates with hosts on other subnets like 192.168.1.0/24, enter the following router's addresses. VPN Gateway will forward decrypted packets destinated to other subnets to the router(192.168.0.1 and 2011:db8::1).
Internal Gateway's Address (optional) > IPv4: 192.168.0.1
Internal Gateway's Address (optional) > IPv6: 2001:db8::1
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> Network Interface[Left-Tree]:
Click this tree node and show Network
Interface pane.
- Uncheck Use default route and enter the followings.
Primary interface:
- Name: Select br0 as a source interface
and IPv4 and IPv6.
- Uncheck Destination NAT Address (MOBIKE Responder) and enter the followings.
Primary interface:
Dest NAT IPv4 Address: 10.0.0.1 (Router1's global address[eth0])
Dest NAT IPv6 Address: 2001:db8:10::1 (Router1's global address[eth0])
By the above settings, a remote client is notified of a Router1's global address as a MOBIKE additional address.
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> Service[Left-Tree]:
Click this tree node and show Service pane.
- Network Deployment: Select Hub(Concentrator) Node.
- Remote Configuration(IKEv2): Select Remote Configuration Server.
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> Service[Left-Tree]
> Remote Config Server[Left-Tree]:
Click this tree node and show Remote Config Server(IKEv2) pane.
- Remote Config Server(IKEv2)[Pane]
> Internal Address Pool[Tab]:
Click Add Address Pool button.
- Add a New Address Pool[Dialog]:
Enter the following, then click OK button.
Address Type: IPv4 Address Range
IPv4 Address Range: 192.168.0.20 - 192.168.0.30
Similarly, add the following for IPv6.
Address Type: IPv6 Address Range
IPv6 Address Range: 2001:db8::20 - 2001:db8::2a
- Remote Config Server(IKEv2)[Pane]
> Internal Route Map[Tab]:
Enter the following as Internal router's addresses.
Gateway Address > IPv4: 192.168.0.1
Gateway Address > IPv6: 2001:db8::1
- Click Add Destination Network button.
Add a New Internal Route[Dialog]:
Enter the following, then click OK button.
IP Version: IPv4
Destination IPv4 Network: 192.168.1.0
Netmask: 255.255.255.0
Similarly, add the following internal route for IPv6.
IP Version: IPv6
Destination IPv6 Network: 2001:db8:1::
Prefix: 64
- Remote Config Server(IKEv2)[Pane]
> Internal DNS[Tab]:
Enter the following as Internal DNS server's addresses.
DNS Server's Address > IPv4: 192.168.0.101
DNS Server's Address > IPv6: 2001:db8::101
- Click Add DNS Suffix button.
Add a New DNS Suffix[Dialog]:
Enter the following, then click OK button.
DNS Suffix: .example.com
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> My Key Store[Left-Tree]:
Click this tree node and show My Key Store pane.
- Enter the following.
Authentication Method: RSA Signature(RSA-Sig)
My ID Type: auto
Key Format: PEM(Base64-encoding) - File
My Certificate(X.509, *.pem): gateway1.example.com-cert.pem
RSA private key(*.pem): gateway1.example.com-pkey.pem
RSA Private Key's Password: himitsu
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> Peers' Key Store[Left-Tree]:
Click this tree node and show Peers Key Store pane.
- Click Add Peer's Key/Password button.
Add a New Peer's Key[Dialog]: Enter the following, then click OK button.
Peer ID Type: IKEv2: Host Name(FQDN)
Peer ID: remoteclient1.example.com
Pre-Shared Key(PSK): 1234567890
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Bridge)[Left-Tree]
> CA Certificate/CRL[Left-Tree]:
Click this tree node and show CA Certificate/Certificate
Revocation List(CRL) pane.
- Enter the following.
Certificate/CRL Format: PEM(Base64-encoding) - File
CA Certificates(X.509, *.pem): TestCA-cacert.pem
- VPN Configuration[Tab] > Edit VPN Realm(Save, Add, etc.)[Left-Tree]: Click this tree node and show Edit VPN Realm(Save, Add, Remove, or Load) pane.
- Click Save Configuration button.
- VPN Configuration[Tab] > Edit VPN Realm(Save, Add, etc.)[Left-Tree]: Click this tree node and show Edit VPN Realm(Save, Add, Remove, or Load) pane.
- Click Add VPN Realm button.
Add a VPN Realm[Dialog]:
Enter the following, then click OK button.
Realm ID: 10
Realm Name: "Example VPN"
Description: "Config for Example VPN."
Mode: Remote Client
- VPN Configuration[Tab] > VPN Realms[Left-Tree] > 10:Example VPN(Remote Client)[Left-Tree] > Destination[Left-Tree]: Click this tree node and show Destination (Concentrator / Gateway) pane.
- Enter the following. This expects a public DNS server to provide both IPv4 and IPv6 addresses as gateway1.example.com's addresses (Router1's global addresses). Also, you can edit /etc/hosts file.
Destination Address: Host Name(FQDN) and gateway1.example.com
Of course, you can specify an VPN Gateway's IPv4 or IPv6 address (Actually, it is a Router1's public IPv4 or IPv6 address).
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> My Key Store[Left-Tree]:
Click this tree node and show My Key
Store pane.
- Enter the following.
Authentication Method: Pre-Shared Key(PSK)
My ID Type: Host Name(FQDN)
My ID: remoteclient1.example.com
Pre-Shared Key(PSK): 1234567890
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> CA Certificate/CRL[Left-Tree]:
Click this tree node and show CA Certificate/Certificate
Revocation List(CRL) pane.
- Enter the following.
Imported Certificate/CRL Format: PEM(Base64-encoding) - File
CA Certificates(X.509, *.pem): TestCA-cacert.pem
- VPN Configuration[Tab]
> Edit VPN Realm(Save, Add, etc.)[Left-Tree]:
Click this tree node and show Edit
VPN Realm(Save, Add, Remove, or Load) pane.
- Click Save Configuration button.
- VPN Configuration[Tab] > Edit VPN Realm(Save, Add, etc.)[Left-Tree]: Click this tree node and show Edit VPN Realm(Save, Add, Remove, or Load) pane.
- Click Add VPN Realm button.
Add a VPN Realm[Dialog]:
Enter the following, then click OK button.
Realm ID: 10
Realm Name: "Example VPN"
Description: "Config for Example VPN."
Mode: Remote Client
- Check Advanced Settings. (Version: 0.2.b1-021 or later)
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> VPN Interface[Left-Tree]:
Click this tree node and show VPN
Tunnel/TAP Interface pane.
- Enter the following.
Internal Address Type: Auto(IKEv2 Configuration)
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> Network Interface[Left-Tree]:
Click this tree node and show Network
Interface pane.
- Check Use default route.
or
- Uncheck Use default route and enter the followings.
Primary interface:
- Name: Select eth0 as a source interface.
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> Service[Left-Tree]:
Click this tree node and show Service pane.
- Network Deployment: Select Spoke Node/Other.
- Remote Configuration(IKEv2): Select Remote Access Client.
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> My Key Store[Left-Tree]:
Click this tree node and show My Key
Store pane.
- Enter the following.
Authentication Method: Pre-Shared Key(PSK)
My ID Type: Host Name(FQDN)
My ID: remoteclient1.example.com
Pre-Shared Key(PSK): 1234567890
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> Peers[Left-Tree]: Click
this tree node and show Peers pane.
- Click Add Peer button.
Add a New Peer[Dialog]:
Enter the following, then click OK button.
Peer ID Type: IKEv2: Host Name(FQDN)
Peer ID: gateway1.example.com
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> Peers[Left-Tree] >
gateway1.example.com(FQDN)[Left-Tree]:
Click this tree node and show Peer: gateway1.example.com(FQDN) pane.
- Enter the following.
Peer's Address: IPv6 and 2001:db8:10::1 (Router1's global address[eth0])
Secondary IP Address: IPv4 and 10.0.0.1 (Router1's global address[eth0])
This peer's Network Deployment: Hub(Concentrator) Node
- VPN Configuration[Tab]
> VPN Realms[Left-Tree]
> 10:Example VPN(Remote Client)[Left-Tree]
> CA Certificate/CRL[Left-Tree]:
Click this tree node and show CA Certificate/Certificate
Revocation List(CRL) pane.
- Enter the following.
Imported Certificate/CRL Format: PEM(Base64-encoding) - File
CA Certificates(X.509, *.pem): TestCA-cacert.pem
- VPN Configuration[Tab]
> Edit VPN Realm(Save, Add, etc.)[Left-Tree]:
Click this tree node and show Edit
VPN Realm(Save, Add, Remove, or Load) pane.
- Click Save Configuration button.