Network Address Translation (NAT)
-
Upload
reuben-reilly -
Category
Documents
-
view
30 -
download
1
description
Transcript of Network Address Translation (NAT)
![Page 1: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/1.jpg)
1
Network Address Translation (NAT)
![Page 2: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/2.jpg)
2
Private Network
• Private IP network is an IP network that is not directly connected to the Internet
• IP addresses in a private network can be assigned arbitrarily. – Not registered and not guaranteed to be globally unique
• Generally, private networks use addresses from the following experimental address ranges (non-routable addresses): – 10.0.0.0 – 10.255.255.255– 172.16.0.0 – 172.31.255.255– 192.168.0.0 – 192.168.255.255
![Page 3: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/3.jpg)
3
Private Addresses
H1
R1
H2
10.0.1.3
10.0.1.1
10.0.1.2
H3
R2
H4
10.0.1.310.0.1.2
Private network 1
Internet
H5
10.0.1.1Private network 1
213.168.112.3
128.195.4.119 128.143.71.21
![Page 4: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/4.jpg)
4
Network Address Translation (NAT)
• NAT is a router function where IP addresses (and possibly port numbers) of IP datagrams are replaced at the boundary of a private network
• NAT is a method that enables hosts on private networks to communicate with hosts on the Internet
• NAT is run on routers that connect private networks to the public Internet, to replace the IP address-port pair of an IP packet with another IP address-port pair.
![Page 5: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/5.jpg)
5
Basic operation of NAT
• NAT device has address translation table
H1
private address: 10.0.1.2public address: 128.143.71.21
H5
Privatenetwork
Internet
Source = 10.0.1.2Destination = 213.168.112.3
Source = 128.143.71.21Destination = 213.168.112.3
public address: 213.168.112.3NATdevice
Source = 213.168.112.3Destination = 128.143.71.21
Source = 213.168.112.3Destination = 10.0.1.2
PrivateAddress
PublicAddress
10.0.1.2 128.143.71.21
![Page 6: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/6.jpg)
6
Pooling of IP addresses
• Scenario: Corporate network has many hosts but only a small number of public IP addresses
• NAT solution:– Corporate network is managed with a private address
space– NAT device, located at the boundary between the
corporate network and the public Internet, manages a pool of public IP addresses
– When a host from the corporate network sends an IP datagram to a host in the public Internet, the NAT device picks a public IP address from the address pool, and binds this address to the private address of the host
![Page 7: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/7.jpg)
7
Pooling of IP addresses
H1
private address: 10.0.1.2public address:
H5
Privatenetwork
Internet
Source = 10.0.1.2Destination = 213.168.112.3
Source = 128.143.71.21Destination = 213.168.112.3
public address: 213.168.112.3NATdevice
PrivateAddress
PublicAddress
10.0.1.2
Pool of addresses: 128.143.71.0-128.143.71.30
![Page 8: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/8.jpg)
8
Supporting migration between network service providers
• Scenario: In CIDR, the IP addresses in a corporate network are obtained from the service provider. Changing the service provider requires changing all IP addresses in the network.
• NAT solution:– Assign private addresses to the hosts of the corporate network– NAT device has static address translation entries which bind the
private address of a host to the public address. – Migration to a new network service provider merely requires an update
of the NAT device. The migration is not noticeable to the hosts on the network.
Note:– The difference to the use of NAT with IP address pooling is that the
mapping of public and private IP addresses is static.
![Page 9: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/9.jpg)
9
Supporting migration between network service providers
H1
private address: 10.0.1.2public address: 128.143.71.21
128.195.4.120
Source = 10.0.1.2Destination = 213.168.112.3
NATdevice
PrivateAddress
PublicAddress
10.0.1.2128.143.71.21128.195.4.120
128.143.71.21
128.195.4.120
Source = 128.143.71.21Destination = 213.168.112.3
Source = 128.195.4.120Destination = 213.168.112.3
ISP 2allocates address block
128.195.4.0/24 to privatenetwork:
Privatenetwork
ISP 1allocates address block
128.143.71.0/24 to privatenetwork:
![Page 10: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/10.jpg)
10
IP masquerading
• Also called: Network address and port translation (NAPT), port address translation (PAT).
• Scenario: Single public IP address is mapped to multiple hosts in a private network.
• NAT solution:– Assign private addresses to the hosts of the corporate
network– NAT device modifies the port numbers for outgoing traffic
![Page 11: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/11.jpg)
11
IP masquerading
H1
private address: 10.0.1.2
Private network
Source = 10.0.1.2Source port = 2001
Source = 128.143.71.21Source port = 2100
NATdevice
PrivateAddress
PublicAddress
10.0.1.2/2001 128.143.71.21/2100
10.0.1.3/3020 128.143.71.21/4444
H2
private address: 10.0.1.3
Source = 10.0.1.3Source port = 3020
Internet
Source = 128.143.71.21Destination = 4444
128.143.71.21
![Page 12: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/12.jpg)
12
Load balancing of servers
• Scenario: Balance the load on a set of identical servers, which are accessible from a single IP address
• NAT solution:– Here, the servers are assigned private addresses – NAT device acts as a proxy for requests to the server from
the public network– The NAT device changes the destination IP address of
arriving packets to one of the private addresses for a server
– A sensible strategy for balancing the load of the servers is to assign the addresses of the servers in a round-robin fashion.
![Page 13: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/13.jpg)
13
Load balancing of servers
Private network
Source = 213.168.12.3Destination = 128.143.71.21
NATdevice
PrivateAddress
PublicAddress
10.0.1.2 128.143.71.21
Inside network
10.0.1.4 128.143.71.21
Internet128.143.71.21
S1
S2
S3
10.0.1.4
10.0.1.3
10.0.1.2
PublicAddress
128.195.4.120
Outside network
213.168.12.3
Source = 128.195.4.120Destination = 128.143.71.21
![Page 14: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/14.jpg)
14
Concerns about NAT
• Performance:– Modifying the IP header by changing the IP address
requires that NAT boxes recalculate the IP header checksum
– Modifying port number requires that NAT boxes recalculate TCP checksum
• Fragmentation– Care must be taken that a datagram that is fragmented
before it reaches the NAT device, is not assigned a different IP address or different port numbers for each of the fragments.
![Page 15: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/15.jpg)
15
Concerns about NAT
• End-to-end connectivity:– NAT destroys universal end-to-end reachability of hosts on
the Internet. – A host in the public Internet often cannot initiate
communication to a host in a private network. – The problem is worse, when two hosts that are in a private
network need to communicate with each other.
![Page 16: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/16.jpg)
16
Concerns about NAT
• IP address in application data:– Applications that carry IP addresses in the payload of the
application data generally do not work across a private-public network boundary.
– Some NAT devices inspect the payload of widely used application layer protocols and, if an IP address is detected in the application-layer header or the application payload, translate the address according to the address translation table.
![Page 17: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/17.jpg)
17
NAT and FTP
H1 H2
public address:128.143.72.21
FTP client FTP server
PORT 128.143.72.21/1027
200 PORT command successful
public address:128.195.4.120
RETR myfile
150 Opening data connection
establish data connection
• Normal FTP operation
![Page 18: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/18.jpg)
18
NAT and FTP
• NAT device with FTP support
H1
Private network
NATdevice
H2
private address: 10.0.1.3public address: 128.143.72.21
Internet
FTP client FTP server
PORT 10.0.1.3/1027 PORT 128.143.72.21/1027
200 PORT command successful200 PORT command successful
RETR myfile
establish data connection
RETR myfile
150 Opening data connection150 Opening data connection
establish data connection
![Page 19: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/19.jpg)
19
NAT and FTP
• FTP in passive mode and NAT.
H1
Private network
NATdevice
H2
private address: 10.0.1.3public address: 128.143.72.21
Internet
FTP client FTP server
PASV PASV
Entering Passive Mode128.195.4.120/10001
Entering Passive Mode128.195.4.120/10001
public address:128.195.4.120
Establish data connection Establish data connection
![Page 20: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/20.jpg)
20
Configuring NAT in Linux
• Linux uses the Netfilter/iptable package to add filtering rules to the IP module
Incomingdatagram
filterINPUT
Destinationis local?
filterFORW ARD
natOUTPUT
To application From application
Outgoingdatagram
natPOSTROUTING
(SNAT)
No
Yes filterOUTPUT
natPREROUTING
(DNAT)
![Page 21: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/21.jpg)
21
Configuring NAT with iptable
• First example:iptables –t nat –A POSTROUTING –s 10.0.1.2 –j SNAT --to-source 128.143.71.21
• Pooling of IP addresses:iptables –t nat –A POSTROUTING –s 10.0.1.0/24 –j SNAT --to-source 128.128.71.0–128.143.71.30
• ISP migration: iptables –t nat –R POSTROUTING –s 10.0.1.0/24 –j SNAT --to-source 128.195.4.0–128.195.4.254
• IP masquerading: iptables –t nat –A POSTROUTING –s 10.0.1.0/24 –o eth1 –j MASQUERADE
• Load balancing:iptables -t nat -A PREROUTING -i eth1 -j DNAT --to-destination 10.0.1.2-10.0.1.4
![Page 22: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/22.jpg)
22
Dynamic Host Configuration Protocol (DHCP)
![Page 23: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/23.jpg)
23
Dynamic Assignment of IP addresses
• Dynamic assignment of IP addresses is desirable for several reasons:– IP addresses are assigned on-demand– Avoid manual IP configuration– Support mobility of laptops
![Page 24: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/24.jpg)
24
Solutions for dynamic assignment of IP addresses
• Reverse Address Resolution Protocol (RARP)– Works similar to ARP– Broadcast a request for the IP address associated
with a given MAC address– RARP server responds with an IP address– Only assigns IP address (not the default router and
subnetmask)
RARP
Ethernet MACaddress(48 bit)
ARPIP address(32 bit)
![Page 25: Network Address Translation (NAT)](https://reader035.fdocuments.in/reader035/viewer/2022062304/56813735550346895d9ec469/html5/thumbnails/25.jpg)
25
BOOTP
• BOOTstrap Protocol (BOOTP) • From 1985• Host can configure its IP parameters at boot time. • 3 services.
– IP address assignment.
– Detection of the IP address for a serving machine.
– The name of a file to be loaded and executed by the client machine (boot file name)
– Not only assign IP address, but also default router, network mask, etc. – Sent as UDP messages (UDP Port 67 (server) and 68 (host))– Use limited broadcast address (255.255.255.255):
• These addresses are never forwarded