Border Gateway Protocol (BGP) Structure of the Internet Networks - - PowerPoint PPT Presentation

border gateway protocol bgp structure of the internet
SMART_READER_LITE
LIVE PREVIEW

Border Gateway Protocol (BGP) Structure of the Internet Networks - - PowerPoint PPT Presentation

Border Gateway Protocol (BGP) Structure of the Internet Networks (ISPs, CDNs, etc.) group with IP prefixes Networks are richly interconnected, often using IXPs Prefix B1 Prefix D1 Prefix C1 ISP B CDN D IXP CDN C IXP Prefix E1


slide-1
SLIDE 1

Border Gateway Protocol (BGP)

slide-2
SLIDE 2

Structure of the Internet

  • Networks (ISPs, CDNs, etc.) group with IP prefixes
  • Networks are richly interconnected, often using IXPs

CDN C Prefix C1 ISP A Prefix A1 Prefix A2 Net F Prefix F1

IXP IXP IXP IXP

CDN D Prefix D1 Net E Prefix E1 Prefix E2 ISP B Prefix B1

slide-3
SLIDE 3

Internet-wide Routing

Two requirements not met by simple routing

  • 1. Incorporating policy decisions
  • Letting parties choose routes to suit their own needs
  • 2. Scaling to very large networks
  • Prefix aggregation
slide-4
SLIDE 4

Effects of Independent Parties

  • Each party selects routes to

suit its own interests

  • e.g, shortest path in ISP
  • What path will be chosen

for A2àB1 and B1àA2?

  • What is the best path?

Prefix B2 Prefix A1

ISP A ISP B

Prefix B1 Prefix A2

slide-5
SLIDE 5

Effects of Independent Parties (2)

  • Selected paths are longer

than overall shortest path

  • And asymmetric too!
  • Consequence of

independent decisions

Prefix B2 Prefix A1

ISP A ISP B

Prefix B1 Prefix A2

slide-6
SLIDE 6

Routing Policies

  • Capture the goals of different parties
  • Could be anything
  • E.g., Internet2 only carries non-commercial traffic
  • Common policies we’ll look at:
  • ISPs give TRANSIT service to customers
  • ISPs give PEER service to each other
slide-7
SLIDE 7

Routing Policies – Transit

  • One party (customer) gets TRANSIT

service from another party (ISP)

  • ISP accepts traffic for customer from

the rest of Internet

  • ISP sends traffic from customer to the

rest of Internet

  • Customer pays ISP for the privilege

Customer 1

ISP

Customer 2

Rest of Internet

Non- customer

slide-8
SLIDE 8

Routing Policies – Peer

  • Both party (ISPs in example) get

PEER service from each other

  • Each ISP accepts traffic from the other

ISP only for their customers

  • ISPs do not carry traffic to the rest of

the Internet for each other

  • ISPs don’t pay each other

Customer A1

ISP A

Customer A2 Customer B1

ISP B

Customer B2

slide-9
SLIDE 9

Routing with BGP

  • iBGP is used for “internal” routing
  • eBGP is interdomain routing for the Internet
  • Path vector, a kind of distance vector

ISP A Prefix A1 Prefix A2 Net F Prefix F1

IXP

ISP B Prefix B1 Prefix F1 via ISP B, Net F at IXP

slide-10
SLIDE 10

Routing with BGP (2)

  • Parties like ISPs are called AS (Autonomous Systems)
  • AS numbers are unique identifiers
  • AS’s configure their internal BGP routes
  • External routes go through complicated filters
  • Intra-AS BGP routers communicate (via iBGP) to keep

consistent routing information

slide-11
SLIDE 11

Routing with BGP (3)

  • Border routers of ASes announce BGP routes
  • Route announcements have IP prefix, path

vector, next hop

  • Path vector is list of ASes on the way to the prefix
  • List is to find loops
  • Route announcements move in the opposite

direction to traffic

slide-12
SLIDE 12

Routing with BGP (4)

Prefix

slide-13
SLIDE 13

Routing with BGP (5)

Policy is implemented in two ways:

  • 1. Border routers of ISP announce paths only to
  • ther parties who may use those paths
  • Filter out paths others can’t use
  • 2. Border routers select the best path of the ones

they hear in any way (not necessarily shortest)

slide-14
SLIDE 14

Routing with BGP (6)

  • TRANSIT: AS1 says [B, (AS1, AS3)], [C, (AS1, AS4)] to AS2
slide-15
SLIDE 15

Routing with BGP (7)

  • CUSTOMER (other side of TRANSIT): AS2 says [A, (AS2)] to AS1
slide-16
SLIDE 16

Routing with BGP (8)

  • PEER: AS2 says [A, (AS2)] to AS3, AS3 says [B, (AS3)] to AS2
slide-17
SLIDE 17

Routing with BGP (9)

  • AS2 has two routes to B (AS1, AS3) and chooses AS3 (Free!)
slide-18
SLIDE 18

BGP “bad gadget”: Non-convergence

[3, 0] > [0] > [3, 1, 0] [2, 0] > [0] > [2, 3, 0] [1, 0] > [0] > [1, 2, 0]

slide-19
SLIDE 19

BGP slow convergence

1 2 3 4 [1, 0]

  • [3, 1, 0]

[4, 1, 0] [1, 0]

  • [2, 1, 0]

[3, 1, 0] [1, 0]

  • [4, 1, 0]

[2, 1, 0]

x

slide-20
SLIDE 20

BGP slow convergence

1 2 3 4 [3, 1, 0]

  • [4, 1, 0]

[2, 1, 0]

  • [3, 1, 0]

[4, 1, 0]

  • [2, 1, 0]

x

slide-21
SLIDE 21

BGP slow convergence

1 2 3 4 [3, 4, 1, 0] [2, 3, 1, 0] [4, 2, 1, 0]

x

slide-22
SLIDE 22

Implementing policy in BGP

  • 1. Export policy
  • Determines what to announce to whom
  • 2. Import policy
  • Determine how to modify (or drop) incoming announcements
  • 3. Decision process
  • Determine “best” path among all those available
slide-23
SLIDE 23

Export policy

Arbitrary transformation and filtering of route attributes

  • Legal transformations for (10.10.10.0/24, [12, 42], [com1, com2])
  • (10.10.10.0/24, [12, 24, 93], [com1, com2])
  • (10.10.10.0/24, [12, 24, 93, 93, 93, 93], [com1, com2])
  • (10.10.10.0/24, [93], [com1, com2])
  • (10.10.10.0/24, [12, 24, 93], [])
  • (10.10.10.0/24, [12, 24, 93], [com1, com32])

In addition, one may aggregate

  • Only announce, 10.10.0.0/16
  • Typically done only if a sub-prefix is present
slide-24
SLIDE 24

Import policy

Arbitrary transformation and filtering of route attributes And attach a numerical “local preference” attribute

slide-25
SLIDE 25

Decision process

Standard process (all the mauling happens beforehand)

  • 1. Prefer higher local preference
  • 2. Prefer locally originated routes
  • 3. Prefer shorter AS path
  • 4. Prefer eBGP over iBGP
  • 5. Prefer lower internal cost
  • 6. Prefer lower router ID
slide-26
SLIDE 26
slide-27
SLIDE 27