Modeling TCP Throughput: A Simple Model and its Empirical Validation Jitendra Padhye, Victor Firoiu, Don Towsley, and Jim Kurose SIGCOMM 1998.

Slides:



Advertisements
Similar presentations
Michele Pagano – A Survey on TCP Performance Evaluation and Modeling 1 Department of Information Engineering University of Pisa Network Telecomunication.
Advertisements

Modeling TCP Throughput Jitendra Padhye Victor Firoiu Don Towsley Jim Kurose Presented by Jaebok Kim A Simple Model and its Empirical Validation.
Simulation-based Comparison of Tahoe, Reno, and SACK TCP Kevin Fall & Sally Floyd Presented: Heather Heiman September 10, 2002.
1 Transport Protocols & TCP CSE 3213 Fall April 2015.
1 TCP Congestion Control. 2 TCP Segment Structure source port # dest port # 32 bits application data (variable length) sequence number acknowledgement.
ECE 4450:427/527 - Computer Networks Spring 2015
Computer Networks: TCP Congestion Control 1 TCP Congestion Control Lecture material taken from “Computer Networks A Systems Approach”, Fourth Edition,Peterson.
Introduction 1 Lecture 14 Transport Layer (Transmission Control Protocol) slides are modified from J. Kurose & K. Ross University of Nevada – Reno Computer.
School of Information Technologies TCP Congestion Control NETS3303/3603 Week 9.
Introduction to Congestion Control
Transport Layer 3-1 Fast Retransmit r time-out period often relatively long: m long delay before resending lost packet r detect lost segments via duplicate.
Congestion Control Tanenbaum 5.3, /12/2015Congestion Control (A Loss Based Technique: TCP)2 What? Why? Congestion occurs when –there is no reservation.
Transport Layer3-1 Congestion Control. Transport Layer3-2 Principles of Congestion Control Congestion: r informally: “too many sources sending too much.
Stochastic Differential Equation Modeling and Analysis of TCP- Windowsize Behavior EE228a Class Presentation Anshi Liang.
Modeling TCP Throughput Jeng Lung WebTP Meeting 11/1/99.
Computer Networks: TCP Congestion Control 1 TCP Congestion Control Lecture material taken from “Computer Networks A Systems Approach”, Third Ed.,Peterson.
1 Multimedia Streaming via TCP: An Analytic Performance Study Bing Wang, Jim Kurose, Prashant Shenoy, Don Towsley.
CSCE 515: Computer Network Programming Chin-Tser Huang University of South Carolina.
Week 9 TCP9-1 Week 9 TCP 3 outline r 3.5 Connection-oriented transport: TCP m segment structure m reliable data transfer m flow control m connection management.
Computer Networks : TCP Congestion Control1 TCP Congestion Control.
1 Chapter 3 Transport Layer. 2 Chapter 3 outline 3.1 Transport-layer services 3.2 Multiplexing and demultiplexing 3.3 Connectionless transport: UDP 3.4.
Data Communication and Networks
1 Validation and Verification of Simulation Models.
Networks : TCP Congestion Control1 TCP Congestion Control.
Networks : TCP Congestion Control1 TCP Congestion Control Presented by Bob Kinicki.
Estimating Congestion in TCP Traffic Stephan Bohacek and Boris Rozovskii University of Southern California Objective: Develop stochastic model of TCP Necessary.
Advanced Computer Networks: TCP Congestion Control 1 TCP Congestion Control Lecture material taken from “Computer Networks A Systems Approach”, Fourth.
TCP: flow and congestion control. Flow Control Flow Control is a technique for speed-matching of transmitter and receiver. Flow control ensures that a.
Lect3..ppt - 09/12/04 CIS 4100 Systems Performance and Evaluation Lecture 3 by Zornitza Genova Prodanoff.
Transport Layer3-1 Chapter 3 outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles.
Transport Layer3-1 Chapter 3 outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles.
Modeling TCP Throughput: A Simple Model and its Empirical Validation Ross Rosemark Penn State University.
TFRC: TCP Friendly Rate Control using TCP Equation Based Congestion Model CS 218 W 2003 Oct 29, 2003.
Principles of Congestion Control Congestion: informally: “too many sources sending too much data too fast for network to handle” different from flow control!
Chapter 12 Transmission Control Protocol (TCP)
27th, Nov 2001 GLOBECOM /16 Analysis of Dynamic Behaviors of Many TCP Connections Sharing Tail-Drop / RED Routers Go Hasegawa Osaka University, Japan.
Malathi Veeraraghavan Originals by Jörg Liebeherr 1 Error Control Congestion Control Timers.
Copyright 2008 Kenneth M. Chipps Ph.D. Controlling Flow Last Update
Copyright © Lopamudra Roychoudhuri
1 TCP - Part II Relates to Lab 5. This is an extended module that covers TCP data transport, and flow control, congestion control, and error control in.
Transport Layer 3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March
Modeling TCP Throughput: A Simple Model and its Empirical Validation Jitendra Padhye, Victor Firoiu, Don Towsley, and Jim Kurose Department of Computer.
Computer Networking Lecture 18 – More TCP & Congestion Control.
Lab The network simulator ns The network simulator ns Allows us to watch evolution of parameters like cwnd and ssthresh Allows us to watch evolution of.
TCP: Transmission Control Protocol Part II : Protocol Mechanisms Computer Network System Sirak Kaewjamnong Semester 1st, 2004.
1 CS 4396 Computer Networks Lab TCP – Part II. 2 Flow Control Congestion Control Retransmission Timeout TCP:
1 TCP Timeout And Retransmission Chapter 21 TCP sets a timeout when it sends data and if data is not acknowledged before timeout expires it retransmits.
Transport Layer3-1 Chapter 3 outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles.
1 Computer Networks Congestion Avoidance. 2 Recall TCP Sliding Window Operation.
TCP Congestion Control 컴퓨터공학과 인공지능 연구실 서 영우. TCP congestion control2 Contents 1. Introduction 2. Slow-start 3. Congestion avoidance 4. Fast retransmit.
TCP continued. Discussion – TCP Throughput TCP will most likely generate the saw tooth type of traffic. – A rough estimate is that the congestion window.
Network Coding and Reliable Communications Group Modeling Network Coded TCP Throughput: A Simple Model and its Validation MinJi Kim*, Muriel Médard*, João.
Transport Layer3-1 Chapter 3 outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles.
© Janice Regan, CMPT 128, CMPT 371 Data Communications and Networking Congestion Control 0.
TCP as a Reliable Transport. How things can go wrong… Lost packets Corrupted packets Reordered packets …Malicious packets…
Transmission Control Protocol (TCP) TCP Flow Control and Congestion Control CS 60008: Internet Architecture and Protocols Department of CSE, IIT Kharagpur.
Karn’s Algorithm Do not use measured RTT to update SRTT and SDEV Calculate backoff RTO when a retransmission occurs Use backoff RTO for segments until.
1 ICCCN 2003 Modelling TCP Reno with Spurious Timeouts in Wireless Mobile Environments Shaojian Fu School of Computer Science University of Oklahoma.
Other Methods of Dealing with Congestion
TCP - Part II Relates to Lab 5. This is an extended module that covers TCP flow control, congestion control, and error control in TCP.
Chapter 6 TCP Congestion Control
A Stochastic Model of TCP Reno Congestion Avoidance and Control
TCP - Part II Relates to Lab 5. This is an extended module that covers TCP flow control, congestion control, and error control in TCP.
Other Methods of Dealing with Congestion
Chapter 6 TCP Congestion Control
TCP Throughput Modeling
CS4470 Computer Networking Protocols
Chapter 3 outline 3.1 Transport-layer services
TCP flow and congestion control
TCP: Transmission Control Protocol Part II : Protocol Mechanisms
Presentation transcript:

Modeling TCP Throughput: A Simple Model and its Empirical Validation Jitendra Padhye, Victor Firoiu, Don Towsley, and Jim Kurose SIGCOMM 1998

Contributions characterization of the steady state throughput loss rateround trip timeDevelop a simple analytic characterization of the steady state throughput of a bulk transfer TCP flow (i.e., a flow with an unlimited amount of data to send) as a function of loss rate and round trip time the behavior of TCP’s fast retransmit mechanismthe effect of TCP’s timeout mechanismThe model captures both the behavior of TCP’s fast retransmit mechanism and the effect of TCP’s timeout mechanism on throughput The model can accurately predict throughput over a significantly wider range of loss rates than the previous works Explicitly models the effects of small receiver-side windows

A model for TCP Congestion Control congestion avoidanceFocus on the congestion avoidance behavior of TCP and its impact on throughput, taking into account the dependence of congestion avoidance on ACK behavior, the manner in which packet loss is inferred (dup ACK detection and fast retransmit or by timeout), limited receiver window size, and average round trip time (RTT) The model is based on TCP-Reno Recall: in TCP’s congestion avoidance, increased –the congestion window, W, is increased by 1/W each time a regular ACK is received decreased –conversely, the window is decreased whenever a lost packet is detected: the triple dup ACKsif the loss is detected by the triple dup ACKs, cwnd = cwnd / 2 timeoutif the loss is detected by timeout, cwnd = 1 (slow-start)

Details of the model “rounds”TCP’s congestion avoidance behavior is modeled in terms of “rounds”: W –a “round” starts with the back-to-back transmission of W packets, where W is the current size of the TCP congestion window W –once all packets falling within the congestion window have been sent in this back-to-back manner, no other packets are sent until the first ACK is received for one of these W packets –this ACK reception marks the end of the current round and the beginning of the next round the duration of a round –note that, in this model, the duration of a round is equal to the round trip time and is assumed to be independent of the window size

’At the beginning of the next round, a group of W’ new packets will be sent, where W’ is the new size of the congestion window bLet b be the number of packets that are acknowledged by a received ACK. (i.e., delayed ACK, b=2) W/b –if W packets are sent in the first round and are all received and acknowledged correctly, then W/b acks will be received 1/W W’ = W + 1/b –since each ack increases the window size by 1/W, the window size at the beginning of the second round is then W’ = W + 1/b during congestion avoidance and in the absence of loss 1/bthat is, during congestion avoidance and in the absence of loss, the window size increases linearly in time, with a slope of 1/b packets per round trip time

assumptions: –The duration of a round is assumed to be independent of the window size –The time needed to send all the packets in a window is smaller than the round trip time –A packet is lost in a round independently of any packets lost in other rounds –On the other hand, if a packet is lost, all remaining packets transmitted until the end of that round are also lost (bursty loss behavior) - tail drop –“throughput” is measured in terms of packets per unit of time

loss indications are exclusively of type “triple-duplicate” ACK (TD) the window size is not limited by the receiver’s advertised window the flow starts at time t = 0, and the sender always has data to send for any given time t > 0, N t –let N t be the number of packets transmitted in the interval [0, t], and B t = N t / t –let B t = N t / t be the throughput of that interval “B”the long-term steady-state TCP throughput “B” is defined as: plet p be the probability that a packet is lost, given that either it is the first packet in its round or the preceding packet in its round is not lost B(p)note that, we are interested in establishing a relationship B(p) Loss indications are exclusively “triple-duplicate” ACKs

TD period (TDP)a TD period (TDP) is a period between two TD loss indications between two TD loss indications, the sender is in congestion avoidance and the window increases with slope 1/b packets per round for the i-th TD period, –Y i : # packets sent in the period –A i : the duration of the period –W i : the window size at the end of the period considering {W i } i to be a Markov regenerative process with rewards {Y i } i, it can be shown that: to derive B, the long-term steady state throughput, we must derive E[Y] and E[A]

W i-1 / 2a TD period starts immediately after a TD loss indication, and thus the current congestion window size is equal to W i-1 / 2, half the size of window before the TD occurred 1/b bat the end of each round the window is incremented by 1/b and # of packets sent per round is incremented by one every b rounds i : the first packet lost in TDP i X i : the round which this loss occurs after packet i, (W i ) - 1 more packets are sent in an additional round before a TD loss indication occurs (and the current TD period ends) thus, a total of Yi = i + (W i ) - 1 packets are sent in (X i ) + 1 rounds it follows that:

to derive E[ ], consider the random process { i } i, where i is the number of packets sent in a TD period up to and including the first packet that is lost based on the assumption that packets are lost in a round independently of any packets lost in other rounds, { i } i is a sequence of independent and identically distributed (i.i.d.) random variables given the proposed loss model, the probability that i = k is equal to the probability that exactly k-1 packets are successfully acknowledged before a loss occurs now, we have to derive E[W] and E[A]

to derive E[W] and E[A], consider again a TDP i –Define r ij to be the duration (round-trip time) of the j-th round of TDP i –consider the round-trip times r ij to be random variables, that are assumed to be independent of the size of congestion window, and thus independent of the round number, j then, the duration of TDP i is if follows from the assumption mentioned above that: the paper denoted that E[r] = RTT, the average value of round-trip time now, we have to derive an expression for E[X]

to derive and expression for E[X], consider the evolution of W i as a function of the number of rounds, as in figure 2 for simplicity, in this derivation, it is assumed that (W i-1 / 2) and (X i / b) are integers first of all, it can be expressed that during the i-th TD period, the window size increases between W i-1 / 2 and W i. Since the increase is linear with slope 1 / b, we have: next, the fact that Y i packets are transmitted in TDPi is expressed by: Where i : the number of packets send in the last round (X i+1 -th)

Assume that {X i } and {W i } are mutually independent sequences of random variables, it follows from (7) that it also follows from (10) and (5) that we consider that i, the number of packets in the last round is uniformly distributed between 1 and Wi, and thus E[ ] = E[W] / 2 from (11) and (12), we have: observe that, i.e., for small values of p

from (11) and (13), we have from (6) and (15), we have observe that, from (1) and (5), we have substitute (13) and (16) in (18), we get equation (19) can be expressed as:

Loss indications are triple-duplicate ACKs and time-outs from the measurements done by this paper, the majority of window decreases are due to time-outs rather than fast retransmits hence, a good model should capture time-out loss indications to capture time-out loss indications, the model has to be extended to include the case where the TCP sender times- out this occurs when packets (ACKs) are lost, and less than three duplicate ACKs are received

the sender waits for a period of time denoted by T 0, and then retransmits non-acknowledged packets following a time-out, the congestion window is reduced to one, and one packet is thus resent in the first round after a time out. in the case that another time-out occurs before successfully retransmitting the packets lost during the first time-out, the period of time out doubles to 2*T 0 ; this doubling is repeated for each unsuccessful retransmission until 64*T 0 is reached, after which the time out period remains constant at 64*T 0

Z i TO denotes the duration of a sequence of time-outs ( no successful retransmission in those periods) Z i TD denotes the time interval between two consecutive time-out sequences (there is some successful retransmission and a number of TD periods within the interval) define S i to be: S i = Z i TD + Z i TO define M i to be # packets sent during S i define, also, R i to be # packets sent during time-out sequence Z i TO

given {(S i, M i )} i is an i.i.d. sequence of random variables, we have: let n i be the number of TD periods in interval Z i TD for the j-th TD period of interval, –define Y ij to be the number of packets sent in the period –define A ij to be the duration of the period –define X ij to be the number rounds in the period –define W ij to be the window size at the end of the period note that, the definition of a TD period is extended to the period: –between two TD loss indications (original definition), or –starting after a TO loss indication and ended by a TD loss indication –starting after a TD loss indication and ended by a TO loss indication

hence, we have: assume that {n i } i to be an i.i.d. sequence of random variables, independent of {Y ij } and {A ij }, we have :

to derive E[n]: –observe that, during Z i TD, the time between two consecutive time-out sequences, there are n i TDPs, where each of the first n i -1 end in a TD, and the last TDP ends in a TO –according to the observation mentioned above, it follows that: in Z i TD, there is one TO out of n i loss indications therefore, if we denote by Q the probability that a loss indication ending a TDP is a TO, we have E[n] = 1 / Q –note that {n i } i is considered as Geom(Q) consequently, since Y ij and A ij do not depend on time-outs, their means are those derived in (4) and (16) to compute TCP throughput using (21), we must still determine Q, E[R] and E[Z TO ]

to derive an expression for Q, consider the round where a loss occur in figure 4; it will be referred to as the “penultimate” round note that, in figure 4, the ACK is not delayed (b = 1) for simplicity of illustration wlet w be the current congestion window size –thus, packets f 1 …f w are sent in the penultimate round –packets f 1 …f k are acknowledged –packet f k+1 is the first one to be lost (or not ACKed) –again, from the assumption that packet losses are correlated within a round, all packet following f k+1 in the penultimate round are also lost –however, since packets f 1 …f k are ACKed, another k packets, s 1 …s k are sent in the next round, which will be referred as the “last” round –this last round contains another loss, say packet s m+1 –again, based on the assumption about packet loss correlation, s m+2 …s k are also lost in the last round

mthe m packets successfully sent in the last round are responded to by ACKs for packet f k, which are counted as duplicate ACKs since ACKs are not delayed in this scenario, the number of duplicate ACKs is equal to the number of successfully received packets in the last round –if the number of such ACKs is greater than 3, then a TD indication occurs –otherwise, a TO occurs –in both cases, the current period between losses, TDP, ends define A(w,k) to be the probability that the first k packets are ACKed in a round of w packets, given there is a sequence of one or more losses in the round.

also, define C(n, m) to be the probability that m packets are ACKed in sequence in the last round (where n packets were sent; p is the probability that a packet will be lost) and the rest of the packets in the round, if any, are lost then,, the probability that a loss in a window of size w is a TO, is given by

Note that, – : # of packets successfully transmitted in the penultimate round, k, is less than three – : # of packets successfully transmitted in the penultimate round, k, is greater than three; however # of packets successfully transmitted in the last round, m, is less than three after algebraic manipulations, we have numerically, a very good approximation of Q is

Q, the probability that a loss indication is a TO, is next, we consider the derivation of E[R] –from the observation in TCP traces, in most cases, one packet is transmitted between two time-outs in sequence –in addition, a sequence of k TOs occurs when there are k-1 consecutive losses (the first loss is given) followed by a successfully transmitted packet –consequently, the number of TOs in a TO sequence has a geometric distribution, and thus –then, the expected value of R is

next, we focus on E[Z TO ], the average duration of a time- out sequence excluding retransmission times –the first six time-outs in one sequence have length (2 i-1 )*T 0, where i = 1…6 –all immediately following timeouts having length 64*T 0 –then, the duration of a sequence with k time-outs is –the mean of Z TO is

with the expressions for Q, E[S], E[R] and E[Z TO ], the equation (21) for B(p) can be expressed as: Q is given in (23), E[W] in (13) and E[X] in (15) using (24), (14) and (17), we have that (27) can be approximated by:

The impact of window limitation during a period without loss indications, the sender’s window is dominated by both the congestion avoidance algorithm and the receiver’s advertised window –sender’s window = min(cwnd, advertised window) –let W max = min(cwnd, advertised window) as a consequence, during a period without loss indications, the window size can grow up to Wmax, but will not grow further beyond this value

define W u to be the unconstrained window size, the mean of which is given in (13): if E[W u ] < W max, –in other words, if E[W u ] < W max, the receiver-window limitation has negligible effect on the long term average of the TCP throughput, and thus the TCP throughput is given by (27) if W max <= E[W u ], –consider an interval Z TD between two time-out sequences consisting of a series of TD periods as in figure 6

during the 1 st TDP, the window grows linearly up to W max for U 1 rounds, then remains constant for V 1 rounds then a TD indication occurs, the window drops to W max / 2, and the process repeats thus, W i = (W i-1 / 2) + (U i / b) E[W] = (E[W] / 2) + (U i / b) W max / 2= E[U] / b E[U] = (b / 2) W max

considering the number of packets sent in the i-th TD period, we have: and then since Y i, the number of packets in the i-th TD period, does not depend on window limitation, E[Y] has been given by (5), E[Y] = (1 - p) / p + W max, and thus finally, since X i = U i + V i, we have

by substituting this result of E[X] and E[W] W max in (27), we obtain the TCP throughput, B(p), when the window is limited in conclusion, the complete characterization of TCP throughput, B(p), is:

where f(p) is given in (28), Q is given in (23) and E[W u ] is in (13) the following approximation of B(p) follows from (29) and (31): equation (31) will be referred as the “full model” equation (32) will be referred as the “approximate model”

Measurements and Trace Analysis equations (31) and (32) provide an analytic characterization of TCP as a function of packet loss indication rate, RTT and maximum window size next, the empirical validation of these formulae will be done the measurement data are collected from 37 TCP connections established between 18 hosts scattered across United States and Europe

table 1 lists the domains and operating systems of 18 hosts all data sets are for unidirectional bulk data transfer tcpdumpthe measurement data are gathered by running tcpdump at the sender, and analyzing its output various measurement and implementation related problems: –E.g., Linux sender uses two dup ACKs to indicate loss instead of three tcptracensthe trace analysis programs were further verified by checking them against tcptrace and ns

Table 2: –24 data sets, –each corresponds to a 1 hour long TCP connection –sender behaves as an “infinite source” p  (total # loss) / (total # packet sent) the 5 th and 6 th columns show a breakdown of the loss indications to: TD and TO the last two columns report the average round-trip time and average duration of a “single” timeout (T 0 ) these values have been averaged over the entire trace performed at randomly selected times during 1997 and beginning of 1998

Table 3 reports summary results from additional 13 data sets: –each data set represents 100 serially-initiated TCP connections between a given sender-receiver pair –each connection lasted 100 seconds, and was followed by a 50 second gap before the next connection was initiated –these experiments were performed at randomly selected times during 1998

important observations drawn from the data in these tables: –in all traces, timeouts constitute the majority or a significant fraction of the total number of loss indications –exponential backoff due to multiple timeouts occurs with significant frequency next, use the measurement data described above to validate the model proposed in the paper each one-hour trace was divided into 36 consecutive 100 second intervals, and each plotted point on a graph represents the number of packet sent versus the number of loss indications during a 100s interval the x-axis represents the frequency of loss indications, p the y-axis represents the number of packets sent

* each 100 second interval is classified into one of five categories: - TD: did not suffer any timeout (only triple-duplicate) - T0: suffered at least one “single” timeout (no exp backoff) - T1: suffered from a single exp backoff (double timeout) - T2: suffered from two exp backoffs - T3 or more: more than two exp backoffs occurred

Models for 1 hour traces N observed -number of packets sent over an interval P observed -loss frequency over an interval N predicted = B(p observed )*100s

Models for 100 second traces Use the value of RTT and timeout calculated for each 100 second trace. For most cases, proposed model is better than the TD Only model.

Model and Experimental Results Assumption that round trip time is independent of the window size is found to be false for certain cases: –Assumption is checked by measuring coefficient of correlation between duration of round samples and the number of packets in transit during each sample. –For most traces the coefficient is in the range -0.1 to +0.1 –In the case when the receiver is at the end of a modem line, the coefficient of correlation is found to be as high as 0.97