تعريف NAT على راوتر سيسكو

By حواديت شبكات

NAT هو اختصار لـِ Network Address Translation، وأبسط تعريف له هو التحويل من عنوان IP إلى آخر. ويتم تشغيله على مداخل الشبكة Gateways كأجهزة الراوتر أو جدران النار firewall أو أجهزة البروكسي. من أكثر الإستخدامات الدارجة حالياً لـNAT هو من خلال خطوط ADSL بهدف تمكين مجموعة من المستخدمين ضمن الشبكة الداخلية والذين لديهم عناوين خاصة Private IP من الدخول إلى الانترنت باستخدام عنوان عام واحد Public IP.

لنفترض أن لدينا 20 جهاز معرّفين ضمن المجال 192.168.10.0/24، ولدينا راوتر مرتبط بالشبكة الداخلية من خلال مخرج fastethernet0/1 ومعرّف عليه المخرج Dialer0 لخط  الـ ADSL ويحمل العنوان 150.160.170.180. لكي يتمكن جميع المستخدمين من النفاذ للإنترنت ينبغي علينا عمل الخطوات الثلاث التالية:
الخطوة الأولى:
تعريف الراوتر بمجموعة العناوين الخاصة التي تحملها الأجهزة والتي سيسمح لها بالخروج إلى الإنترنت، وذلك من خلال قائمة standard access list.

router(config)# access-list 10 permit 192.168.10.0

الخطوة الثانية:
تعريف NAT على الراوتر

router(config)# ip nat inside source list 10 dialer0 overload

وهذا يتضمن تحديد القائمة التي تعرّف العناوين  source list 10 (القائمة 10 كما حددناها في الخطوة الأولى). والمخرج الخارجي الذي سيتم إسناد الـ IP الخاص به لكل جهاز يحتاج للخروج إلى الإنترنت وهو dialer0. وبما أن لدينا 20 جهاز سيستخدمون جميعاً نفس عنوان الـ IP الخارجي نضيف كلمة overload وبذلك فإن كل جهاز سيتم تمييزه عن الآخر عن طريق إضافة رقم منفذ port number بشكل عشوائي إلى عنوان IP (وهذا يدعى أيضاً PAT أي Port Address Translation).

مثال على عمل NAT

اسم الجهاز

العنوان الداخلي الأصلي

العنوان الخارجي بعد NAT

PC1

192.168.10.5

150.160.170.180:9856

PC2

192.168.10.6

150.160.170.180:5682

PC3

192.168.10.7

150.160.170.180:21548

الخطوة الثالثة:
تحديد إتجاه عمل NAT. فهو سيعمل على تحويل كل عنوان قادم من الشبكة الداخلية عن طريق المنفذ fastethernet0/1 إلى عنوان خارجي عن طريق المنفذ الخارجي dialer0 وهذا يتم كما يلي:

router (config)# interface fastethernet 0/1
router (config-if)# ip nat inside

router (config)# interface dialer 0
router (config-if)# ip nat outside

بقي أن أضيف أن باستطاعتك التأكد من عمل NAT بالشكل الصحيح من خلال بعض أوامر show :

router# show ip nat transactions

وهذا يُظهر جدولاً بعناوين الأجهزة التي حصلت على عناوين من خلال NAT

router# show ip nat statistics

ويُظهر معلومات حول المخارج التي يعمل عليها NAT وعدد الأجهزة التي حصلت على عناوين، وعدد الأجهزة التي فشلت أيضاً في الحصول على عناوين.

الأوسمة: , , , , , , , , ,

14 تعليقات إلى “تعريف NAT على راوتر سيسكو”

  1. عمر ودالمعيلق يقول:

    واللة كلامكم طيب وجميل ومفيد ولكن ارجو تنسيق تركيب الشبكة مع الرويتر والسيوتش خطوة خطوة وبسيطة كى تفهم بدون تعقيد وكلام كتير وارجو شرح الاختصارات حتى تفهم ولكم الشكر
    ملحوظة لوامكن ارجو ارسال كل الشرح الى بريدى ولكم التحية

    ابـــــــــــوبسمــلة

  2. حواديت شبكات يقول:

    الأخ عمر … إن شاء الله سوف أفرد لها تدوينة مستقلة

  3. أحمد حافظ يقول:

    بجد انا سعيد انى لاقيت مدونتك لانها بجد شئ جميل جدا وانا متابع معاك
    وياريت لو تشرفنا فى منتدى عرب هارد وير لافادة اخوانك هناك
    http://www.arabhardware.net/forum/index.php
    وانا اسمى Mr Mac هناك على فكرة :D

  4. حواديت شبكات يقول:

    الأخ أحمد
    أهلا وسهلا بك في المدونة
    سرتني دعوتك لمنتدى عرب هاردوير ..
    زرت المنتدى عده مرات من قبل.. وبدون مجاملة هو من أفضل المنتديات العربية على الإطلاق
    أسأل الله التوفيق لكم

  5. احمد حافظ يقول:

    عندى سؤال فى النات
    ما اهمية جعل outside network تظهر عندى كــ inside network

    مثل R1(config)# ip nat outside list 2 pool company

  6. abdullah kamis يقول:

    شكرآ جزيلآ على هذا التوضيح و خصوصآ أنه باللغة العربية…
    أتمنى التواصل عبر الإيميل للإطلاع على ما هو جديد
    eng.ayak@yahoo.com
    وشكرآ

  7. حواديت شبكات يقول:

    الأخ أحمد
    أعتذر على التأخر في الرد بسبب الإنشغال

    يستخدم الأمر ip nat outside كما هو واضح لتحويل عناوين الشبكة الخارجية (بالنسبة للراوتر)…
    من الإستخدامات الدارجة لذلك هو وجود عناوين متداخلة (متشابهة) بين الشبكتين على طرفي الراوتر (inside network و outside network)
    لنفترض مثلا وجود شبكتين قائمتين أصلاً تستخدمان نفس مجموعة العناوين ip subnet واحتجنا إلى عمل routing بينهما.. هنا يأتي عمل nat وذلك بقيام الراوتر أولاً بعملية التحويل للعنوان القادم إلى عنوان جديد مختلف عن الموجود داخلياً ومن ثم يقوم بعملية توجيه المعلومات routing إلى الشبكة الداخلية

  8. حواديت شبكات يقول:

    الأخ عبد الله
    أهلا وسهلا بك…
    أرجو أن تزورنا دائماً في المدونة

  9. Ahmed Hafez يقول:

    شكرا لك استاذى الصورة وضحت والحمد لله

  10. SOURCE يقول:

    جزاك الله كل خير

  11. ahmad tuffaha يقول:

    سبحان الله
    فعلا موضوع رائع
    هل تعلم اني مافهمت النات الا من طريقة شرحك المميزة
    الله يعطيك ويزيدك من العلم والمعرفة
    شكرا جزيلا

  12. زياد دلاشه- فلسطين يقول:

    بدي اشبك4 خطوط ادسل علي سيسكو 1841
    عتدي CONFIG بس يصراحه ما عاجبيتني
    ارجو المساعده
    ziaddl2008@gmail.com

  13. حواديت شبكات يقول:

    زياد

    يعتمد هذا على الإعدادات التي توفرها لك شركة الإتصالات المشترك معها
    على أية حال ارسل لي ملف config لمعاينته

  14. زياد دلاشه يقول:

    service timestamps debug datetime msec
    service timestamps log datetime msec
    service password-encryption
    !
    hostname Ziad-1841
    !
    boot-start-marker
    boot system flash
    boot-end-marker
    !
    logging buffered 4096 debugging
    enable secret 5 $1$gpgC$OWJRYh5fLE5dHMdMfWakG/
    !
    no aaa new-model
    ip cef
    !
    !
    no ip dhcp use vrf connected
    ip dhcp excluded-address 10.0.0.200
    !
    ip dhcp pool LAN
    network 10.0.0.0 255.255.255.0
    default-router 10.0.0.138
    dns-server 194.90.1.5 212.143.212.143
    lease infinite
    !
    !
    no ip bootp server
    ip name-server 194.90.1.5
    ip name-server 212.143.212.143
    ip sla monitor 1
    type echo protocol ipIcmpEcho 212.143.225.94
    timeout 30
    ip sla monitor schedule 1 life forever start-time now
    ip sla monitor 2
    type echo protocol ipIcmpEcho 212.235.2.141
    timeout 30
    ip sla monitor schedule 2 life forever start-time now
    ip sla monitor 3
    type echo protocol ipIcmpEcho 212.235.2.140
    timeout 30
    ip sla monitor schedule 3 life forever start-time now
    !
    !
    !
    !
    !
    track 1 rtr 1 reachability
    !
    track 2 rtr 2 reachability
    !
    track 3 rtr 3 reachability
    !
    !
    !
    !
    interface FastEthernet0/0
    description connected to MODEMS
    ip address 192.168.1.254 255.255.255.0
    no ip redirects
    no ip proxy-arp
    ip nat outside
    ip virtual-reassembly
    no ip route-cache cef
    no ip route-cache
    duplex auto
    speed auto
    !
    interface FastEthernet0/1
    ip address 10.0.0.138 255.0.0.0 secondary
    ip address 212.235.0.185 255.255.255.248
    ip nat inside
    ip virtual-reassembly
    ip tcp adjust-mss 1420
    ip policy route-map LOAD_BALANCE
    duplex auto
    speed auto
    !
    ip route 0.0.0.0 0.0.0.0 192.168.1.1
    ip route 212.143.225.94 255.255.255.255 192.168.1.1
    ip route 212.235.2.140 255.255.255.255 192.168.1.3
    ip route 212.235.2.141 255.255.255.255 192.168.1.2
    !
    !
    ip http server
    no ip http secure-server
    ip nat translation timeout 6000
    ip nat translation tcp-timeout 6000
    ip nat translation udp-timeout 600
    ip nat translation dns-timeout 300
    ip nat translation max-entries 12000
    ip nat inside source list 2 interface FastEthernet0/0 overload
    ip nat inside source static tcp 10.0.0.138 23 interface FastEthernet0/0 23
    ip nat inside source static tcp 10.0.0.200 80 interface FastEthernet0/0 80
    !
    ip access-list extended Modem1
    permit tcp any any eq smtp
    permit tcp any any eq 1863
    permit udp any any eq 1863
    permit udp any any eq 7001
    permit tcp any any eq 7001
    permit icmp any any
    ip access-list extended Modem2
    permit tcp any any eq www
    permit tcp any any eq 443
    permit tcp any any eq 8080
    permit tcp any any eq pop3
    permit icmp any any
    ip access-list extended Modem3
    deny tcp any any eq smtp
    deny tcp any any eq pop3
    deny tcp any any eq www
    deny tcp any any eq 8080
    deny tcp any any eq 443
    deny tcp any any eq 1863
    deny udp any any eq 1863
    deny udp any any eq 7001
    deny tcp any any eq 7001
    permit ip any any
    !
    access-list 2 permit 10.0.0.0 0.0.0.255
    access-list 20 permit 194.90.1.33
    access-list 20 permit 10.0.0.0 0.0.0.255
    access-list 20 permit 192.168.1.0 0.0.0.255
    !
    route-map LOAD_BALANCE permit 10
    match ip address Modem1
    set ip next-hop verify-availability 192.168.1.1 10 track 1
    set ip next-hop verify-availability 192.168.1.2 20 track 2
    set ip next-hop verify-availability 192.168.1.3 30 track 3
    !
    route-map LOAD_BALANCE permit 20
    match ip address Modem2
    set ip next-hop verify-availability 192.168.1.2 10 track 2
    set ip next-hop verify-availability 192.168.1.3 20 track 3
    set ip next-hop verify-availability 192.168.1.1 30 track 1
    !
    route-map LOAD_BALANCE permit 30
    match ip address Modem3
    set ip next-hop verify-availability 192.168.1.3 10 track 3
    set ip next-hop verify-availability 192.168.1.2 20 track 2
    set ip next-hop verify-availability 192.168.1.1 30 track 1
    !
    !
    !
    !
    control-plane
    !
    !
    !
    line con 0
    line aux 0
    line vty 0 4
    access-class 20 in
    password 7A
    login
    transport input telnet ssh
    transport output telnet ssh
    !
    scheduler allocate 20000 1000
    end

    Ziad-1841#

اترك رد