ebook img

Computer Networks: An Open Source Approach PDF

768 Pages·2011·9.474 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Computer Networks: An Open Source Approach

Computer Networks: An Open Source Approach Computer Networks: An Open Source Approach Ying-Dar Lin National Chiao Tung University Ren-Hung Hwang National Chung Cheng University Fred Baker Cisco Systems, Inc. COMPUTER NETWORKS: AN OPEN SOURCE APPROACH Published by McGraw-Hill, a business unit of The McGraw-Hill Companies, Inc., 1221 Avenue of the Americas, New York, NY 10020. Copyright © 2012 by The McGraw-Hill Companies, Inc. All rights reserved. No part of this publication may be reproduced or distributed in any form or by any means, or stored in a database or retrieval system, without the prior written consent of The McGraw-Hill Companies, Inc., including, but not limited to, in any network or other electronic storage or transmission, or broadcast for distance learning. Some ancillaries, including electronic and print components, may not be available to customers outside the United States. This book is printed on acid-free paper. 1 2 3 4 5 6 7 8 9 0 DOC/DOC 1 0 9 8 7 6 5 4 3 2 1 ISBN 978-0-07-337624-0 MHID 0-07-337624-8 Vice President & Editor-in-Chief: M arty Lange Vice President EDP/Central Publishing Services: Kimberly Meriwether David Global Publisher: Raghothaman Srinivasan Senior Marketing Manager: Curt Reynolds Development Editor: Lorraine K. Buczek Senior Project Manager: Jane Mohr Design Coordinator: Brenda A. Rolwes Cover Designer: Studio Montage, St. Louis, Missouri Cover Image: The illustration “Packet Factory” was drafted by Ying-Dar Lin and then drawn by his 12-year-old daughter, Melissa Hou-Yun Lin. It mimics routing and forwarding at the control plane (up to the 3rd fl oor) and the data plane (up to the 2nd fl oor), respectively. Buyer: Susan K. Culbertson Media Project Manager: Balaji Sundararaman Compositor: Glyph International Typeface: 10/12 Times LT Std Printer: R. R. Donnelley All credits appearing on page or at the end of the book are considered to be an extension of the copyright page. Library of Congress Cataloging-in-Publication Data Lin, Ying–Dar. Computer networks : an open source approach / Ying-Dar Lin, Ren-Hung Hwang, Fred Baker. p. cm. Includes bibliographical references and index. ISBN-13: 978-0-07-337624-0 (alk. paper) ISBN-10: 0-07-337624-8 (alk. paper) 1. Computer networks—Management. 2. Computer networks—Computer programs. 3. Open source software. I. Hwang, Ren-Hung. II. Baker, Fred, 1952- III. Title. TK5105.5.L55 2011 004.6—dc22 2010047921 www.mhhe.com Dedication Dedicated to Our Sweet Families .... 3 wives and 8 children. About the Authors Ying-Dar Lin is Professor of Computer Science at National Chiao Tung Univer- sity (NCTU) in Taiwan. He received his Ph.D. in Computer Science from UCLA in 1993. He spent his sabbatical year as a visiting scholar at Cisco Systems in San Jose in 2007–2008. Since 2002, he has been the founder and director of Network Benchmarking Lab (NBL, www.nbl.org.tw), which reviews network products with real traffi c. He also cofounded L7 Networks Inc. in 2002, which was later acquired by D-Link Corp. His research interests include design, analysis, implementation, and benchmarking of network protocols and algorithms, quality of services, network security, deep packet inspection, P2P networking, and embedded hardware/software co-design. His work on “multi-hop cellular” has been cited over 500 times. He is currently on the editorial boards of IEEE Communications Magazine, IEEE Com- munications Surveys and Tutorials, IEEE Communications Letters, Computer Com- munications, and Computer Networks. Ren-Hung Hwang is Research Distinguished Professor of Computer Science as well as director of Ching-Jiang Learning Center at National Chung Cheng University in Taiwan. He received his Ph.D. in Computer Science from the University of Massachusetts, Amherst, in 1993. He has published more than 150 international jour- nal and conference papers in the computer networking area. His research interests include ubiquitous computing, P2P networking, next-generation wireless networks, and e-Learning. He was the program chair of the 10 th International Symposium on Pervasive Systems, Algorithms, and Networks (I-SPAN) held in KaoHsiung, Taiwan, 2009. He is currently on the editorial board of the Journal of Information Science and Engineering . He received the Outstanding Teaching Award from National Chung Cheng University in 2002 and several Outstanding Communication and Network Courseware Design Awards from the Ministry of Education, Taiwan from 1998 to 2001. He currently also serves as a committee member of the IP Committee of TWNIC and the Criteria and Procedures Committee of the Institute of Engineering Education Taiwan (IEET). Fred Baker has been active in the networking and communications industry since the late 1970s, working successively for CDC, Vitalink, and ACC. He is currently a Fellow at Cisco Systems. He was IETF chair from 1996 to 2001. He has chaired a number of IETF working groups, including Bridge MIB, DS1/DS3 MIB, ISDN MIB, PPP Extensions, IEPREP, and IPv6 Operations, and served on the Internet Architecture Board from 1996 to 2002. He has coauthored or edited around 40 RFCs and contributed to others. The subjects covered include network management, OSPF and RIPv2 routing, quality of service (using both the Integrated Services and vi About the Authors vii Differentiated Services models), lawful interception, precedence-based services on the Internet, and others. In addition, he has served as a member of the Board of Trustees of the Internet Society 2002–2008, having served as its chair from 2002 through 2006. He is also a former member of the Technical Advisory Council of the Federal Communications Commission. He currently co-chairs the IPv6 Operations Working Group in the IETF, and is a member of the Internet Engineering Task Force Administrative Oversight Committee. Brief Contents Preface xvi 1 Fundamentals 1 2 Physical Layer 54 3 Link Layer 125 4 Internet Protocol Layer 223 5 Transport Layer 339 6 Application Layer 417 7 Internet QoS 546 8 Network Security 590 Appendices: A Who’s Who 654 B Linux Kernel Overview 669 C Development Tools 683 D Network Utilities 707 Index 723 viii Contents 1.5 Book Roadmap: A Packet’s Life 39 Preface xvii 1.5.1 Packet Data Structure: sk_buff 39 1.5.2 A Packet’s Life in a Web Server 40 1 1.5.3 A Packet’s Life in a Gateway 41 Chapter Performance Matters: From Socket to Driver within a Server 42 Fundamentals 1 Performance Matters: From Input Port to 1.1 Requirements for Computer Networking 2 Output Port within a Router 44 1.1.1 Connectivity: Node, Link, Path 2 Principle in Action: A Packet’s Life in the Historical Evolution: Link Standards 4 Internet 45 Historical Evolution: ATM Faded 6 1.6 Summary 46 1.1.2 Scalability: Number of Nodes 6 Common Pitfalls 47 1.1.3 Resource Sharing 7 Further Readings 48 Principle in Action: Datacom vs. Telecom 10 Frequently Asked Questions 50 1.2 Underlying Principles 10 Exercises 51 1.2.1 Performance Measures 10 Principle in Action: Little’s Result 13 1.2.2 Operations at Control Plane 14 2 Chapter 1.2.3 Operations at Data Plane 16 1.2.4 Interoperability 20 Physical Layer 54 1.3 The Internet Architecture 21 1.3.1 Solutions to Connectivity 22 2.1 General Issues 55 Principle in Action: Constantly Challenged 2.1.1 Data and Signal: Analog or Digital 55 Statelessness 23 Principle in Action: Nyquist Theorem vs. 1.3.2 Solutions to Scalability 25 Shannon Theorem 57 1.3.3 Solutions to Resource Sharing 27 2.1.2 Transmission and Reception Flows 59 1.3.4 Control-Plane and Data-Plane 2.1.3 Transmission: Line Coding and Digital Operations 29 Modulation 61 Principle in Action: Flavors of the Internet 2.1.4 Transmission Impairments 62 Architecture 31 Historical Evolution: Software Defi ned 1.4 Open Source Implementations 32 Radio 63 1.4.1 Open vs. Closed 32 2.2 Medium 65 1.4.2 Software Architecture in Linux 2.2.1 Wired Medium 65 Systems 33 2.2.2 Wireless Medium 68 1.4.3 Linux Kernel 36 2.3 Information Coding and Baseband 1.4.4 Clients and Daemon Servers 36 Transmission 70 1.4.5 Interface Drivers 37 2.3.1 Source and Channel Coding 71 1.4.6 Device Controllers 38 2.3.2 Line Coding 72 ix x Contents Open Source Implementation 2.1: 8B/10B 3.2.2 Point-to-Point Protocol (PPP) 145 Encoder 82 3.2.3 Internet Protocol Control Protocol 2.4 Digital Modulation and Multiplexing 84 (IPCP) 147 2.4.1 Passband Modulation 84 Open Source Implementation 3.4: PPP 2.4.2 Multiplexing 92 Drivers 148 2.5 Advanced Topics 96 3.2.4 PPP over Ethernet (PPPoE) 149 2.5.1 Spread Spectrum 96 3.3 Ethernet (IEEE 802.3) 150 2.5.2 Single-Carrier vs. Multiple-Carrier 106 3.3.1 Ethernet Evolution: A Big Picture 150 2.5.3 Multiple Inputs, Multiple Outputs Historical Evolution: Competitors to (MIMO) 109 Ethernet 153 Open Source Implementation 2.2: IEEE 3.3.2 The Ethernet MAC 153 802.11a Transmitter with OFDM 112 Open Source Implementation 3.5: Historical Evolution: Cellular Standards 116 CSMA/CD 161 Historical Evolution: LTE-Advanced vs. IEEE Historical Evolution: Power-Line Networking: 802.16m 117 HomePlug 166 2.6 Summary 118 3.3.3 Selected Topics in Ethernet 167 Common Pitfalls 119 Historical Evolution: Backbone Networking: SONET/SDH and MPLS 169 Further Readings 120 Historical Evolution: First-Mile Networking: Frequently Asked Questions 122 xDSL and Cable Modem 171 Exercises 123 3.4 Wireless Links 171 3.4.1 IEEE 802.11 Wireless LAN 172 3 Principle in Action: Why Not CSMA/CD in Chapter WLAN? 175 Open Source Implementation 3.6: IEEE 802.11 Link Layer 125 MAC Simulation with NS-2 177 3.1 General Issues 126 3.4.2 Bluetooth Technology 182 3.1.1 Framing 127 3.4.3 WiMAX Technology 186 3.1.2 Addressing 129 Historical Evolution: Comparing Bluetooth 3.1.3 Error Control and Reliability 130 and IEEE 802.11 187 Principle in Action: CRC or Checksum? 133 Historical Evolution: Comparing 3G, LTE, and Principle in Action: Error Correction WiMAX 190 Code 133 3.5 Bridging 191 Open Source Implementation 3.1: 3.5.1 Self-Learning 191 Checksum 134 Historical Evolution: Cut-Through vs. Store- Open Source Implementation 3.2: Hardware and-Forward 193 CRC-32 135 Open Source Implementation 3.7: Self- 3.1.4 Flow Control 137 Learning Bridging 194 3.1.5 Medium Access Control 138 3.5.2 Spanning Tree Protocol 196 3.1.6 Bridging 139 Open Source Implementation 3.8: Spanning 3.1.7 Link-Layer Packet Flows 139 Tree 198 Open Source Implementation 3.3: Link-Layer 3.5.3 Virtual LAN 200 Packet Flows in Call Graphs 139 Principle in Action: VLAN vs. 3.2 Point-to-Point Protocol 142 Subnet 201 3.2.1 High-Level Data Link Control 3.6 Device Drivers of a Network Interface 204 (HDLC) 143 3.6.1 Concepts of Device Drivers 204

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.