NAT64 explained

NAT64 is an IPv6 transition mechanism that facilitates communication between IPv6 and IPv4 hosts by using a form of network address translation (NAT). The NAT64 gateway is a translator between IPv4 and IPv6 protocols, for which function it needs at least one IPv4 address and an IPv6 network segment comprising a 32-bit address space. The "well-known prefix" reserved for this service is .

An IPv6 client embeds the IPv4 address it wishes to communicate with using the host part of the IPv6 network segment, resulting in an IPv4-embedded IPv6 addresses (hence the 32-bit address space in the IPv6 network segment), and sends packets to the resulting address. The NAT64 gateway creates a mapping between the IPv6 and the IPv4 addresses, which may be manually configured or determined automatically.

Principle of operation

A simple NAT64 installation may consist of a gateway with two interfaces connected to an IPv4 network and an IPv6 network, respectively. Traffic from the IPv6 network is routed via the gateway which performs all the necessary translations for transferring packets between the two networks. However, the translation is not symmetric,[1] as the IPv6 address space is much larger than the IPv4 address space; thus, one-to-one address mapping is not possible. The gateway maintains IPv6-to-IPv4 address mapping, which may be established with an automatic algorithm (stateless mapping) or with special and manual translations (stateful mapping) when the first packet from the IPv6 network reaches the NAT64 gateway.

Stateless translation is appropriate when a NAT64 translator is used in front of IPv6-only servers to allow them to be reached by remote IPv4-only clients.[2] Stateful translation is suitable for deployment at the client side or at the service provider, allowing IPv6-only client hosts to reach remote IPv4-only nodes.

In general, NAT64 is designed to be used when the communication is initiated by IPv6 hosts. Some mechanisms, including static address mapping, exist to allow the inverse scenario.[3]

Not every type of resource is accessible with NAT64. Protocols that embed IPv4 literal addresses, such as SIP and SDP, FTP, WebRTC, Skype, MSN, and any other content with IPv4 literals are excluded, but a dual-stacked web proxy allows IPv6-only clients to access even web pages with IPv4 literals in URLs. However, 464XLAT, which uses NAT64, allows use of such protocols over IPv6-only connections. For SIP and FTP, the problem can also be solved using an application-level gateway, or using Port Control Protocol with the PREFIX64 extension.

Implementations

Notes and References

  1. Web site: Mavrin. Alex. NAT64 power and limitations. Blog article. 6 January 2014. https://web.archive.org/web/20140108194726/http://blog.apteriks.com/2012/12/08/ipv6-nat64-power-and-limitations/. 8 January 2014. dead.
  2. Web site: NAT64 Address Translation .
  3. Web site: NAT64 Technology: Connecting IPv6 and IPv4 Networks . dead . Cisco . en . 2021-01-12 . 2020-11-12 . https://web.archive.org/web/20201112002031/https://www.cisco.com/c/en/us/products/collateral/ios-nx-os-software/enterprise-ipv6-solution/white_paper_c11-676278.html .
  4. Web site: Introduction to Jool . April 4, 2024 . Jool.
  5. Web site: package: jool-tools-netfilter . April 4, 2024 . OpenWrt wiki.
  6. Web site: Lutchansk. Nathan. Tayga- Simple, no-fuss NAT64 for Linux. April 4, 2024 .
  7. Web site: March 27, 2017 . April 4, 2024 . Supporting IPv6 DNS64/NAT64 Networks.
  8. Web site: Configuring Stateful NAT64 for Handling IPv4 Address Depletion. April 4, 2024 .
  9. Web site: Understand and Configure NAT64. April 4, 2024 .