CINXE.COM
RED (Random Early Detection) Queue Management
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> <html><head><title>RED (Random Early Detection) Queue Management</title></head><body> <!-- bad citations: ftp://engr.ans.net/pub/papers/tcp-performance.ps http://www-nrg.ee.lbl.gov/diff-serv-arch/thrd48.html --> Topics below include:<br> <a href="#parameters">Setting Parameters</a>,<br> <a href="#evaluations">Evaluations of RED</a>,<br> <a href="#other">Other Proposals for Active Queue Management</a>,<br> <a href="#preference">RED with Drop Preference</a>,<br> <a href="#flow">Active Queue Management with Per-Flow Behaviors</a>,<br> <a href="#3G">Queue Management for 3G Links</a>,<br> <a href="#ns">The RED implementation in the NS simulator</a>,<br> <a href="#implementations">RED Implementations</a>,<br> <a href="#experiences">Deployment</a>,<br> <a href="#notes">Notes from Sally</a>,<br> <a href="#recommendations">Papers with Recommendations for RED</a>,<br> <a href="#related">Related Papers</a>,<br> <a href="#email">Email discussions regarding RED</a>. <h2>References on RED (Random Early Detection) Queue Management</h2> <ul> <li> Floyd, S., and Jacobson, V., <b><a href="./papers/red/red.html"> Random Early Detection gateways for Congestion Avoidance</a> </b> V.1 N.4, August 1993, p. 397-413. <b><a href="abstracts.html#FJ93">Abstract</a>.</b> <br> This is the basic paper that describes RED queue management. <br><br> <li> B. Braden, D. Clark, J. Crowcroft, B. Davie, S. Deering, D. Estrin, S. Floyd, V. Jacobson, G. Minshall, C. Partridge, L. Peterson, K. Ramakrishnan, S. Shenker, J. Wroclawski, L. Zhang, <b> <a href="http://www.ietf.org/rfc/rfc2309.txt"> RFC 2309: Recommendations on Queue Management and Congestion Avoidance in the Internet</a></b>, April 1998. Informational. <br><br> <li> Sally Floyd, Ramakrishna Gummadi, and Scott Shenker, <b> Adaptive RED: An Algorithm for Increasing the Robustness of RED's Active Queue Management</b> (<a href="./papers/adaptiveRed.ps">postscript</a>, <a href="./papers/adaptiveRed.pdf">PDF</a>), August 2001. <a href="http://www.icir.org/floyd/adaptivered/"> Simulation scripts</a>. <p> <li>Floyd, S., <b> <a href="./red/gentle.html"> Recommendation on using the "gentle_" variant of RED</a></b>, March 2000. <br> This note recommends implementing RED, and running simulations, with the "gentle_" modification to RED.<br> A variant of Adaptive RED has also been implemented in NS, and is illustrated in "./test-all-adaptive-red" in "tcl/test". In Adaptive RED, max_p is adjusted to better control the average queue size. <br><br> <li>Floyd, S., and Fall, K., papers about <b> <a href="./end2end-paper.html"> Promoting the Use of End-to-End Congestion Control in the Internet</a></b>. <br><br> <li>Bug-fix for pseudocode in [FJ93]:<br> Stefann De Cnodder, Omar Elloumi, and Kenny Pauwels, <b> <a href="./red/Elloumi99.pdf"> Effect of Different Packet Sizes on RED Performance</a></b>, 1999.<br> This paper points out a bug in the pseudocode given in [FJ93] for RED in byte mode (RED_2), where the packet dropping probability depends on the packet size in bytes, and gives a fix (RED_4). RED_4 corresponds to the byte-mode mechanism that has been implemented in NS since 4/30/97. <p> </ul> <a name="parameters"> <h2>Setting Parameters:</h2> <ul> <li> In the "<a href="./notes/test-suite-red.txt">gentle_</a>" modification to RED in NS, the packet-dropping probability varies from "max_p" to 1 as the average queue size varies from "maxthresh" to twice "maxthresh". This option makes RED much more robust to the setting of the parameters "maxthresh" and "max_p", and was added to NS on 6/12/99. My recommendation is to implement RED, and to run simulations, with "gentle_" set to 1. <p> <li> Floyd, S., <b> <a href="./REDparameters.txt"> RED: Discussions of Setting Parameters</a></b>, November 1997.<br> My current advice is to use the new default parameters of "Queue/RED set q_weight_ -1", "Queue/RED set thresh_ 0", and "Queue/RED set maxthresh_ 0", for automatic configuration. In this case, "thresh_" and "maxthresh_" are set as determined by the target average delay in seconds, "targetdelay_". The current default is "Queue/RED set targetdelay_ 0.005". <p> <li> I [Sally] have been intending to write a note on "<b>Preventing Oscillations Considered Harmful</b>", explaining why preventing oscillations in the queue size is not one of RED's overriding goals, but I haven't quite gotten to it yet. Please don't set RED parameters with the overriding goal of preventing oscillations in the queue size in an environment of long-lived flows all with the same round-trip time! </ul> <a name="evaluations"> <h2>Evaluations of RED</h2> <ul> <li>Elloumi, O., and Afifi, H., <b><a href="http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?arnumber=624699"> RED Algorithm in ATM Networks</a>.</b> Tech report, June 1997. <br> "We demonstrate ... how queue monitoring using an enhanced RED algorithm can further provide higher throughput, lower delay and fairness. We show that maintaining a low average buffer queue size benefits to connections sending small amounts of data." <br><br> <!-- <li>Martin May's <a href="http://www-sop.inria.fr/rodeo/personnel/mmay/may_red.html"> RED Web Page at INRIA</a>. <br><br> --> <li>May, M., Bolot, J., Diot, C., and Lyles, B., <b><a href="http://citeseer.ist.psu.edu/may99reasons.html"> Reasons not to deploy RED</a></b>, technical report, June 1999.<br> "The main results we found were, first, that RED with small buffers does not improve significantly the performance of the network... Second, parameter tuning in RED remains an inexact science, but has no big impact on end-to-end performance." <br> <b>Note from Sally</b>: It is not a big surprise that RED with small buffers doesn't improve performance significantly. This doesn't strike me as a relevant reason not to deploy RED. <p> <li>The UNC articles: <ul> <li>M. Christiansen, K. Jeffay, D. Ott, and F.D. Smith, <b><a href="http://www.cs.unc.edu/Research/dirt/abstracts/SIGCOMM-2000-abs.html"> Tuning RED for Web Traffic</a></b>, ACM SIGCOMM, August 2000. Or the June 2001 version in IEEE/ACM Transactions on Networking. <br> "We conclude that for links carrying only web traffic, RED queue management appears to provide no clear advantage over tail-drop FIFO for end-user response times... There are some limitations of this study that should be considered... Congestion on both paths on a full-duplex link and over multiple router hops should also be considered." <br> <b>Note from Sally</b>: This paper uses as its metric the response time for HTTP request-response pairs. While the use of RED often improves average queueing delay and packet drop rates, it doesn't necessarily affect throughput; throughput is often just fine in Drop-Tail environments, particularly in realistic environments such as those used in this paper. The benefits of RED are shown in metrics that are more directly related to queueing delay and drop rates. <p> <li>L. Le, J. Aikat, K. Jeffay, and F.D. Smith, <b> <a href="http://www.sigcomm.org/sigcomm2003/papers.html#p265-le"> The Effects of Active Queue Management on Web Performance</a></b>, ACM SIGCOMM, 2003. <br> "We conclude that without ECN there is little end-user performance gain to be realized by employing the AQM designs studied here. However, with ECN, response times can be significantly improved." <p> <li>L. Le, J. Aikat, K. Jeffay, and F.D. Smith, <b> <a href="http://www.cs.unc.edu/~jeffay/papers/IEEE-ToN-05.pdf"> The Effects of Active Queue Management and Explicit Congestion Notification on Web Performance</a></b>, IEEE/ACM Transactions on Networking, 2005. <br> "We conclude that AQM can improve application and network performance for Web or Web-like workloads. In particular, it appears likely that with AQM and ECN, provider links may be operated at near saturation levels without significant degradation in userperceived performance." <p> </ul> <li> <b> A Report on Some Recent Developments in TCP Congestion Control </b> (<a href="./papers/TCPreport.ps">postscript</a>, <a href="./papers/TCPreport.pdf">PDF</a>), <a href="./">Floyd, S.</a>, In submission, June 2000.<br> Section 3.1 of this paper includes a discussion of the impact of RED for TCP traffic. <p> <li> Yin Zhang and Lili Qiu, <a href="http://citeseer.ist.psu.edu/381704.html"> Understanding the End-to-End Performance Impact of RED in a Heterogeneous Environment</a>, Cornell CS Technical Report 2000-1802, July 2000.<br> "Our results show that overall RED improves performance at least for the types of heterogeneity we have considered." <p> <li> C. Hollot, V. Misra, D. Towsley and W. Gong. <a href="ftp://gaia.cs.umass.edu/pub/MisraInfocom01-RED-Control.pdf"> A Control Theoretic Analysis of RED</a>, INFOCOMM 2001.<br> "We present guidelines for designing linearly stable systems subject to network parameters like propogation delay and load level." <p> <li> Wesley Eddy and Mark Allman. <a href="http://www.icir.org/mallman/papers/"> A Comparison of RED's Byte and Packet Modes</a>. Computer Networks, 42(2), June 2003. <p> <li> P. Ranjan, E. H. Abed, and R. J. La, <a href="http://citeseer.ist.psu.edu/509166.html"> Nonlinear Instabilities in TCP-RED</a> IEEE/ACM Transactions on Networking, December 2004. <br> "This work develops a discrete-time dynamical feed-back system model for a simplified TCP network with RED control and provides a nonlinear analysis that can help in understanding observed parametric sensitivities." <br> <b>Note from Sally</b>: The simulations show oscillations in the average queue size, using scenarios with one-way traffic and with very low RED averaging weights of 0.000004 and 0.000005. <p> <li> P. Tinnakornsrisuphap and R. J. La, <a href="http://www.ece.umd.edu/~hyongla/publication.htm"> Asymptotic Behavior of Heterogeneous TCP Flows and RED Gateway</a>, IEEE/ACM Transactions on Networking, February 2006. <br> "We introduce a stochastic model of a bottleneck ECN/RED gateway under a large number of heterogeneous TCP flows, i.e., flows with diverse round-trip delays and session dynamics." <br> Discussion: "First, ... the arrivals and departures of connections (or simply session dynamics) are a major contributor to the random queue fluctuations. Second, the magnitude of the random queue fluctuations is not sensitive to the slope of the marking function. However, the stability of a system with TCP flows and RED gateway(s) is shown to be relatively sensitive to the slope of the system. Third, oscillations caused by [the binary nature and uncertainty of RED feedback and the structure of TCP] are also significant." <p> </ul> <a name="other"> <h2>Proposed Modifications to RED, and Other Proposals for Active Queue Management</h2> <ul> <li>M. Shin, S. Chong, and I. Rhee, <a href="http://citeseerx.ist.psu.edu/viewdoc/summary;jsessionid=74600814DD7AEE4D86A405E4912530B5?doi=10.1.1.68.8825"> Dual-Resource TCP/AQM for Processing-Constrained Networks</a>, IEEE/ACM ToN. April 2008. <br> "Both bandwidth and CPU resources can be a bottleneck and thus congestion control must deal with `congestion' on both of these resources." <br> - S. Chong, M. Shin, J. Mo, and H. Lee, <a href="http://netsys.kaist.ac.kr/main/publications/publications.htm"> Flow Control with Processing Constraint</a>", IEEE Communications Letters, October 2005. <br> "We re-examine 铿俹w control issues for a network environment where transmission links and CPUs on a data path can be jointly bottlenecked." <p> <li> Shao Liu, Tamer Basar, and R. Srikant, <a href="http://citeseer.ist.psu.edu/659054.html"> Exponential RED: A Stabilizing AQM Scheme for Low- and High-speed TCP Protocols</a>, IEEE/ACM ToN, October 2005. <br> "Our modification to RED sets the packet marking probability as an exponential function of the length of a virtual queue whose capacity is slightly smaller than the link capacity.... E-RED is the first router algorithm which can be proved to stabilize TCP-Reno for a general topology network with heterogeneous delays." <br>-- A related idea was proposed in an unpublished thesis in 2003 by Somak Halder in "<b>EXPRED - A New Active Queue Management Algorithm</b>". From that document: "The drop probability becomes an exponential function instead of a linear function of the average queue size." <p> <li> Ashvin Lakshmikantha, C. L. Beck and R. Srikant, <b> Robustness of Real and Virtual Queue-Based Active Queue Management Schemes</b> (<a href="http://citeseer.ist.psu.edu/lakshmikantha02robustness.html">2002</a> version), IEEE/ACM ToN, February 2005. <br>"Using fluid flow models, we show via analysis and simulations that Virtual Queue (VQ)-based marking schemes outperform Real Queue (RQ)-based marking schemes in terms of robustness to disturbances and the ability to maintain low queueing delays." <p> <li> S. Athuraliya, V. H. Li, S. H. Low and Q. Yin, <b> <a href="http://citeseer.ist.psu.edu/athuraliya01rem.html"> REM: Active Queue Management</a></b>, IEEE Network, May 2001.<br> "We describe a new active queue management scheme, Random Exponential Marking (REM), that aims to achieve both high utilization and negligible loss and delay in a simple and scalable manner." REM's goal is to stabilize the input rate around the link capacity, and to stabilize the queue around a small target. <p> <li> J. Aweya, M. Ouellette, D. Y. Montuno and A. Chapman, <b>A Control Theoretic Approach to Active Queue Management</b>, Computer Networks 36, 2001, and <b>An Optimization-oriented View of Random Early Detection</b>, Computer Communications, 2001, to appear.<br> These two papers propose Dynamic-RED (DRED), which has the goal of maintaining the queue size close to a threshold value, and uses a controller that adapts the packet-dropping probability as a function of the average distance of the queue from the threshold value. <p> <li> W. Feng, D. Kandlur, D. Saha, K. Shin, <b><a href="http://citeseer.ist.psu.edu/268991.html"> Techniques for Eliminating Packet Loss in Congested TCP/IP Networks</a></b>, U. Michigan CSE-TR-349-97, November 1997. <br> This paper proposes Adaptive RED, which adjusts the packet dropping probability "max_p" based on the past history of the average queue size.<br> See also W. Feng, D. Kandlur, D. Saha, K. Shin, <b><a href="http://citeseer.ist.psu.edu/feng99selfconfiguring.html"> A Self-Configuring RED Gateway</a></b>, INFOCOM '99, March 1999, for a subset of the work in [FKSS97]. <p> <li>W. Feng, D. Kandlur, D. Saha, K. Shin, <b> <a href="http://citeseer.ist.psu.edu/feng99blue.html"> Blue: A New Class of Active Queue Management Algorithms</a></b>, UM CSE-TR-387-99, 1999. <br> This paper proposes a mechanism for active queue management that is based not on the queue size, but only on buffer overflow and link idle events. In Stochastic Fair Blue (SFB), a variant of Blue, flows are hashed into accounting bins, and each bin has its own packet-marking probability. <p> <li> C. Hollot, V. Misra, D. Towsley and W. Gong. <a href="http://citeseer.ist.psu.edu/hollot00designing.html"> On Designing Improved Controllers for AQM Routers Supporting TCP Flows</a>, INFOCOMM 2001.<br> "The second of our designs, the Proportional Integral (PI) controller is shown to outperform RED significantly."<br> <p> <li>Van Jacobson, <b> Notes on using RED for Queue Management and Congestion Avoidance</b>, viewgraphs (<a href="ftp://ftp.ee.lbl.gov/talks/vj-nanog-red.pdf">PDF</a>, <a href="ftp://ftp.ee.lbl.gov/talks/vj-nanog-red.ps.gz">compressed Postscript</a>), talk at NANOG 13, June 1998. <p> <!-- <li> Srisankar Kunniyur's web page on <a href="http://www.comm.csl.uiuc.edu/~kunniyur/aqm.html"> ECN Marking and AQM Schemes</a>. <p> --> <li> S. Kunniyur and R. Srikant, <b> <a href="http://www.comm.csl.uiuc.edu/~srikant/pub.html"> A time-scale decomposition approach to adaptive ECN marking</a></b>. U. Illinois, CSL Technical Report. Earlier versions of this paper are to appear in Globecom2000 and Infocom2001.<br> Related paper: S. Kunniyur and R. Srikant, <b> <a href="http://www.comm.csl.uiuc.edu/~srikant/pub.html"> Analysis and Design of an Adaptive Virtual Queue Algorithm for Active Queue Management</a></b>, Sigcomm 2001. (Later appeared in IEEE/ACM Transactions on Networking, April 2004.) <p> <li>T. J. Ott, T. V. Lakshman, and L. H. Wong, SRED: Stabilized RED, Proceedings IEEE INFOCOM '99, New York, March 1999. <br> This paper proposes a mechanism for statistically estimating the number of active flows at a link; this mechanism could also be used for identifying misbehaving flows. The paper also describes Stabilized RED (SRED), which uses a packet-dropping probability based on the estimated number of active flows and the instantaneous queue size. <p> <li>V. Rosolen, Bonaventure, O., and G. Leduc, <b> <a href="http://citeseer.ist.psu.edu/535821.html"> A RED discard strategy for ATM networks and its performance evaluation with TCP/IP traffic</a></b>, ACM Computer Communication Review, July 1999, and <b> <a href="http://www.run.montefiore.ulg.ac.be/publications/papers/abstract-PP98-0 2.html">Impact of cell discard strategies on TCP/IP in ATM UBR networks</a></b>, Proc. of the 6th Workshop on Performance Modelling and Evaluation of ATM Networks (IFIP ATM'98) Ilkley, UK, July 98. <br> These papers investigate a modified version of RED with a smoothed packet-dropping probability that varies from "max_p" to 1 as the average queue size varies from "maxthresh" to twice "maxthresh". This variant of RED is then modified for an ATM switch. Simulation results compare plain UBR with UBR with Early Packet Discard (EPD), Fair Buffer Allocation (FBA), and with RED.<br> [This modification to RED has been added to NS, via the `gentle_' parameter.] <p> <li> Bing Zheng and Mohammed Atiquzzaman, <b> <a href="http://www.cs.ou.edu/~atiq/papers/TR-CS-01-001.pdf"> Low Pass Filter/Over Drop Avoidance (LPF/ODA): An algorithm to improve the performance of RED gateways </a></b>, CS-TR-01-001, technical report, University of Oklahoma, February 2001. <br> This paper proposes a new algorithm for computing the average queue length with a quicker response to long-term changes in the queue size. <p> </ul> <a name="preference"> <h2>RED with Drop Preference</h2> <ul> <li> David D. Clark and Wenjia Fang, Explicit Allocation of Best Effort Packet Delivery Service (<A HREF="http://nms.lcs.mit.edu/6829-papers/p362-clark.pdf">PDF</A>), ACM Transactions on Networking, August, 1998.<BR> This paper describes RIO, or RED with In/Out bit. RIO "discriminates against Out packets in times of congestion." <p> <li> U. Bodin, O. Schelen, and S. Pink, <A HREF="http://www.acm.org/sigcomm/ccr/archive/ccr-toc/ccr-toc-2000.html"> Load-tolerant Differentiation with Active Queue Management</A>, CCR, July, 2000.<br> This paper evaluates RIO and WRED (Weighted RED), and proposes a modification, WRT (WRED With Thresholds), that calculates a separate average queue length for the higher-priority packets, preventing starvation for the lower-priority traffic. </ul> <a name="stability"> <h2>Stability and Oscillations</h2> This is a small sampling of a rather large literature in this area... <p> <ul> <li>K. B. Kim and S. H. Low, <A HREF="http://caltechcstr.library.caltech.edu/340/"> Analysis and Design of AQM for Stabilizing TCP</A>, Caltech Technical Report caltechCSTR:2002.009, March, 2002. <br> "We interpret existing AQMs such as RED (Random Early Detection), REM (Random Exponential Marking), PI (Proportional-Integral) and AVQ as different approximations of the unified AQM structure." </ul> <a name="flow"> <h2>Active Queue Management with Per-Flow Behaviors</h2> <ul> <li>Dong Lin and Robert Morris, <b> <a href="http://www.acm.org/sigcomm/sigcomm97/advance-program.html#ab078"> Dynamics of Random Early Detection</a>.</b> SIGCOMM 97.<br> This paper proposes FRED, a variant of RED, that uses per-active-connection accounting to make different dropping decisions for connections with different bandwidth usages. <p> <li><a href="http://www.cs.cmu.edu/~istoica/csfq/"> Core-Stateless Fair Queueing</a>, 1998. <p> <li>Farooq M. Anjum, Leandros Tassiulas, <a href="http://hdl.handle.net/1903/6067"> Balanced-RED: An Algorithm to Achieve Fairness in the Internet</a>, Infocom 1999, March 1999.<br> This paper proposes Balanced-RED (BRED), which drops packets based on the buffer occupancy of the flow, to achieve a more balanced bandwidth allocation in the presence of non-adaptive traffic. <p> <li>Anurag Acharya and Anand Rangarajan, <b> <a href="http://www.cs.ucsb.edu/TRs/Docs/TRCS99-26.ps"> Early Regulation of Unresponsive Flows</a></b>, July 1999. <br> This paper proposes that RED-based core routers generate rate-limited source quenches, and that edge routers use the source quenches to control per-flow regulators. The goal is to drop undeliverable packets as close to the periphery of the network as possible. <p> <li>Ratul Mahajan and Sally Floyd, <b><a href="../red-pd/"> RED with Preferential Dropping (RED-PD)</a></b>, 2001. <br> "This paper investigates RED-PD, a mechanism that uses the packet drop history at the router to detect high-bandwidth flows in times of congestion, and preferentially drops packets from these high-bandwidth flows to control the bandwidth received by these flows at the congested queue." <p> <li> Smitha and A. Reddy, <a href="http://citeseer.ist.psu.edu/473674.html"> LRU-RED: An Active Queue Management Scheme to Contain High Bandwidth Flows at Congested Routers</a>, Global Telecommunicaations Conference, 2001. <br> LRU-RED "maintains an LRU cache at the routers to record information about the high-bandwidth 铿俹ws... In addition, it lowers the drop rates of short-lived 铿俹ws and also of responsive high bandwidth 铿俹ws." <p> </ul> <h2>Active Queue Management with Per-Flow Scheduling</h2> <ul> <li> Bernhard Suter, T. V. Lakshman, Dimitrios Stiliadis, and Abhijit Choudhury, <b> <a href="http://citeseer.ist.psu.edu/suter98efficient.html"> Efficient Active Queue Management for Internet Routers</a></b>, November 1997, Interop '98.<br> "Per-flow service disciplines are only effective when supported by an appropriate per-flow buffer management strategy, and in particular the shared buffer with soft-partitioning, drop-from-front and longest queue drop." </ul> <a name="3G"> <h2>Queue Management for 3G Links</h2> <ul> <li> M. Sagfors, R. Ludwig, M. Meyer, and J. Peisa, <a href="http://ieeexplore.ieee.org/Xplore/login.jsp?url=/iel5/8546/27030/01200636.pdf?arnumber=1200636"> Queue management for TCP Traffic over 3G Links</a>, Wireless Communications and Networking, 2003. WCNC 2003. <br>"We propose a novel active queue management scheme tailored to the specific characteristics of third generation (3G) cellular networks." <p> <li> H. Ekstrom and Reiner Ludwig, <a href="http://www2.computer.org/portal/web/csdl/abs/proceedings/icdcsw/2003/1921/00/19210870abs.htm"> Queue Management for TFRC-Based Traffic in 3G Networks</a> Distributed Computing Systems Workshop, 2003. <br> "We show that drop-on-full queuing is absolutely inappropriate for TFRC traffic running over 3G links." <p> </ul> <a name="ns"> <h2>The RED implementation in the NS simulator</h2> <ul> <li> Floyd, S, <b> <a href="./papers/redsims.ps"> Ns Simulator Tests for Random Early Detection (RED) Gateways</a></b>, Technical report, October 1996, contains simulator validation tests for the <b><a href="http://www.isi.edu/nsnam/ns/"> NS</a></b> simulator. </ul> <a name="implementations"> <h2>RED Implementations</h2> <ul> <li>The red-impl mailing list has been closed, as it is no longer active. It was created for discussions of issues related to software or hardware implementations of RED. <a href="./red/List.archives.6_01.txt">Archives</a> up to June 2001. Discussions of active queue management currently take place on the <a href="http://www.postel.org/mailman/listinfo/end2end-interest"> end2end-interest</a> mailing list. <p> <li>Linux: The RED implementation in Linux was written by Alexey Kuznetsov. RED has been supported in Linux since the 2.2.* kernel. <p> Jamal Hadi Salim has written a multi-level RED variant, GRED, for Linux. GRED can run up to 16 virtual queues on a single physical queue. This is described further in the web page on "<a href="http://diffserv.sourceforge.net/">Differentiated Services on Linux</a>". GRED can operate in "RIO mode", with coupled average queue estimates from the virtual queues, or in "standard mode" where each virtual queue has its own independent average queue estimate. <p> <li>FreeBSD: RED and gentle RED (GRED) are supported in the IPFW2 code in FreeBSD, as of July 2002, from Luigi Rizzo. The parameters for a given queue are: red or gred, w_q, min_th, max_th, and max_p. <p> <li>Cisco: Cisco's RED implementations include <b> <a href="http://www.cisco.com/univercd/cc/td/doc/product/software/ios111/cc111/wred.htm"> Distributed Weighted Random Early Detection</a></b>. More information about Cisco's RED implementations can be found on <b><a href="http://cco.cisco.com/"> Cisco's web pages</a></b> by doing a search for "Random Early Detection" on their search engine. RED is implemented for the Cisco AS5200, 4000, 4500, and 4700. Cisco's Weighted RED preferentially drops lower-priority packets by setting different drop-probability functions for each priority level. <br><br> <li>ATLQ: Cho, K., an <b> <a href="http://www.sonycsl.co.jp/person/kjc/programs.html"> release of RED for BSD Unix</a></b>. This is a release of Alternate Queueing (ALTQ) for BSD Unix, with CBQ, WFQ, RED, and RSVP stubs for CBQ. ALTQ runs on FreeBSD/NetBSD/OpenBSD. <a href="http://www.sonycsl.co.jp/person/kjc/cbq/perf.html"> Test results</a>, 1997. <br><br> <li>Juniper: The <a href="http://kb.juniper.net/?ui_mode=question&question_box=Random+Early+Detection"> RED implementation</a> for Juniper routers. <!-- http://www.juniper.net/techpubs/software/junos51/swconfig51-interfaces/html/cos-config6.html#1015137 --> <!-- uses drop profiles to map the instantaneous queue size to the current packet drop probability. --> <p> <li> Solaris: Michel, Scott, Distant Early Warning (UCLAdew). Distant Early Warning was an implementation of RED for Solaris 2.5 and Solaris 2.5.1. 1997. <br><br> <li> Gaynor, M., <b><a href="http://people.bu.edu/mgaynor/papers/final.ps"> Proactive Packet Dropping Methods for IP Gateways</a></b>. November 1996. <b><a href="./red-abstracts.html#G96">Abstract</a>,</b> <b><a href="red-abstracts.html#G96A">Comments from Sally</a>.</b> <br><br> </ul> <a name="experiences"> <h2>Deployment</h2> <ul> <li> My impression from talking with people (e.g., from Cisco, Juniper, British Telecom) is that there is a reasonable deployment of RED in the Internet on access links, but I don't know of any data except for what is cited below.<br> Possible tests to infer the presence or absence of active queue management along a congested path include the following: (1) Measurements of how frequently multiple packets are dropped from a single window of data; (2) Measurements of the correlation between the loss rate and short-term burstiness. <p> <li> Marcel Dischinger, Andreas Haeberlen, Krishna P. Gummadi, and Stefan Saroiu. <a href="http://www.imconf.net/imc-2007/papers/imc137.pdf"> Characterizing Residential Broadband Networks</a>, IMC 2007. <br> "To quantify the extent of RED deployment in broadband networks, we tested whether the increases in RTT and loss rates are strongly correlated... We found that 26.2% of the DSL hosts show a RED-style drop policy on their upstream queues." <p> <li> <a href="http://www.switch.ch/misc/leinen/"> Simon Leinen</a>, <a href="http://mailman.postel.org/pipermail/end2end-interest/2006-March/005851.html"> Use of RED in practice?</a>, End2end-interest mailing list, March 2006. <br> "We used to use RED when we had overloaded (transatlantic) links, very successfully I might add - RED brought down peak-hour delays considerably, despite the relatively high base delay, without increasing loss rates or reducing link utilization." <p> <li> Cisco's documentation on <a href="http://www.cisco.com/univercd/cc/td/doc/product/software/ios121/121cgcr/qos_c/qcprt3/qcdconav.htm#xtocid118402"> WRED</a> and <a href="http://www.cisco.com/univercd/cc/td/doc/product/software/ios121/121cgcr/qos_c/qcprt3/qcdconav.htm#1000979"> Why Use WRED?</a>, January 2003. <p> <li> Chuck Semeria, <a href="http://whitepapers.silicon.com/0,39024759,60040274p-39000364q,00.htm"> Supporting Differentiated Service Classes: Active Queue Memory Management</a>, Juniper Networks white paper on WRED, RED, and ECN. February 2002 (registration required for free downloading). <br> "Active queue memory management plays a vital role in your network because it allows you to control service class depth, manage end-to-end delay, and avoid global TCP synchronization." <br> WRED and RED are supported in many Juniter routers. <p> <li> Jun Liu and Mark Crovella, <a href="http://citeseer.ist.psu.edu/liu01using.html"> Using Loss Pairs to Discover Network Properties</a>, ACM SIGCOMM Internet Measurement Workshop, 2001. <br> "Using loss pairs, we show that it is possible to characterize the packet dropping behavior of drop-tail and AQM routers internal to the network... One way to characterize the behavior of an AQM scheme is to plot a curve of its drop rate as a function of queue occupancy." <p> <li>John Kristoff has <a href="http://condor.depaul.edu/~jkristof/red/"> data</a> from enabling RED on March 22, 2001 on a border router for an 18 Mbps WAN link. Before RED, packet drop rates were regularly above 400/second. After RED, daily peaks were rarely over 100/second. <!-- <br> Of particular interest are the graphs of the packet drop rates on the afternoon of May 2, 2001, during a several-hour period of heavy outbound traffic from a compromised Windows machine on campus. RED was turned on and off several times during this two-hour period, and the results show that the use of RED significantly reduced the packet drop rate during this period. --> <p> <li> WRED is enabled on <!-- <a href="http://www.ieng.com/warp/public/cc/pd/rt/12000/index.shtml"> --> Cisco GSRs on overloaded links at AS1 (Genuity), to reduce queueing delay (October, 2000). Experience has been positive. (Reported by Derek Fonda of Genuity.) <p> <li>Doran, S., 1998 <!-- <a href="http://adm.ebone.net/~smd/red-1.html"> --> data from a deployment of Cisco's (DW) RED implementation by Ebone Inc. is discussed on a thread on "RED on a busy ISP-facing line" on the <a href="ftp://ftp.isi.edu/end2end/"> end2end-interest mailing list</a>. <p> <li>Villamizar, C., and Song, C., <b> <a href="http://portal.acm.org/citation.cfm?id=205520"> High Performance TCP in ANSNET</a></b>. Computer Communications Review, V. 24 N. 5, October 1994, p. 45-60. <br><br> <li>More reports on actual implementation experiences would be greatly appreciated. </ul> <a name="notes"> <h2>Notes from Sally</h2> <ul> <li> Floyd, S., <b><a href="./email/red_atm.notes"> Notes on Implementing RED with ATM</a></b>, October 1995.<br> The first paragraph is also about computing the average queue size in hardware. <br> Floyd, S., <b> <a href="./papers/redtesting"> Notes on Testing RED Implementations</a></b>, October 1996. <br> Floyd, S., <b> <a href="./REDaveraging.txt"> RED: Discussions of Byte and Packet Modes</a></b>, March 1997. With additional comments from January 1998 and October 2000. <br> Floyd, S., <b> <a href="./REDfunc.txt"> RED: Optimum functions for computing the drop probability? </a></b>, October 1997. <br> Floyd, S., <b> <a href="./REDdistributions.txt"> RED: Distributions for intervals between marked packets. </a></b>, February 1998. <br> Floyd, S., <b> <a href="./REDqueue.txt"> RED: Average queue length vs. instantaneous queue length</a></b>, November 1997. <br> Floyd, S., <b> <a href="./email/sf.98mar11.txt"> RED with Drop From Front</a></b>, March 1998. <br> Floyd, S., <b><a href="./papers/holt.ps.Z"> Notes on the Holt-Winters Procedure,</a></b> October 1993.<br> This note describes a variant of the Exponential-Weighted Moving Average procedure for estimating the average queue size that takes into account the average slope of the average queue size, as well as the queue size itself.<br> <br> </ul> <a name="recommendations"> <h2>Papers with Recommendations for RED</h2> <ul> <li>Firoiu, V., and Borden, M., <b><a href="http://citeseer.ist.psu.edu/firoiu00study.html"> A Study of Active Queue Management for Congestion Control</a>.</b> <br> This paper observes the oscillatory behavior with RED when the average packet drop rate exceeds max_p, in the absence of RED's "gentle_" modification, and strongly recommends against the discontinuity in the packet drop rate that occurs in the original, non-"gentle_" variant of RED. This paper also recommends that the ideal rate for sampling the average queue size is "once every RTT"; it seems to me that with such an infrequent sampling of the average queue size, RED could be overly slow to respond to sharp increases in the queue size. </ul> <a name="related"> <h2>Related Papers</h2> <ul> <li>Floyd, S., <b><a href="./papers/tcp_ecn.4.ps.Z"> TCP and Explicit Congestion Notification</a>.</b> ACM Computer Communication Review, V. 24 N. 5, October 1994, p. 10-23. [This issue of CCR incorrectly has "1995" on the cover instead of "1994".] <b><a href="abstracts.html#F94">Abstract</a>.</b> <br><br> <li>Floyd, S., and Jacobson, V.,<b> <a href="./papers/phase.ps.Z"> On Traffic Phase Effects in Packet-Switched Gateways.</a></b> Internetworking: Research and Experience, V.3 N.3, September 1992, p.115-156. <b><a href="abstracts.html#FJ92">Abstract</a>.</b> An earlier version of this paper appeared in Computer Communication Review, V.21 N.2, April 1991. <br><br> <li>Floyd, S.,<b> <a href="./papers/gates1.ps.Z"> Connections with Multiple Congested Gateways in Packet-Switched Networks Part 1: One-way Traffic.</a></b> Computer Communications Review, Vol.21, No.5, October 1991, p. 30-47. <b><a href="abstracts.html#F91">Abstract</a>.</b> <br><br> </ul> <!-- <a name="email"> <h2>Email discussions regarding RED</h2> <ul> <li>the <a href="http://www-nrg.ee.lbl.gov/diff-serv-arch/"> DiffServ mailing list</a> archives (including a thread on <a href="http://www-nrg.ee.lbl.gov/diff-serv-arch/thrd48.html"> AF: To RED or not to RED</a>), the <a href="ftp://ftp.isi.edu/end2end"> end2end-interest mailing list</a> archives. </ul> --> <p> Return to the [<a href="floyd.html"> Sally Floyd</a>].<br> Last modified: November 2008. Links updated: October 2008. </body></html>