La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

Translation d’adresse NAT

Présentations similaires


Présentation au sujet: "Translation d’adresse NAT"— Transcription de la présentation:

1 Translation d’adresse NAT
Principes d’adressage public/privé Pénurie d’adresses officielles Sécurité RFC 1918 ( ? prefix) ( ? prefix) ( ? prefix) Discard des trames par 1er routeur Internet traversé Solution : translation d’adresses … mais : Important : Sensibilité des applications …

2 Network AddressTranslation
Dans sa plus simple configuration, le NAT s’opère sur un routeur à 2 interfaces : une “ inside ” avec des adresses non autorisées ou non routées sur Internet qui doivent donc être translatées (converties) en adresses légales (officielles, publiques) avant de sortir vers l’extérieur (par la seconde interface : “ outside ”). NAT est défini notamment dans le RFC 1631

3

4 Inside NAT addressing

5 NAT outside addressing

6 Inside local; Configured IP address assigned to a host on the inside network. Address may be globally unique, allocated out of the private address space defined in RFC 1918, or might be officially allocated to another organization. Inside global; The IP address of an inside host as it appears to the outside network, "Translated IP Address." Addresses can be allocated from a globally unique address space, typically provided by the ISP (if the enterprise is connected to the global Internet). Outside local; The IP address of an outside host as it appears to the inside network. Outside global; The configured IP address assigned to a host in the outside network.

7 Principales caractéristiques
Static Address Translation Etablissement d’un mapping un-pour-un entre adresses locales and globales Dynamic Address Translation Etablissement d’un dynamic mapping entre adresses locales and globales Définition d’un pool d’adresses pour l’allocation des global addresses.Intéressant lorsque le nombre d’adresses officielles est inférieur au nombre d’adresses locales (fréquent). Match Host Affecter la même Host portion d’une IP Address et translater seulement le Network prefix. Utile pour identifier les users.

8 Port Address Translation (PAT)
Several internal addresses can be NATed to only one or a few external addresses by using a feature called Port Address Translation (PAT) which is also referred to as "overload," a subset of NAT functionality. PAT uses unique source port numbers on the Inside Global IP address to distinguish between translations. Because the port number is encoded in 16 bits, the total number could theoretically be as high as 65,536 per IP address. PAT will attempt to preserve the original source port, if this source port is already allocated PAT will attempt to find the first available port number starting from the beginning of the appropriate port group 0-511, , or If there is still no port available from the appropriate group and more than one IP address is configured, PAT will move to the next IP address and try to allocate the original source port again. This continues until it runs out of available ports and IP addresses.

9 Concepts PAT

10 Destination Address Rotary Translation
A dynamic form of destination translation can be configured for some outside-to-inside traffic. Once a mapping is set up, a destination address matching one of those on an access list will be replaced with an address from a rotary pool. Allocation is done in a round-robin basis, performed only when a new connection is opened from the outside to the inside. All non-TCP traffic is passed untranslated (unless other translations are in effect). This feature was designed to provide protocol translation load distribution. It is not designed to be used as a substitute technology for Cisco's LocalDirector product. Destination address rotary translation should not be used to provide Web service load balancing because it knows nothing about service availability. As a result, if a Web server were to become offline, the destination address rotary translation feature would continue to send requests to the downed server.

11

12 Limites du NAT Traffic Types/Applications supportés Tout TCP/UDP traffic qui ne comporte pas de source and/or destination IP addresses dans la partie application de la trame. + Applications avec « verrue NAT » HTTP TFTP telnet … Problème résiduel: Netmeeting v3 …

13 Conclusions: Eviter NAT au sein d’une même entreprise Cas des fusions de 2 sociétés Pérennité de connectivité ?? Redéfinition d’un nouveau plan d’adressage : lourd mais préférable

14 Cisco Configuration Commands
Interface Configuration Commands ip nat { inside | outside } Interfaces need to be marked whether they are on the inside or the outside. Global Configuration Commands: Defining a pool ip nat pool <name> <start-ip> <end-ip> { netmask <netmask> | prefix-length <prefix-length> } [type {rotary}] Defines a pool of addresses using start address, end address, and netmask. These addresses will be allocated as needed.

15 Enabling translation of inside source addresses
ip nat inside source { list <acl> pool <name> [overload] | static <local-ip><global-ip> } The first form enables dynamic translation. Packets from addresses that match those on the simple access list are translated using global addresses allocated from the named pool. The optional keyword overload enables port translation for UDP and TCP. The term overload is equivalent to Port Address Translation (PAT). The second form of the command sets up a single static translation.

16 Enabling translation of inside destination addresses
ip nat inside destination { list <acl> pool <name> | static <global-ip> <local-ip> } Commande similaire à la « source translation command ». For dynamic destination translation to make any sense, the pool should be a rotary-type pool. (option rotary dans l’IP nat pool correspondant). Mais quel besoin ? ? ? voir le dernier exemple de ce chapitre …

17 Enabling translation of outside source addresses
ip nat outside source { list <acl> pool <name> | static <global-ip> <local-ip> } The first form (list..pool..) enables dynamic translation. Packets from addresses that match those on the simple access list are translated using local addresses allocated from the named pool. The second form (static) of the command sets up a single static translation. Quel besoin : par exemple cas d’un réseau outside de même adresse réseau que le réseau inside …cas d’une société qui n’aurait pas choisi des adresses officielles ou conformes au RFC1918…

18 Configuring translation timeouts
ip nat translation timeout <seconds> Dynamic translations time out after a period of non-use. When port translation is not configured, translation entries time out after 24 hours. This time can be adjusted with the above command or the following variations: ip nat translation udp-timeout <seconds> ip nat translation dns-timeout <seconds> ip nat translation tcp-timeout <seconds> When port translation is configured, there is finer control over translation entry timeouts, because each entry contains more context about the traffic using it. Non-DNS UDP translations time out after 5 minutes; DNS times out in 1 minute. TCP translations time out after 24 hours.

19 Exec Commands Show active translations show ip nat translations [ verbose ] Show translation statistics show ip nat statistics Clearing dynamic translations clear ip nat translation * Clears all dynamic translations. clear ip nat translation <global-ip> Clears a simple translation. clear ip nat translation <global-ip> &ltlocal-ip> <proto> <global-port> <local-port> Clears a particular dynamic translation.

20 Debugging debug ip nat [ <list> ] [ detailed ]

21 Exemples de Configuration
The following sample configuration translates between inside hosts addressed from either the or nets to the globally-unique /28 network. La translation ne concerne que ces 2 seuls réseaux.

22 ip nat pool net-20 171.69.233.209 171.69.233.223 netmask 255.255.255.240
ip nat inside source list 1 pool net-20 ! interface Ethernet0 ip address ip nat outside interface Ethernet1 ip address ip nat inside access-list 1 permit access-list 1 permit

23 The next sample configuration translates between inside hosts addressed from the net to the globally unique /28 network. Packets from outside hosts addressed from net (the "true" net) are translated to appear to be from net /24. Cas d’une société qui n’aurait pas choisi comme adressage interne un adressage public ou conforme au RFC1918.

24 ip nat pool net-20 171.69.233.209 171.69.233.223 netmask 255.255.255.240
ip nat inside source list 1 pool net-20 ip nat outside source list 1 pool net-10 interface Ethernet0 ip address ip nat outside interface Ethernet1 ip address ip nat inside ! access-list 1 permit La translation ne concerne que ce seul réseau.

25 Configuration du pool:
The pool configuration syntax has been extended to allow discontiguous ranges of addresses : ip nat pool <name> { netmask <mask> | prefix-length <length> } This command will put the user into IP NAT Pool configuration mode, where a sequence of address ranges can be configured. There is only one command in this mode: address <start> <end> Router(config)#ip nat pool fred prefix-length 24 Router(config-ipnat-pool)#address Router(config-ipnat-pool)#address This configuration creates a pool containing addresses and ( has been omitted).

26 Translating to interface's address
As a convenience for users wishing to translate all inside addresses to the address assigned to an interface on the router, the NAT code allows one to simply name the interface when configuring the dynamic translation rule: ip nat inside source list <number> interface <interface> overload If there is no address on the interface, or it the interface is not up, no translation will occur. Example: ip nat inside source list 1 interface Serial0 overload

27 Static translations with ports:
Services on the inside network (like mail) will require additional configuration. This command allows the user to map certain services of certain inside hosts. ip nat inside source static { tcp | udp } <localaddr> <localport> <globaladdr> <globalport> Example: ip nat inside source static tcp

28 Translation Entry Limit
Using the following command, Cisco IOS NAT can be configured to limit the number of translation entries it creates. The default is that there is no limit. ip nat translation max-entries <n>

29 Provide TCP Load Distribution
Another use of NAT is unrelated to Internet addresses. Your organization may have multiple hosts that must communicate with a heavily used host. Using NAT, you can establish a virtual host on the inside network that coordinates load sharing among real hosts. Destination addresses that match an access list are replaced with addresses from a rotary pool. Allocation is done in a round-robin basis, and only when a new connection is opened from the outside to the inside. Non-TCP traffic is passed untranslated (unless other translations are in effect).

30 The router performs the following process when translating rotary addresses:
1.The user on Host B ( ) opens a connection to virtual host at .The router receives the connection request and creates a new translation, allocating the next real host ( ) for the inside local IP address. .The router replaces the destination address with the selected real host address and forwards the packet. .Host receives the packet and responds. .The router receives the packet, performs a NAT table lookup using the inside local address and port number, and the outside address and port number as the key. The router then translates the source address to the address of the virtual host and forwards the packet. The next connection request will cause the router to allocate for the inside local address.

31 Note The access list must permit only those addresses that are to be translated. (Remember that there is an implicit "deny all" at the end of each access list.) An access list that is too permissive can lead to unpredictable results. In the following example, the goal is to define a virtual address, connections to which are distributed among a set of real hosts. The pool defines the addresses of the real hosts. The access list defines the virtual address. If a translation does not already exist, TCP packets from serial 0 (the outside interface) whose destination matches the access list are translated to an address from the pool.

32 ip nat pool real-hosts 192.168.15.2 192.168.15.15 prefix-length 28 type rotary
ip nat inside destination list 2 pool real-hosts ! interface serial 0 ip address ip nat outside interface ethernet 0 ip address ip nat inside access-list 2 permit

33 Firewall – Pare-feux Caractéristiques générales et offre du marché
Firewall applicatifs basé sur PC + OS connu (Unix, NT, Win2K, …) Exemple : Firewall-1 de Checkpoint Software Firewall basé sur boitier standalone et OS propriétaire Exemple : PIX Cisco Offre Cisco : Cisco PIX 501 IOS firewall pour routeur Cisco (mémoires requises)

34 Le Cisco ASA succède au PIX, le boîtier firewall et VPN le plus vendu au monde.
Le suivi de l’évolution des menaces requiert toujours plus de puissance et de débit. Un firewall doit pouvoir filtrer le contenu du trafic, notamment bloquer les virus, spyware, et spams. En outre, le développement de la mobilité professionnelle crée des nouveaux besoins de connexion à distance simplifiés et sécurisés en SSL. L’ASA a été pensé pour fournir ces nouveaux services, dans une plateforme évolutive, parce que toutes les sociétés n’ont pas les mêmes besoins de sécurité.

35 - L’ASA se base sur le moteur Firewall et VPN IPSec du PIX auxquels s’ajoutent des nouveaux services tels que :  • l´accès distant en VPN SSL  • la technologie IPS , détection et prévention d’intrusion  • l’Anti-X : anti-virus, anti-spyware, anti-phishing, anti-spam, blocage d’URL…  • NAC (Network Admission Control) : authentification, autorisation et vérification de la sécurité des machines qui accèdent au  réseau en SSL. - l’ASA est optimisé pour filtrer des services applicatifs de nouvelle génération sans dégradation de la qualité de service, en particulier des flux voix et vidéo. - Il est fourni avec une interface logicielle d’administration graphique de toute nouvelle génération, ASDM 6.0, qui simplifie la vie de l’administrateur

36 PIX Cisco OS Similaire à IOS Cisco mais ce n’est pas un IOS, commandes différentes Modes d’accès : identique IOS Unprivileged mode : ">" prompt. Privileged mode : t "#" Enable, disable, exit, or quit Configuration mode "(config)#" prompt avec la commade configure terminal 0 represents Backups write memory tftp-server, write net

37 Configuration des Interfaces du Firewall
Assignation des IP Address and Subnet Mask ip address inside ip_address netmask ip address outside ip_address netmask Exemple: ip address inside

38 Changer les noms d’Interface et les Security Levels (optionnel)
nameif ethernet0 outside security0 (default) nameif ethernet1 inside security100 (default) nameif ethernet2 intf2 security10 (default) Show nameif Donner des noms significatifs : exemple : dmz1 Niveaux de sécurité : 100 est maximale, 0 minimale Ils servent à contrôler les accès entre les systèmes des différentes interfaces.

39 Principes Pour accéder à une interface de basse sécurité depuis une interface de sécurité haute utiliser les commandes nat et global (voir exemples qui suivent). Par défaut pas de restriction (si une commande nat est activée). Utiliser des access-list pour restreindre les droits (selon l’adresse IP et/ou le port TCP/UDP). Remarques : implicit deny (permit) all existe comme avec IOS. Le wildcard mask n’est pas utilisé on utilise le maque “ normal ”

40 Pour accéder à un interface de haute sécurité depuis une interface de sécurité basse utiliser les commandes static et access-list (voir exemples qui suivent). Par défaut tout est interdit. Remarques : dans les anciennes versions de PIX software (< v5), la commande conduit était utilisée (au lieu de l’access-list).

41 Configuring the PIX Firewall for Routing
route outside (route par defaut) route inside route dmz 1 = next hop

42 @ Outside: DMZ PIX Routeur Inside:

43 Etablir la connectivité Outbound avec NAT et PAT
Network Address Translation (NAT). Port Address Translation (PAT) avec une seule globale IP address 64,000 ports sont en théorie disponibles (port codé sur 16 bits) Le PIX Firewall associe une adresse interne avec une adresse globale en utilisant un NAT identifier (NAT ID).

44 Ajouter une nat commande pour chaque interface de plus haut niveau de securité depuis laquelle vous voulez que des users puissent initialiser des connexions vers des interfaces de niveau de sécurité inférieur : To let inside users start connections on any lower security interface, use the nat (inside) command. To let dmz4 users start connections on any lower security interface such as dmz3, dmz2, dmz1, or the outside, use the nat (dmz4) command. Instead of specifying "0 0," to let all hosts start connections, you can specify a host or a network address and mask. For example, to let only host start connections on the dmz2 interface, you could specify the following: nat (dmz2)

45 LE "1" après l’interface est le NAT ID.
NAT ID 0 means to disable Network Address Translation. Le NAT ID in the nat command has to be the same NAT ID you use for the corresponding global command. global (outside) netmask global (outside) netmask

46 The first global command statement specifies a single IP address, which the PIX Firewall interprets as a PAT. The PAT lets up to 65,535 hosts start connections to the outside. PIX Firewall permits one PAT global command statement for each interface. The second global command statement augments the pool of global addresses on the outside interface. The PAT creates a pool of addresses used only when the addresses in the first global command statement are in use.

47 global (dmz1) netmask global (dmz2) netmask The global command statement for dmz1 lets users on the inside,dmz2, dmz3, and dmz4 start connections on the dmz1 interface. The global command statement for dmz2 lets users on the inside, dmz3, and dmz4 start connections on the dmz2 interface. If you use network subnetting, specify the subnet mask with the netmask option.

48 You can track usage among different subnets by mapping different internal subnets to different PAT addresses. For example: nat (inside) nat (inside) global (outside) global (outside) In this example, hosts on the internal network /24 are mapped to global address , and hosts on the internal network /24 are mapped to global address in global configuration mode.

49

50 Example 1: Two Interfaces Without NAT
nameif ethernet0 outside security0 nameif ethernet1 inside security100 interface ethernet0 10baset interface ethernet1 10baset ip address outside ip address inside hostname pixfirewall arp timeout 14400 no failover logging buffered debugging nat (inside) route outside access-list ping_acl permit icmp any any access-group ping_acl in interface inside access-group ping_acl in interface outside mtu outside 1500 mtu inside 1500

51

52 Example 2: Two Interfaces with NAT
nameif ethernet0 outside security0 nameif ethernet1 inside security100 interface ethernet0 10baset interface ethernet1 10baset ip address outside ip address inside hostname pixfirewall arp timeout 14400 no failover logging buffered debugging nat (inside) 1 0 0 global (outside) global (outside) route outside access-list ping_acl permit icmp any any access-group ping_acl in interface inside access-group ping_acl in interface outside mtu outside 1500 mtu inside 1500

53

54 Exemple3: Interfaces sans NAT or PAT
The network has the following IP addresses and network masks: Outside network interface address: , network mask: Inside network interface address: , network mask: DMZ network interface address: , network mask: Step 1 Identify the security level and names of each interface by entering the following commands: nameif ethernet0 outside security0 nameif ethernet1 inside security100 nameif ethernet2 dmz security50

55 An additional nameif command is required for the third interface in this example.
Step 2 Identify the line speed of each interface by entering the following commands: interface ethernet0 10baset interface ethernet1 10baset interface ethernet0 100basetx Step 3 Identify the IP addresses for each interface: ip address outside ip address inside ip address dmz

56 Step 4 Map access to the 209.165.201.19 host on the outside interface:
static (dmz,outside) Step 5 Use the access-list command to let any outside user access the DMZ host on any port: access-list acl_out permit tcp any host access-group acl_out in interface outside Remarques : on peut spécifier un host extérieur autorisé à la place de any ou spécifier un port qui serait le seul autorisé (eq www en fin de commande).

57 The access-list command lets any outside user
access the host on any port. nameif ethernet0 outside security0 nameif ethernet1 inside security100 nameif ethernet2 dmz security50 interface ethernet0 10baset interface ethernet1 10baset interface ethernet0 100basetx ip address outside ip address inside ip address dmz hostname pixfirewall arp timeout 14400

58 Configuration (suite)
no failover logging buffered debugging nat (inside) static (dmz,outside) access-list acl_out permit tcp any host access-group acl_out in interface outside route outside mtu outside 1500 mtu inside 1500

59 Exemple 4: 3 interfaces avec PAT et NAT
The network has the following IP addresses and network masks: Outside network interface address: , network mask: Allowable global and static addresses on the outside network: , network mask: Inside network interface address: , network mask: DMZ network interface address: , network mask:

60 Exemple4: 3 interfaces avec PAT ni NAT
the PIX Firewall has three interfaces and these attributes: Address translation is performed between the interfaces. A web server on the DMZ interface is publicly accessible. The name command maps its host address to the name "webserver." The inside network has RFC1918 addresses ( ), the DMZ interface has RFC 1918 addresses ( ), and the outside network has legal, registered addresses ( ). TCP and UDP connections from the inside are allowed to go out on the DMZ and outside.

61

62 Step 1 Create a pool of global addresses for the outside and DMZ interfaces. Because there are limited outside IP addresses, add a PAT global to handle overflow. The global (dmz) command gives inside users access to the web server on the DMZ interface. global (outside) global (outside) global (dmz)

63 Step 2 Let inside users start connections on the DMZ and outside interfaces, and let DMZ users start connections on the outside interface: nat (inside) nat (dmz) Step 3 Give the IP address of the web server a label: name webserver

64 Step 4 Let any user on the outside interface access the web server on the DMZ interface:
static (dmz,outside) webserver access-list acl_out permit tcp any host eq 80 access-group acl_out in interface outside The access-list command statement is bound to the outside interface by the access-group command statement.

65 Example 4: Three Interfaces with NAT
nameif ethernet0 outside security0 nameif ethernet1 inside security100 nameif ethernet2 dmz security50 interface ethernet0 10full interface ethernet1 10full interface ethernet2 10full ip address outside ip address inside ip address dmz hostname pixfirewall

66 route outside global (outside) global (outside) global (dmz) nat (inside) nat (dmz) name webserver static (dmz,outside) webserver access-list acl_out permit tcp any host eq 80 access-group acl_out in interface outside

67


Télécharger ppt "Translation d’adresse NAT"

Présentations similaires


Annonces Google