Improving QOS in IP Networks

51
7: Multimedia Networking 7-1 Improving QOS in IP Networks Thus far: “making the best of best effort” Future: next generation Internet with QoS guarantees RSVP: signaling for resource reservations Differentiated Services: differential guarantees Integrated Services: firm guarantees simple model for sharing and congestion studies:

description

Improving QOS in IP Networks. Thus far: “making the best of best effort” Future: next generation Internet with QoS guarantees RSVP: signaling for resource reservations Differentiated Services: differential guarantees Integrated Services: firm guarantees - PowerPoint PPT Presentation

Transcript of Improving QOS in IP Networks

Page 1: Improving QOS in IP Networks

7: Multimedia Networking 7-1

Improving QOS in IP NetworksThus far: “making the best of best effort”Future: next generation Internet with QoS guarantees

RSVP: signaling for resource reservations Differentiated Services: differential guarantees Integrated Services: firm guarantees

simple model for sharing and congestion studies:

Page 2: Improving QOS in IP Networks

7: Multimedia Networking 7-2

Principles for QOS Guarantees

Example: 1Mbps, I P phone, FTP share 1.5 Mbps link. bursts of FTP can congest router, cause audio loss want to give priority to audio over FTP

packet marking needed for router to distinguish between different classes; and new router policy to treat packets accordingly

Principle 1

Page 3: Improving QOS in IP Networks

7: Multimedia Networking 7-3

Principles for QOS Guarantees (more) what if applications misbehave (audio sends higher

than declared rate) policing: force source adherence to bandwidth allocations

marking and policing at network edge: similar to ATM UNI (User Network Interface)

provide protection (isolation) for one class from othersPrinciple 2

Page 4: Improving QOS in IP Networks

7: Multimedia Networking 7-4

Principles for QOS Guarantees (more)

Allocating fixed (non-sharable) bandwidth to flow: inefficient use of bandwidth if flows doesn’t use its allocation

While providing isolation, it is desirable to use resources as efficiently as possible

Principle 3

Page 5: Improving QOS in IP Networks

7: Multimedia Networking 7-5

Principles for QOS Guarantees (more)

Basic fact of life: can not support traffic demands beyond link capacity

Call Admission: flow declares its needs, network may block call (e.g., busy signal) if it cannot meet needs

Principle 4

Page 6: Improving QOS in IP Networks

7: Multimedia Networking 7-6

Summary of QoS Principles

Let’s next look at mechanisms for achieving this ….

Page 7: Improving QOS in IP Networks

7: Multimedia Networking 7-7

What Can a Basic Router do to Packets?

Send it… Delay it… Drop it… How they are done impacts Quality of Service

Best effort? Guaranteed delay? Guaranteed throughput?

Many variations in policies with different behavior Rich body of research work to understand them Limited Internet deployment

Many practical deployment barriers since Internet was best-effort to begin with, adding new stuff is hard

Some people just don’t believe in the need for QoS! Not enough universal support

Page 8: Improving QOS in IP Networks

7: Multimedia Networking 7-8

Router Architecture Assumptions

Assumes inputs just forward packets to outputs Switch core is N times faster than links in a NxN switch

Resource contention occurs only at the output interfaces Output interface has classifier, buffer/queue, scheduler

components

1

2

SchedulerClassifier Buffer/Queue

Page 9: Improving QOS in IP Networks

7: Multimedia Networking 7-9

Internet Classifier

A “flow” is a sequence of packets that are related (e.g. from the same application)

Flow in Internet can be identified by a subset of following fields in the packet header

source/destination IP address (32 bits) source/destination port number (16 bits) protocol type (8 bits) type of service (4 bits)

Examples: All packets from OSU All packets between OSU and Berkeley All UDP packets from OSU ECE department

Classifier takes a packet and decides which flow it belongs to

Page 10: Improving QOS in IP Networks

7: Multimedia Networking 7-10

Buffer/Queue

Buffer: memory where packets can be stored temporarily

Queue: using buffers to store packets in an ordered sequence E.g. First-in-First-Out (FIFO) queue

Buffer

Packet

Packet

Packet

Packet

Buffer

Packet

Packet

Packet

Packet

HeadOf Queue

Page 11: Improving QOS in IP Networks

7: Multimedia Networking 7-11

Buffer/Queue

When packets arrive at an output port faster than the output link speed (perhaps only momentarily)

Can drop all excess packets Resulting in low performance

Or can hold excess packets in buffer/queue Resulting in some delay, but better performance

Still have to drop packets when buffer is full For a FIFO queue, “drop tail” or “drop head” are common

policies, i.e. drop last packet to arrive vs drop first packet in queue to make room

A chance to be smart: Transmission of packets held in buffer/queue can be *scheduled* Which stored packet goes out next? Which is more

“important”? Impacts quality of service

Page 12: Improving QOS in IP Networks

7: Multimedia Networking 7-12

Fair Rate Computation

Denote C – link capacity N – number of flows ri – arrival rate

Max-min fair rate computation:1. compute C/N2. if there are flows i such that ri <= C/N, update C and N

3. if no, f = C/N; terminate4. go to 1

A flow can receive at most the fair rate, i.e., min(f, ri)

Crtsi ii

rCC.

Page 13: Improving QOS in IP Networks

7: Multimedia Networking 7-13

Example of Fair Rate Computation

C = 10; r1 = 8, r2 = 6, r3 = 2; N = 3 C/3 = 3.33 C = C – r3 = 8; N = 2 C/2 = 4; f = 4

8

6

244

2

f = 4: min(8, 4) = 4 min(6, 4) = 4 min(2, 4) = 2

10

Page 14: Improving QOS in IP Networks

7: Multimedia Networking 7-14

6

Max-Min Fairness

Associate a weight wi with each flow i If link congested, compute f such that

Cwfr ii

i ),min(

8

6

222

f = 2: min(8, 2*3) = 6 min(6, 2*1) = 2 min(2, 2*1) = 2

10(w1 = 3)

(w2 = 1)

(w3 = 1)

Page 15: Improving QOS in IP Networks

7: Multimedia Networking 7-15

Scheduler

Decides how the output link capacity is shared by flows Which packet from which flow gets to go out next?

E.g. FIFO schedule Simple schedule: whichever packet arrives first leaves

first Agnostic of concept of flows, no need for classifier, no

need for a real “scheduler”, a FIFO queue is all you need

E.g. TDMA schedule Queue packets according to flows

• Need classifier and multiple FIFO queues Divide transmission times into slots, one slot per flow Transmit a packet from a flow during its time slot

Page 16: Improving QOS in IP Networks

7: Multimedia Networking 7-16

TDMA Scheduling

1

2

TDMAScheduler

flow 1

flow 2

flow n

Classifier

Buffer management

Page 17: Improving QOS in IP Networks

7: Multimedia Networking 7-17

Priority Scheduling

Priority scheduling: transmit highest priority queued packet

multiple classes, with different priorities class may depend on marking or other header info,

e.g. IP source/dest, port numbers, etc..

Page 18: Improving QOS in IP Networks

7: Multimedia Networking 7-18

Round Robin Scheduling

round robin scheduling: multiple classes cyclically scan class queues, serving one from each class (if available)

Page 19: Improving QOS in IP Networks

7: Multimedia Networking 7-19

Internet Today

FIFO queues are used at most routers No classifier, no scheduler, best-effort

Sophisticated mechanisms tend to be more common near the “edge” of the network E.g. At campus routers Use classifier to pick out BitTorrent packets Use scheduler to limit bandwidth consumed by

BitTorrent traffic

Page 20: Improving QOS in IP Networks

7: Multimedia Networking 7-20

Achieving QoS in Statistical Multiplexing Network

We want guaranteed QoS But we don’t want the inefficiency of TDMA

Unused time slots are “wasted”

Want to statistically share un-reserved capacity or reserved but unused capacity

One solution: Weighted Fair Queuing (WFQ) Guarantees a flow receives at least its allocated bit

rate

Page 21: Improving QOS in IP Networks

7: Multimedia Networking 7-21

WFQ Architecture

1

2

WFQScheduler

flow 1

flow 2

flow n

Classifier

Buffer management

Page 22: Improving QOS in IP Networks

7-22

What is Weighted Fair Queueing?

Each flow i given a weight (importance) wi

WFQ guarantees a minimum service rate to flow i ri = R * wi / (w1 + w2 + ... + wn) Implies isolation among flows (one cannot mess up

another)

w1

w2

wn

R

Packet queues

Page 23: Improving QOS in IP Networks

7-23

Intuition: Fluid Flow

w1

water pipesw2

w3

t1

t2

w2 w3

water buckets

w1

Page 24: Improving QOS in IP Networks

7: Multimedia Networking 7-24

Fluid Flow System

If flows can be served one bit at a time WFQ can be implemented using bit-by-bit

weighted round robin During each round from each flow that has data to send,

send a number of bits equal to the flow’s weight

Page 25: Improving QOS in IP Networks

7: Multimedia Networking 7-25

Fluid Flow System: Example 1

1 2 31 2

43 4

55 6

Flow 2(arrival traffic) time

Flow 1(arrival traffic) time

1 2 3 4 5

1 2 3 4 5 6

Packet Size

(bits)

Packet inter-arrival time (ms)

Arrival Rate

(Kbps)

Flow 1

1000 10 100

Flow 2

500 10 50

100 KbpsFlow 1 (w1 = 1)

Flow 2 (w2 = 1)

Servicein fluid flow

system time (ms)0 10 20 30 40 50 60 70 80

Page 26: Improving QOS in IP Networks

7: Multimedia Networking 7-26

Fluid Flow System: Example 2

0 152 104 6 8

5 1 1 11 1

Red flow has packets backlogged between time 0 and 10

Backlogged flow flow’s queue not empty

Other flows have packets continuously backlogged

All packets have the same size

flows

link

weights

Page 27: Improving QOS in IP Networks

7: Multimedia Networking 7-27

Fluid Flow System

0

5

10

15

20

25

30

35

time

queu

e si

ze A

B

C

50 6030

Packets of size 10, 20 & 30 arrive at time 0

Page 28: Improving QOS in IP Networks

7: Multimedia Networking 7-28

Fluid Flow System

0

5

10

15

20

25

time

queu

e si

ze A

B

C

5 15 3040 45

Packets: time 0 size 15 time 5 size 20 time 15 size 10

Page 29: Improving QOS in IP Networks

7: Multimedia Networking 7-29

Fluid Flow System

0

5

10

15

20

25

time

queu

e si

ze A

B

C

5 15 30 45 60

Packets: time 0 size 15 time 5 size 20 time 15 size 10time 18 size 15

Page 30: Improving QOS in IP Networks

7: Multimedia Networking 7-30

Implementation in Packet System

Packet (Real) system: packet transmission cannot be preempted. Why?

Solution: serve packets in the order in which they would have finished being transmitted in the fluid flow system

Page 31: Improving QOS in IP Networks

7: Multimedia Networking 7-31

Packet System: Example 1

0 2 104 6 8

0 2 104 6 8

Select the first packet that finishes in the fluid flow system

Servicein fluid flow

system

Packetsystem

Page 32: Improving QOS in IP Networks

7: Multimedia Networking 7-32

Packet System: Example 2

1 2 1 3 2 3 4 4 55 6Packetsystem time

1 2 31 2

43 4

55 6

Servicein fluid flow

system time (ms)

Select the first packet that finishes in the fluid flow system

Page 33: Improving QOS in IP Networks

7: Multimedia Networking 7-33

Implementation Challenge

Need to compute the finish time of a packet in the fluid flow system…

… but the finish time may change as new packets arrive!

Need to update the finish times of all packets that are in service in the fluid flow system when a new packet arrives

But this is very expensive; a high speed router may need to handle hundred of thousands of flows!

Page 34: Improving QOS in IP Networks

7: Multimedia Networking 7-34

Example

Four flows, each with weight 1

Flow 1

time

time

ε

time

time

Flow 2

Flow 3

Flow 4

0 1 2 3

Finish times computed at time 0

time

time

Finish times re-computed at time ε

0 1 2 3 4

Page 35: Improving QOS in IP Networks

7: Multimedia Networking 7-35

Solution: Virtual Time

Key Observation: while the finish times of packets may change when a new packet arrives, the order in which packets finish doesn’t!

Only the order is important for scheduling

Solution: instead of the packet finish time maintain the round # when a packet finishes (virtual finishing time)

Virtual finishing time doesn’t change when a packet arrives

System virtual time V(t) – index of the round in the bit-by-bit round robin scheme

Page 36: Improving QOS in IP Networks

7: Multimedia Networking 7-36

Example

Suppose each packet is 1000 bits, so takes 1000 rounds to finish

So, packets of F1, F2, F3 finishes at virtual time 1000

When packet F4 arrives at virtual time 1 (after one round), the virtual finish time of packet F4 is 1001

But the virtual finish time of packet F1,2,3 remains 1000

Finishing order is preserved

Flow 1

time

time

ε

time

time

Flow 2

Flow 3

Flow 4

Page 37: Improving QOS in IP Networks

7: Multimedia Networking 7-37

System Virtual Time (Round #): V(t) V(t) increases inversely proportionally to the sum of the weights of the

backlogged flows Since round # increases slower when there are more flows to visit each round.

1 2 31 2

43 4

55 6

Flow 2 (w2 = 1)

Flow 1 (w1 = 1)

time

time

C

C/2V(t)

Page 38: Improving QOS in IP Networks

7: Multimedia Networking 7-38

Virtual Time Implementation of Weighted Fair Queueing

w j

kjk

jkj

LSF

0)0( V

))(,max( 1 kj

kj

kj aVFS

ajk – arrival time of packet k of flow j

Sjk – virtual starting time of packet k of flow j

Fjk – virtual finishing time of packet k of flow j

Ljk – length of packet k of flow j

BJ - backlog flow (flow with packets in queue)

Packets are sent in the increasing order of Fjk

jBii

jj wtVtV

)()(

Page 39: Improving QOS in IP Networks

7-39

Properties of WFQ

Guarantee that any packet is transmitted within packet_length/link_capacity of its transmission time in the fluid flow system

Can be used to provide guaranteed services

Achieve fair allocation Can be used to protect well-behaved flows against

malicious flows

Page 40: Improving QOS in IP Networks

7: Multimedia Networking 7-40

Policing Mechanisms

Page 41: Improving QOS in IP Networks

7: Multimedia Networking 7-41

Policing Mechanisms

Goal: limit traffic to not exceed declared parameters

Three common-used criteria:

(Long term) Average Rate: how many pkts can be sent per unit time (in the long run) crucial question: what is the interval length: 100 packets per sec or 6000 packets per

min have same average!

Peak Rate: e.g., 6000 pkts per min. (ppm) avg.; 1500 ppm peak rate (Max.) Burst Size: max. number of pkts sent consecutively (with no

intervening idle)

Page 42: Improving QOS in IP Networks

7: Multimedia Networking 7-42

Policing Mechanisms

1. Leaky Bucket Algorithm

2. Token Bucket Algorithm

Page 43: Improving QOS in IP Networks

7: Multimedia Networking 7-43

The Leaky Bucket Algorithm

The Leaky Bucket Algorithm used to control rate in a network.

Implemented as a single-server queue with constant service time.

If the bucket (buffer) overflows then packets are discarded.

Page 44: Improving QOS in IP Networks

7: Multimedia Networking 7-44

The Leaky Bucket Algorithm

(a) A leaky bucket with water. (b) a leaky bucket with packets.

Page 45: Improving QOS in IP Networks

7: Multimedia Networking 7-45

The leaky bucket enforces a constant output rate regardless of the burstiness of the input. Does nothing when input is idle.

The host injects one packet per clock tick onto the network. This results in a uniform flow of packets, smoothing out bursts and reducing congestion.

When packets are the same size (as in ATM cells), the one packet per tick is okay. For variable length packets though, it is better to allow a fixed number of bytes per tick.

The Leaky Bucket Algorithm

Page 46: Improving QOS in IP Networks

7: Multimedia Networking 7-46

Token Bucket

Token Bucket: limit input to specified Burst Size and Average Rate.

bucket can hold b tokens tokens generated at rate r token/sec unless

bucket full over interval of length t: number of packets

admitted less than or equal to (r t + b).

Page 47: Improving QOS in IP Networks

7: Multimedia Networking 7-47

Token Bucket Characterized by three parameters (b, r, R)

b – token depth r – average arrival rate R – maximum arrival rate (e.g., R link capacity)

A bit is transmitted only when there is an available token When a bit is transmitted exactly one token is consumed

r tokens per second

b tokens

<= R bps

regulatortime

bits

b*R/(R-r)

slope R

slope r

Page 48: Improving QOS in IP Networks

7: Multimedia Networking 7-48

Characterizing a Source by Token Bucket

Arrival curve – maximum amount of bits transmitted by time t Use token bucket to bound the arrival curve

time

bits

Arrival curve

time

bps

Page 49: Improving QOS in IP Networks

7: Multimedia Networking 7-49

Example Arrival curve – maximum amount of bits transmitted by time t Use token bucket to bound the arrival curve

size of timeinterval

bitsArrival curve

time

bps

0 1 2 3 4 5

1

2

1 2 3 4 5

1

2

3

4

(b=1,r=1,R=2)

Page 50: Improving QOS in IP Networks

7: Multimedia Networking 7-50

Policing Mechanisms

token bucket, WFQ combine to provide guaranteed upper bound on delay, i.e., QoS guarantee!

WFQ

token rate, r

bucket size, b

per-flowrate, R

D = b/Rmax

arrivingtraffic

Page 51: Improving QOS in IP Networks

7: Multimedia Networking 7-51

Leaky Bucket vs. Token Bucket

Leaky Bucket vs Token Bucket

With TB, a packet can only be transmitted if there are enough tokens to cover its length in bytes.

LB sends packets at an average rate. TB allows for large bursts to be sent faster by speeding up the output.

TB allows saving up tokens (permissions) to send large bursts. LB does not allow saving.