Mechanizmy routingu w systemach wolnodostępnych



Podobne dokumenty
(secure) ROUTING WITH OSPF AND BGP FOR FUN, FUN & FUN. Łukasz Bromirski. lukasz@bromirski.net

ROUTING DYNAMICZNY. Łukasz Bromirski. ...a Linux.

PROTOKOŁY DYNAMICZNEGO ROUTINGU IP RIP i OSPF

Jak zbudować profesjonalny styk z internetem?

Protokół BGP Podstawy i najlepsze praktyki Wersja 1.0

Marcin Mazurek P.I.W.O, 22/05/2004, Poznań, Polska:)

Wykorzystanie połączeń VPN do zarządzania MikroTik RouterOS

Zarządzanie systemem komendy

BGP. Piotr Marciniak (TPnets.com/KIKE) Ożarów Mazowiecki, 26 marca 2010 r.

Routing - wstęp... 2 Routing statyczny... 3 Konfiguracja routingu statycznego IPv Konfiguracja routingu statycznego IPv6...

DR INŻ. ROBERT WÓJCIK DR INŻ. JERZY DOMŻAŁ PODSTAWY RUTINGU IP. WSTĘP DO SIECI INTERNET Kraków, dn. 7 listopada 2016 r.

Routing dynamiczny... 2 Czym jest metryka i odległość administracyjna?... 3 RIPv RIPv Interfejs pasywny... 5 Podzielony horyzont...

OSPF... 3 Komunikaty OSPF... 3 Przyległość... 3 Sieć wielodostępowa a punkt-punkt... 3 Router DR i BDR... 4 System autonomiczny OSPF...

Sterowanie ruchem wyjściowym

Warstwa sieciowa rutowanie

Konfigurowanie protokołu OSPF w systemie Linux

Sieci komputerowe. Tadeusz Kobus, Maciej Kokociński Instytut Informatyki, Politechnika Poznańska

IPv6. Wprowadzenie. IPv6 w systemie Linux. Zadania Pytania. budowa i zapis adresu, typy adresów tunelowanie IPv6 w IPv4

ISP od strony technicznej. Fryderyk Raczyk

PROTOKÓŁ BGP. Łukasz Bromirski PODSTAWY DZIAŁANIA BUDOWA STYKU Z INTERNETEM PROJEKT BGP BLACKHOLING PL. lukasz@bromirski.net lbromirski@cisco.

PBS. Wykład Routing dynamiczny OSPF EIGRP 2. Rozwiązywanie problemów z obsługą routingu.

Sieci komputerowe. Tadeusz Kobus, Maciej Kokociński Instytut Informatyki, Politechnika Poznańska

Wykład 2: Budowanie sieci lokalnych. A. Kisiel, Budowanie sieci lokalnych

RUTERY. Dr inŝ. Małgorzata Langer

Routing. mgr inż. Krzysztof Szałajko

Badanie protokołów routingu

CCNA : zostań administratorem sieci komputerowych Cisco / Adam Józefiok. Gliwice, cop Spis treści

Księgarnia PWN: Mark McGregor Akademia sieci cisco. Semestr piąty

Sieci komputerowe. Routing. dr inż. Andrzej Opaliński. Akademia Górniczo-Hutnicza w Krakowie.

Praktyczne aspekty implementacji IGP

Wykład 3: Internet i routing globalny. A. Kisiel, Internet i routing globalny

Konfigurowanie protokołu BGP w systemie Linux

ZiMSK. Routing dynamiczny 1

EFEKTYWNOŚĆ PROTOKOŁÓW TRASOWA- NIA BGP + OSPF PRZY REALIZACJI USŁUG TRANSPORTU DANYCH

Link-State. Z s Link-state Q s Link-state. Y s Routing Table. Y s Link-state

BADANIE DOBORU TRAS W WIELODROGOWEJ ARCHITEKTURZE SIECIOWEJ ZE WZGLĘDU NA ZMIENNE WARUNKI SIECIOWE

PROJEKT BGP BLACKHOLING PL

IP Anycast. Ochrona i skalowanie usług sieciowych. Łukasz Bromirski lbromirski@cisco.com

Rozległe Sieci Komputerowe

Adresy w sieciach komputerowych

Koncepcja komunikacji grupowej

Warsztaty z Sieci komputerowych Lista 3

Instrukcja do laboratorium 1

Routing / rutowanie (marszrutowanie) (trasowanie)

Projekt BGP BLACKHOLING PL Łukasz Bromirski

GRAF DECYZJI O TRASIE PAKIETU

Sieci Komputerowe. Zajęcia 2 c.d. Warstwa sieciowa. Adresacja IPv4

Instrukcja do laboratorium 2. Podstawowa konfiguracja środowiska MPLS (Multi-Protocol Label Switching)

Dlaczego? Mało adresów IPv4. Wprowadzenie ulepszeń względem IPv4 NAT CIDR

Podstawy Sieci Komputerowych Laboratorium Cisco zbiór poleceń

PROTOKOŁY RUTINGU W SIECIACH PAKIETOWYCH

Podstawy MPLS. PLNOG4, 4 Marzec 2010, Warszawa 1

Konfigurowanie protokołu BGP w ruterach Cisco

lp wykonawca nr w dzienniku (dz) 1. POL GRZYBOWSKI MAZUR zadanie rodzaj tunelowania typ tunelu wybór 1. wyspy IPv6 podłączone w trybie Manual Mode 4

Zarządzanie Jakością Usług w Sieciach Teleinformatycznych

Sieci komputerowe - Protokoły wspierające IPv4

WPROWADZENIE DO PROTOKOŁU BGP (BORDER GATEWAY PROTOCOL)

Open Shortest Path First Protokół typu link-state Szybka zbieżność Obsługa VLSMs (Variable Length Subnet Masks) Brak konieczności wysyłania

ZiMSK. Charakterystyka urządzeń sieciowych: Switch, Router, Firewall (v.2012) 1

Sieci komputerowe dr Zbigniew Lipiński

Laboratorium - Przeglądanie tablic routingu hosta

ZiMSK NAT, PAT, ACL 1

1.1 Ustawienie adresów IP oraz masek portów routera za pomocą konsoli

PORADNIKI. Routery i Sieci

Sieci komputerowe Warstwa sieci i warstwa transportowa

Sieci Komputerowe Laboratorium 08 OSPF

* konfiguracja routera Asmax V.1501 lub V.1502T do połączenia z Polpakiem-T lub inną siecią typu Frame Relay

BRINET Sp. z o. o.

Sieci komputerowe. Router. Router

Zarządzanie ruchem w sieci IP. Komunikat ICMP. Internet Control Message Protocol DSRG DSRG. DSRG Warstwa sieciowa DSRG. Protokół sterujący

Sklejanie VPN (różnych typów)

Zapis adresu. Adres IPv6 zapisujemy w postaci szesnastkowej, w ośmiu blokach 2-bajtowych Przykład:

Routowanie we współczesnym Internecie. Adam Bielański

Sieci Komputerowe. Wykład 1: TCP/IP i adresowanie w sieci Internet

Sieci Komputerowe Laboratorium 10. Redystrybucja_OSPF_EIGRP_RIP

Czym jest router?... 3 Vyatta darmowy router... 3 Vyatta podstawowe polecenia i obsługa... 3 Zarządzanie użytkownikami... 3 Uzupełnianie komend...

Sieci Komputerowe. Zadania warstwy sieciowej. Adres IP. Przydzielanie adresów IP. Adresacja logiczna Trasowanie (ang. routing)

router wielu sieci pakietów

Warstwa sieciowa. Model OSI Model TCP/IP. Aplikacji. Aplikacji. Prezentacji. Sesji. Transportowa. Transportowa

ZADANIE.03 Routing dynamiczny i statyczny (OSPF, trasa domyślna) 1,5h

DLACZEGO QoS ROUTING

Open Shortest Path First Protokół typu link-state Szybka zbieżność Obsługa VLSMs (Variable Length Subnet Masks) Brak konieczności wysyłania

Formularz Oferty Technicznej

1. Podstawy routingu IP

ZST Wykład (lato 2014)

Instrukcja do laboratorium 1. Podstawowa konfiguracja środowiska MPLS (Multi-Protocol Label Switching)

Badanie bezpieczeństwa IPv6

Zadanie1: Odszukaj w Wolnej Encyklopedii Wikipedii informacje na temat NAT (ang. Network Address Translation).

Internet Protocol v6 - w czym tkwi problem?

LOKALNE i ROZLEGŁE SIECI KOMPUTEROWE Local and Wide Area Networks Forma studiów: Stacjonarne Poziom kwalifikacji: I stopnia

Plan wykładu. Wyznaczanie tras. Podsieci liczba urządzeń w klasie C. Funkcje warstwy sieciowej

Routing i polityka bezpieczeństwa w Śląskiej Akademickiej Sieci Komputerowej

Konfiguracja połączenia G.SHDSL punkt-punkt w trybie routing w oparciu o routery P-791R.

Institute of Telecommunications. koniec wykładu II.

Ćwiczenie Konfiguracja statycznych oraz domyślnych tras routingu IPv4

ZP-92/022/D/07 załącznik nr 1. Wymagania techniczne dla routera 10-GIGABIT ETHERNET

Gdzie ComNet świadczy usługi.

Plan prezentacji. Konfiguracja protokołu routingu OSPF. informatyka+

LABORATORIUM SIECI KOMPUTEROWYCH (compnet.et.put.poznan.pl)

Transkrypt:

Mechanizmy routingu w systemach wolnodostępnych Łukasz Bromirski lukasz@bromirski.net 1

Agenda Routing IP Quagga/OpenBGPD/OpenOSPFD/XORP Gdzie i dlaczego OSPF? OSPF w praktyce Gdzie i dlaczego BGP? BGP w praktyce Routing dynamiczny a inne zagadnienia Q&A NAT, QoS, multicasty i VPNy, redundancja 2

Wymagana będzie......znajomość chociażby na minimalnym poziomie zagadnień związanych z routingiem dynamicznym i protokołów OSPF i BGP...pakietu Quagga i/lub OpenOSPFd/BGPd Na końcu tej prezentacji znajdują się odnośniki do materiałów uzupełniających również tych bardzo podstawowych 3

O czym będzie ta sesja? internet ISP A ISP B (AS300) (AS200) Twoja sieć (AS 100) 4

POWTÓRKA Z ROZRYWKI: ROUTING IP 5

Routing IP O czym mówimy? Routing IP to decyzja (standardowo) podejmowana na podstawie adresu docelowego pakietu IP Kernel podejmuje tą decyzję na podstawie tablicy FIB Forwarding Information Base Aplikacje zapewniające routing dynamiczny utrzymują zwykle swoją tablicę RIB Routing Information Base z której najlepsze wpisy eksportowane są do FIB 6

Routing IP O czym mówimy? Narzędzia systemowe wpływają na FIB opcje FIB_HASH/FIB_TRIE w kernelach 2.6.x Narzędzia konkretnej aplikacji wpływają na RIB właściwy dla pakietu Dodatkowo Linux posiada bogate opcje routingu na podstawie adresu źródłowego pakiet iproute2 integracja z aplikacjami zewnętrznymi tablice, realms Realms: http://vcalinus.gemenii.ro/quaggarealms.html 7

Routing IP Czym zajmuje się router? Router otrzymuje datagramy IPv4 w postaci: RFC 791, http://www.ietf.org/rfc/rfc0791.txt 8

Routing IP Budowa FIB Zawartość FIB: [me@slack ~]$ ip route list 10.0.0.0/24 dev eth0 proto kernel src 10.0.0.100 169.254.0.0/16 dev eth0 scope link default via 10.0.0.1 dev eth0 [me@slack ~]$ route n Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use If 10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0 169.254.0.0 0.0.0.0 255.255.0.0 U 0 0 0 eth0 0.0.0.0 10.0.0.1 0.0.0.0 UG 0 0 0 eth0 9

QUAGGA/ZEBRA vs XORP vs OpenOSPFd 10

Quagga/Zebra (0.99.5/0.98.6) Quagga posiada budowę modularną Proces zebra odpowiada za interakcje wszystkich pozostałych z kernelem (FIB) i zarządzanie RIB Osobne procesy odpowiedzialne za protokoły routingu ripd (v1/v2), ripngd (v3 dla IPv6) ospfd (v2), ospf6d (v3 dla IPv6) bgpd (v4+) is is* Dostępne narzędzie vtysh do zarządzania wszystkim jednocześnie Quagga jest przygotowana do przechowywania wielu takich samych tras w RIB: configure [...] enable multipath=x 11

XORP (1.3) XORP również posiada budowę modularną Router manager (rtrmngr) nadzoruje pracę grupy procesów Dwie osobne ścieżki: unicast: BGP4, RIPv1/2 i RIPng, OSPFv2 multicast: PIM SM, IGMPv1/v2, MLDv1 Wydzielony RIB dla wszystkich protokołów Wydzielona FEA, pozwalająca uniezależnić się od systemu/dostępnych interfejsów Dostępna powłoka xorpsh do zarządzania Wiele rozmaitych problemów 12

OpenOSPFd Projekt zespołu OpenBSD Henning Brauer, Claudio Jeker & Esen Norby Projekt w trakcie dopracowywania IPv6 problemy z redystrybucją/wstrzyknięciem trasy default Tradycyjny zestaw narzędzi i plików: ospfd demon odpowiedzialny za protokół ospfctl narzędzie do kontroli /etc/ospfd.conf konfiguracja 13

OpenBGPd Ten sam team zespołu OpenBSD Henning Brauer, Claudio Jeker & Esen Norby i inni Projekt w trakcie dopracowywania IPv6 + różne zagadnienia z filtrowaniem/utrzymywaniem atrybutów tras Podobnie jak OpenOSPFd: bgpd demon odpowiedzialny za protokół bgpctl narzędzie do kontroli /etc/bgpd.conf konfiguracja Linux port PoC: http://hasso.linux.ee/doku.php/english:network:openbgpd 14

Podsumowanie obecnego stanu Wiele możliwości, potęgowanych możliwościami pakietu iproute2 Nadal brak jasnej wizji dotyczącej zarządzaniem przez kernel różnymi źródłami informacji routingowej Ten sam problem mają wszystkie dystrybucje Linuksa oraz Free/Net/OpenBSD 15

GDZIE I DLACZEGO OSPF? 16

Dlaczego OSPF? Najszybszy standardowy protokół IGP IGP = wewnętrzny (ang. internal gateway protocol) Większość małych i średnich sieci ma strukturę hierarchiczną, lub da się ją stworzyć Dostosowywalny do większości scenariuszy za pomocą standardowych mechanizmów i narzędzi Dostępny for free w implementacjach: Quagga ospfd OpenOSPFd 17

Protokół routingu OSPF Jak działa? OSPF posługuje się hierarchiczną strukturą sieci: obszar backbone (area 0) obszary podłączone różnych typów Każdy z obszarów musi być połączony do obszaru 0 jeśli nie może przez link wirtualny Routery identyfikowane są za pomocą router id najwyższy adres IP ze wszystkich interfejsów pierwszeństwo mają interfejsy loopback użyj ich! 18

Protokół routingu OSPF Przykład topologii Internal Area 10 ABR LAN Internal Area 12 ABR ABR Area 0 ABR Backbone Area 11 Internal ASBR RIP/RIPv2 19

Jak podzielić sieć na obszary OSPF? Area10 Area0 Area11 Area20 20

Jak właściwie wybrać DR/BDRa dla segmentu? We wszystkich topologiach, w których wiele routerów łączy wspólny segment Ethernet priorytet routera (0 254, 254 najwyższy, 0 nie zostanie DR) wyższe router id (zalecane stabilne rozplanowanie numeracji interfejsów loopback!) interface eth0 ip ospf priority 253 router ospf router id 172.16.254.253 interface eth0 ip ospf priority 254 router ospf router id 172.16.254.254 BDR drother interface eth0 ip ospf priority 0 router ospf router id 172.16.254.49 DR 21

Protokół OSPF Kiedy point to point? Zalecane w przypadku sieci używających jako warstwy transportowej 802.11: oszczędzamy czas potrzebny na elekcję DR/BDR Dwa interfejsy: interface eth0! interfejs podłączony do mostu 802.11 ip ospf network point to point ip ospf cost 20! interfejs 100Mbit/s pracuje jak 5Mbit/s interface eth1! interfejs podłączony do linku 100Mbit/s ip ospf network point to point ip ospf cost 1! interfejs 100Mbit/s 22

Protokół OSPF Kiedy point to point? Zalecane w przypadku sieci używających jako warstwy transportowej 802.11: oszczędzamy czas potrzebny na elekcję DR/BDR Jeden interfejs do bridge a i łącza 100Mbit/s: interface eth0.10! interfejs podłączony do mostu 802.11 ip ospf network point to point ip ospf cost 20! interfejs 100Mbit/s pracuje jak 5Mbit/s interface eth0.20! interfejs podłączony do linku 100Mbit/s ip ospf network point to point ip ospf cost 1! interfejs 100Mbit/s 23

Protokół routingu OSPF Sumaryzacja brak Area10 172.16.10.0/24 172.16.20.0/24 172.16.30.0/24 172.16.40.0/24 172.17.10.0/24 172.17.20.0/24 172.17.30.0/24 172.17.40.0/24 Area20 Area0 172.18.10.0/24 Area11 172.18.20.0/24 172.18.30.0/24 172.18.40.0/24 Wiele prefiksów w Area 0 Dodatkowe obciążenie dla algorytmu SPF i routerów backbone up/down prefiksu obciążamy CPU routerów w A0 24

Protokół routingu OSPF Sumaryzacja skonfigurowana Area0 Area10 172.16.0.0/16 172.17.0.0/16 172.18.0.0/16 Area11 Area20 Pojedyncze prefiksy w Area 0 Zmniejszamy obciążenie CPU, nie propagujemy problemów w warstwie dostępowej do szkieletu/rdzenia 25

Protokół routingu OSPF Sumaryzacja konfiguracja Obszar 10 rozgłasza sieć 172.16.0.0/16, zamiast: 172.16.10.0/24 172.16.20.0/24... router ospf ospf router id 172.16.254.11 [...] area 0.0.0.10 range 172.16.0.0/16 26

Trasa domyślna router ospf default information originate [always] router ospf area 0.0.0.10 stub no summary Area10 Area0 Area11 router ospf area 0.0.0.10 stub no summary Area20 27

GDZIE I DLACZEGO BGP? 28

Protokół BGP Wstęp i rozwinięcie Protokół routingu używany do wymiany informacji o osiągalności sieci (prefiksów) pomiędzy systemami autonomicznymi klasy EGP Exterior Gateway Protocol Do niedawna RFC1771 + rozszerzenia, od stycznia 2006 obowiązuje RFC4271: http://www.ietf.org/rfc/rfc4271.txt RFC4276 opisuje raport implementacyjny RFC4271 RFC4277 dodatkowo opisuje doświadczenia z różnymi implementacjami 29

Protokół BGP System Autonomiczny AS100 Zwykle jedna firma/organizacja, zarządzana przez jedną grupę ludzi Jedna polityka routingu wewnętrznego i zewnętrznego ASN 0 i 65535 zarezerwowane, 23456 również (do przejścia na 32 bitową notację), natomiast 1 64511 zarządzane centralnie (publiczne) 64512 65534 do prywatnego użytku Obecnie zarejestrowano trochę ponad 39935 ASN, z czego około 21000 jest widocznych w globalnych tablicach routingu 30

Protokół BGP internal BGP vs external BGP ebgp ibgp ebgp AS100 AS200 ibgp sesje pomiędzy routerami w tym samym AS wszystkie routery wewnątrz AS muszą nawiązać sesje każdy z każdym (można to obejść przez konfederacje/klastry) ebgp sesje pomiędzy routerami w różnych AS domyślnie połączenie bezpośrednie, należy wprost wskazać że połączenie jest multihop 31

Protokół BGP Jak BGP wybiera najlepszą trasę? (wersja skrócona) Najwyższy local preference (w ramach AS) Najkrótsza ścieżka AS Path Najniższy kod pochodzenia (Origin) IGP < EGP < incomplete Najniższa wartość MED (Multi Exit Discriminator) Lepiej trasa z ebgp niż z ibgp Najpierw trasa z niższym kosztem wg. IGP do next hop Najniższy router id routera BGP Najniższy adres peer a (pełna lista w RFC4271) 32

Protokół BGP Atrybuty pozwalające wpływać na trasę 1: ORIGIN 2: AS PATH 3: NEXT HOP 4: MED 5: LOCAL_PREF 6: ATOMIC_AGGREGATE 7: AGGREGATOR 8: COMMUNITY 9: ORIGINATOR_ID 10: CLUSTER_LIST 14: MP_REACH_NLRI 15: MP_UNREACH_NLRI 33

Protokół BGP Atrybuty AS Path Trasa, jaką prefiks przeszedł Mechanizm zapobiegający pętlom Narzędzie narzucania polityki 34

Protokół BGP Atrybuty local preference 35

Protokół BGP Atrybuty community Opisane w RFC1997, mogą być przekazywane pomiędzy ASami (transitive) i są opcjonalne 32 bitowa wartość dodatnia Dla wygody zapisywana jako dwie 16 bitowe wartości rozdzielone dwukropkiem Standardowo <NUMER AS>:XXXX Na przykład: 64999:666 Bardzo przydatne i często spotykane w publicznych peeringach do sterowania polityką dotyczącą oznaczonego prefiksu 36

Protokół BGP Ilustracja działania nadawanie community otrzymywanym prefiksom 1.1.1.0/24 route map prefiks: 1.1.1.0/24 oznacz: 200:100 AS100 4.4.4.1 4.4.4.4 AS200 1.1.1.0/24 via 4.4.4.4, AS200, 200:100 37

Protokół BGP Ilustracja działania wysyłanie odpowiednio oznaczonych community 1.1.1.0/24 AS5617 route map TAG8246 4.4.4.1 prefiks: 1.1.1.0/24 oznacz: 8246:2103 AS100 4.4.4.4 AS8246 1.1.1.0/24 via 4.4.4.4, AS100 1.1.1.0/24: AS100, AS8246, AS8246, AS8246 router bgp 100 neighbor 4.4.4.4 route map 8246 out 38

Protokół BGP Ilustracja działania wysyłanie odpowiednio oznaczonych community 1.1.1.0/24 AS5617 route map prefiks: 1.1.1.0/24 oznacz: 8246:2103 AS100 4.4.4.1 4.4.4.4 AS8246 1.1.1.0/24 via 4.4.4.4, AS100 1.1.1.0/24: AS100, AS8246, AS8246, AS8246 39

CZY MUSZĘ UŻYWAĆ BGP? 40

Czy na pewno muszę mieć BGP? Pojedyncze połączenie do Internetu NIE w sieci używasz domyślnej trasy (statycznie lub protokół routingu) Twój ISP zapewnia widoczność i osiągalność przydzielonej Ci adresacji IP Nawet jeśli łącza są dwa lub trzy do tego samego ISP, BGP nie jest potrzebne wiele tras domyślnych na różne IP po stronie Twojej i ISP 192.168.1.0/24 0.0.0.0/0 ISP A B 192.168.1.0/24 C 41

Czy na pewno muszę mieć BGP? Jeśli jesteś połączony do dwóch różnych ISP BGP jest pożądane rozgłasza do obu swoją pulę adresów, Internet widzi ją przez obu ISP Nie oznacza to, że musisz pobierać wszystkie światowe prefiksy...pozwala to jednak świadomie kształtować własną politykę routingu dużo dokładniej 192.168.1.0/24 ISP A AS65000 0.0.0.0/0 A 192.168.1.0/24 ISP B AS65001 42

PRZYKŁAD ZASTOSOWANIA BGP 43

...nasza sieć: internet ISP A ISP B (AS300) (AS200) A B AS100 10.10.10.0/24 44

Protokół BGP Przykładowa konfiguracja router A prefix oraz sesje ebgp router bgp 100 bgp router id 10.10.10.253 network 10.10.10.0 mask 255.255.255.0 aggregate address 10.10.10.0 255.255.255.0 summary only neighbor 172.16.10.1 remote as 200 neighbor 172.16.10.1 description AS200 neighbor 172.16.10.1 version 4 neighbor 172.16.10.1 password AJAX*PERSIL*E neighbor 10.10.10.2 remote as 100 neighbor 10.10.10.2 description router B neighbor 10.10.10.2 version 4 neighbor 10.10.10.2 password BEZ*MD5*JEST*ZIA ZIA 45

...nasza sieć: internet ISP A ISP B (AS300) (AS200) 10.10.10.0/24 10.10.10.0/24 AS100 46

Przykładowy problem: łącze z ISP B jest przeciążone internet ISP A ISP B (AS300) (AS200) AS100 Dwa podstawowe narzędzia: AS Prepend Rozdzielenie prefiksów 47

Przykładowy problem: łącze z ISP B jest przeciążone Pogorszenie atrakcyjności własnego prefiksu 10.10.10.0/24 przez AS200 router bgp 100 neighbor 172.16.10.1 remote as 200 neighbor 172.16.10.1 route map KuLepszejPrzyszlosci out route map KuLepszejPrzyszlosci permit 10 set as path prepend 100 100 AS200rtr# show ip bgp 10.0.10.0 Network Next Hop LocPrf Path * 10.0.10.0/24 172.16.10.2 100 100 100 100 i *> 172.16.99.1 100 300 100 i 48

Przykładowy problem: większość ruchu wychodzi przez ISP A internet ISP A ISP B (AS300) (AS200) 4Mbit/s 25Mbit/s Podstawowe narzędzie: local preference AS100 49

Przykładowy problem: większość ruchu wychodzi przez ISP A Wszystkie prefiksy otrzymane z AS200 są lepsze niż inne, z domyślnym (100) local preference router bgp 100 neighbor 172.16.10.1 remote as 200 neighbor 172.16.10.1 route map KuLepszejPrzyszlosci in route map KuLepszejPrzyszlosci permit 10 set local preference 5000 50

Przykładowy problem: do sieci 8.8.8.0/24 zawsze lepiej przez ISP A 8.8.8.0/24 internet ISP A ISP B (AS300) (AS200) AS100 51

Protokół BGP Prefiks 8.8.8.0/24 w pierwszej kolejności przez ISP A Tylko prefiks 8.8.8.0/24 lub bardziej dokładny jest zawsze lepszy przez AS300 router bgp 100 neighbor 172.16.20.1 remote as 300 neighbor 172.16.20.1 route map KuLepszejPrzyszlosci in ip prefix list JedynaDroga permit 8.8.8.0/24 le 32 route map KuLepszejPrzyszlosci permit 10 match ip prefix list JedynaDroga set local preference 5000 Dobry opis jak działają prefix listy: http://www.groupstudy.com/archives/ccielab/200404/msg00539.html 52

ROUTING DYNAMICZNY A INNE ZAGADNIENIA 53

Routing dynamiczny a inne zagadnienia NAT W momencie, w którym routery robią NAT... 172.16.10.0/24? 172.16.10.0/24 172.16.10.0/24 172.16.10.0/24 Uwaga na nakładające się podsieci prywatne przy redystrybucji tras połączonych/statycznych do protokołów routingu dynamicznego! Trasy można odfiltrować nawet, jeśli redystrybucja jest włączona 54

Routing dynamiczny a inne zagadnienia NAT Filtrowanie sieci z RFC1918 przy redystrybucji tras połączonych/statycznych do OSPFa: router ospf redistribute kernel route map NORFC1918 route map NORFC1918 permit 10 match ip address prefix list 10 ip prefix list 10 deny 10.0.0.0/8 le 32 ip prefix list 10 deny 172.16.0.0/12 le 32 ip prefix list 10 deny 192.168.0.0/16 le 32 ip prefix list 10 permit any 55

Routing dynamiczny a inne zagadnienia Filtrowanie ruchu Protokoły routingu mają swoje wymagania co do przepuszczanego ruchu: RIPv1 520/udp RIPv2 multicast pod adres 224.0.0.9 na 520/udp za pomocą wskazania wprost sąsiada można dodatkowo wysyłać pakiety unicast (przydatne przy tunelach IPsec) OSPF multicast, protokół IP numer 89 BGP protokół TCP na/z portu 179 56

Routing dynamiczny a inne zagadnienia Tunelowanie IP w IP i GRE Tunele GRE pozwalają przenieść multicasty oraz inne protokoły warstwy 3 w szczególności IPX wygodne i funkcjonalne połączenie dwóch sieci z możliwością zapewnienia działania protokołów RIPv2 i OSPF quagga automatycznie konfiguruje interfejsy gre jako punkt punkt, ale tylko te, które istnieją zanim zostanie uruchomiona warto sprawdzić, czy interfejs jest widziany jako posiadający flagę multicast różnie dla różnych kerneli i wersji pakietu 57

Routing dynamiczny a inne zagadnienia QoS Mechanizmy/polityka QoS powinna w szczególności dotyczyć protokołów routingu Priorytet dla pakietów hello, oraz zapewniających funkcjonowanie protokołów routingu powinien być pierwszym składnikiem polityki (przed gwarancjami dla VoIP itp.) Zastosowanie mechanizmów nawet, jeśli nie ma potrzeby ich stosowania daje ochronę w trakcie ataków (D)DoS oraz np. infekcji wirusami/trojanami 58

Routing dynamiczny a inne zagadnienia MPLS Linux posiada już infrastrukturę wielu tabel routingu iproute2 etc. Implementacja architektury MPLS wymaga: wyposażenia infrastruktury sterowników sieciowych w mechanizmy odpowiedniej hermetyzacji tagów MPLS (Ethernet/FR/ATM) stworzenia demona odpowiedzialnego za sygnalizację (LDP) stworzenia mechanizmu dla obsługi inżynierii ruchu (RSVP lub OSPF TE) Testowane: http://sourceforge.net/projects/mpls linux/ http://www.cs.virginia.edu/~mngroup/projects/mpls/ 59

First Hop Redundancy Standardy: VRRP Cisco made: HSRP i GLBP Inne: CARP Idea: podstawić jeden wirtualny router w miejsce wielu fizycznych i zapewnić obsługę routingu wirtualny IP i wirtualny MAC 60

First Hop Redundancy VRRP standard (RFC3768) VRRPd: http://off.net/~jme/vrrpd/ FreeVRRPd CARP/UCARP analogiczne dla OpenBSD/innych systemów http://www.ucarp.org/project/ucarp Integracja aplikacji i systemu operacyjnego: LVS: http://www.linuxvirtualserver.org/ ct_sync (netfilter) + keepalived + LVS/coś innego: http://svn.netfilter.org/cgi bin/viewcvs.cgi/trunk/netfilter ha/ http://www.netfilter.org/projects/libnetfilter_conntrack/index.html 61

GDZIE WARTO RZUCIĆ OKIEM 62

Książki 63

Zasoby WWW Test routerów opartych o Quaggę/XORP http://www.networkworld.com/reviews/2006/100906 quagga router test.html Pakiet Quagga: http://www.quagga.net Pakiet XORP: http://www.xorp.org Demon OpenOSPFd/OpenBGPd: http://www.openbsd.org 64

Zasoby WWW Einar LiveCD wykorzystujące Xen i Quaggę: http://www.isk.kth.se/proj/einar/ IP routing protocols home page (Cisco): http://www.cisco.com/en/us/tech/tk365/tsd_technolo gy_support_protocol_home.html OSPF MANET: http://folk.uio.no/kenneho/index.php?page=studies&s ubpage=wospf 65

& 66