NAT Traversal (NAT-T) » History » Version 6

Noel Kuntze, 16.02.2016 23:57

1 2 Martin Willi
h1. NAT Traversal
2 1 Martin Willi
3 2 Martin Willi
4 2 Martin Willi
h2. IKEv1
5 1 Martin Willi
6 5 Tobias Brunner
Before [[5.0.0]], NAT discovery and traversal had to be enabled by setting _nat_traversal=yes_ in the [[ConfigSetupSection|config setup]] section of [[IpsecConf|ipsec.conf]]. Otherwise strongSwan 4.x's IKEv1 pluto daemon would not accept incoming IKE packets with a UDP source port different from 500. Since [[5.0.0]] IKEv1 traffic is handled by the charon daemon which supports NAT traversal according to "RFC 3947": without enabling it explicitly.
7 2 Martin Willi
8 1 Martin Willi
h2. IKEv2
9 1 Martin Willi
10 5 Tobias Brunner
The IKEv2 protocol includes NAT traversal in the core standard, but it's optional to implement. strongSwan implements it, and there is no configuration involved. The @NAT_DETECTION_SOURCE/DESTINATION_IP@ notifications included in the @IKE_SA_INIT@ exchange indicate the peers NAT-T capability and if a NAT situation is detected, UDP encapsulation is activated for IPsec.
11 3 Andreas Steffen
12 3 Andreas Steffen
strongSwan starts sending keep-alive packets if it is behind a NAT router to keep the mappings on the NAT device intact.
13 6 Noel Kuntze
14 6 Noel Kuntze
NAT traversal cannot be disabled in the charon daemon. If you don't like automatic port floating to UDP/4500 due to the MOBIKE protocol (RFC 4555) which happens even if no NAT situation exists then you can disable MOBIKE by adding
15 6 Noel Kuntze
16 6 Noel Kuntze
17 6 Noel Kuntze
18 6 Noel Kuntze
to ipsec.conf in the connection definition.
19 6 Noel Kuntze