1 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant: Mike Wawrzoniak

Slides:



Advertisements
Similar presentations
COS 461: Computer Networks Spring 2011 Lectures: MW 10-10:50am in Bowen 222 Prof. Mike Freedman Precepts: F 10-10:50am, 11-11:50am Preceptors: Matvey Arye,
Advertisements

BZUPAGES.COM 1 User Datagram Protocol - UDP RFC 768, Protocol 17 Provides unreliable, connectionless on top of IP Minimal overhead, high performance –No.
Copyright 1999, S.D. Personick. All Rights Reserved. Telecommunications Networking II Lecture 32 Transmission Control Protocol (TCP) Ref: Tanenbaum pp:
CPSC 441: Intro, UDP1 Transport Layer Instructor: Carey Williamson Office: ICT Class Location:
© 2007 Cisco Systems, Inc. All rights reserved.Cisco Public 1 Version 4.0 OSI Transport Layer Network Fundamentals – Chapter 4.
Network Layer Packet Forwarding IS250 Spring 2010
CSE 486/586, Spring 2012 CSE 486/586 Distributed Systems The Internet in 2 Hours: The First Hour Steve Ko Computer Sciences and Engineering University.
CPSC156a: The Internet Co-Evolution of Technology and Society Lecture 3: September 11, 2003 Internet Basics, continued Acknowledgments: R. Wang and J.
1 COS 461: Computer Networks Spring 2008 (MW 1:30-2:50 in CS 105) Jennifer Rexford Teaching Assistants: Sunghwan Ihm and Yaping Zhu
COS 461: Computer Networks Jennifer Rexford Lectures: MW 10-10:50am in Architecture N101 Preceptors: Rob Kiefer, Xiaozhou Li, and Peng Sun Precepts: F.
CPSC 441: Intro, UDP1 Instructor: Anirban Mahanti Office: ICT Class Location: ICT 121 Lectures: MWF 12:00 – 12:50 Notes.
COS 461: Computer Networks Spring 2009 (MW 1:30-2:50 in CS 105) Mike Freedman Teaching Assistants: Wyatt Lloyd and Jeff Terrace
Internet Routing COS 598A Jennifer Rexford Tuesdays/Thursdays 11:00am-12:20pm.
IP-UDP-RTP Computer Networking (In Chap 3, 4, 7) 건국대학교 인터넷미디어공학부 임 창 훈.
Gursharan Singh Tatla Transport Layer 16-May
Process-to-Process Delivery:
Lect3..ppt - 09/12/04 CIS 4100 Systems Performance and Evaluation Lecture 3 by Zornitza Genova Prodanoff.
1 Transport Layer Computer Networks. 2 Where are we?
TCP/IP Essentials A Lab-Based Approach Shivendra Panwar, Shiwen Mao Jeong-dong Ryoo, and Yihan Li Chapter 0 TCP/IP Overview.
TELE202 Lecture 9 Internet Protocols (1) 1 Lecturer Dr Z. Huang Overview ¥Last Lecture »Congestion control »Source: chapter 12 ¥This Lecture »Internet.
What is a Protocol A set of definitions and rules defining the method by which data is transferred between two or more entities or systems. The key elements.
Network Technologies (TCP/IP Suite) Tahir Azim
Chapter 1: Introduction to Web Applications. This chapter gives an overview of the Internet, and where the World Wide Web fits in. It then outlines the.
Computer Networks CEN 5501C Spring, 2008 Ye Xia (Pronounced as “Yeh Siah”)
1.1 What is the Internet What is the Internet? The Internet is a shared media (coaxial cable, copper wire, fiber optics, and radio spectrum) communication.
CSx760 Computer Networks1 Introduction to Network Protocols Kang Li.
COS 461: Computer Networks Mike Freedman Spring 2013 Lectures: MW 10-10:50am in Architecture N101 Preceptors: Aaron Blankstein, Scott Erickson, Naga Katta.
CSE 486/586, Spring 2014 CSE 486/586 Distributed Systems The Internet in 2 Hours: The First Hour Steve Ko Computer Sciences and Engineering University.
TCP/IP Essentials A Lab-Based Approach Shivendra Panwar, Shiwen Mao Jeong-dong Ryoo, and Yihan Li Chapter 5 UDP and Its Applications.
Introduction to Networks CS587x Lecture 1 Department of Computer Science Iowa State University.
1 Introduction. 2 Goals for Today’s Class Course overview –Goals of the course –Structure of the course –Learning the material –Course grading –Academic.
Digital Multimedia, 2nd edition Nigel Chapman & Jenny Chapman Chapter 17 This presentation © 2004, MacAvon Media Productions Multimedia and Networks.
TCOM 509 – Internet Protocols (TCP/IP) Lecture 04_a Transport Protocols - UDP Instructor: Dr. Li-Chuan Chen Date: 09/22/2003 Based in part upon slides.
Fall 2005Computer Networks20-1 Chapter 20. Network Layer Protocols: ARP, IPv4, ICMPv4, IPv6, and ICMPv ARP 20.2 IP 20.3 ICMP 20.4 IPv6.
Fundamentals of Computer Networks ECE 478/578 Lecture #19: Transport Layer Instructor: Loukas Lazos Dept of Electrical and Computer Engineering University.
Computer Networking. 2 Outline 3 Objectives Understand the state-of-the-art in network protocols, architectures and applications Understand how networking.
FALL 2005CSI 4118 – UNIVERSITY OF OTTAWA1 Part 2.5 Internetworking Chapter 25 (Transport Protocols, UDP and TCP, Protocol Port Numbers)
1 The Internet and Networked Multimedia. 2 Layering  Internet protocols are designed to work in layers, with each layer building on the facilities provided.
Copyright 2002, S.D. Personick. All Rights Reserved.1 Telecommunications Networking II Topic 20 Transmission Control Protocol (TCP) Ref: Tanenbaum pp:
The Inter-network is a big network of networks.. The five-layer networking model for the internet.
TCOM 509 – Internet Protocols (TCP/IP) Lecture 03_b Protocol Layering Instructor: Dr. Li-Chuan Chen Date: 09/15/2003 Based in part upon slides of Prof.
Internet Protocol ECS 152B Ref: slides by J. Kurose and K. Ross.
Internetworking Internet: A network among networks, or a network of networks Allows accommodation of multiple network technologies Universal Service Routers.
Internetworking Internet: A network among networks, or a network of networks Allows accommodation of multiple network technologies Universal Service Routers.
1 CS 4396 Computer Networks Lab TCP/IP Networking An Example.
Networking Basics CCNA 1 Chapter 11.
15-744: Computer Networking L-1 Intro to Computer Networks.
Transport Layer3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach Featuring the Internet, 3 rd edition. Jim Kurose, Keith Ross Addison-Wesley,
CMSC 23300/33300 Computer Networks Spring 2006 (Tu, Th 1:30-2:50 in Ry 251) Lecturer: Ian Foster Teaching Assistants: George Kuan, Ido Rosen, Ioan Raicu,
Digital Multimedia, 2nd edition Nigel Chapman & Jenny Chapman Chapter 17 This presentation © 2004, MacAvon Media Productions Multimedia and Networks.
1 CDA 4527 Computer Communication Networking (not “analysis”) Prof. Cliff Zou School of Electrical Engineering and Computer Science University of Central.
1 CSE524: Lecture 2 Internet protocols in a nutshell (Protocols in practice)
Transport Protocols.
ECE 374: Computer Networks & Internet Introduction Spring 2015 Prof. Michael Zink.
1 CNT 4704 Analysis of Computer Communication Networks Cliff Zou Department of Electrical Engineering and Computer Science University of Central Florida.
ECE 374: Computer Networks & Internet Introduction Spring 2012 Prof. Michael Zink.
1 Review – The Internet’s Protocol Architecture. Protocols, Internetworking & the Internet 2 Introduction Internet standards Internet standards Layered.
Computer Networks CNT5106C
1 Network Architecture Section Network Architecture Challenge –Fill the gap between hardware capabilities and application expectations, and to.
McGraw-Hill Chapter 23 Process-to-Process Delivery: UDP, TCP Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display.
CSE 486/586, Spring 2013 CSE 486/586 Distributed Systems The Internet in 2 Hours: The First Hour Steve Ko Computer Sciences and Engineering University.
TCP/IP1 Address Resolution Protocol Internet uses IP address to recognize a computer. But IP address needs to be translated to physical address (NIC).
COS 461: Computer Networks Mike Freedman Spring 2014 Lectures: MW 10-10:50am in CS 104 Lead Preceptor: Dr. Sandra Batista Preceptors: Marcela Melara, Scott.
What is a Protocol A set of definitions and rules defining the method by which data is transferred between two or more entities or systems. The key elements.
Introduction to TCP/IP networking
Process-to-Process Delivery:
Lecture 6: TCP/IP Networking 1nd semester By: Adal ALashban.
1 TRANSMISSION CONTROL PROTOCOL / INTERNET PROTOCOL (TCP/IP) K. PALANIVEL Systems Analyst, Computer Centre Pondicherry University, Puducherry –
Process-to-Process Delivery: UDP, TCP
Presentation transcript:

1 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant: Mike Wawrzoniak

2 Goals for Today’s Class COS 461 overview –Goals of the course –Structure of the course –Learning the material –Programming assignments –Course grading –Academic policies Key concepts in data networking –Protocols –Layering –Resource allocation –Naming

3 What You Learn in This Course Skill: network programming –Socket programming –Designing and implementing protocols Knowledge: how the Internet works –IP protocol suite –Internet architecture –Applications (Web, , P2P, VoIP, …) Insight: key concepts in networking –Protocols –Layering –Resource allocation –Naming

4 Structure of the Course (1 st Half) Start at the top –Sockets: how applications view the Internet –Protocols: essential elements of a protocol Then study the “narrow waist” of IP –IP best-effort packet-delivery service –IP addressing and packet forwarding And how to build on top of the narrow waist –Transport protocols (TCP, UDP) –Domain Name System (DNS) –Glue (ARP, DHCP, ICMP) –End-system security and privacy (NAT, firewalls) Looking underneath IP –Link technologies (Ethernet, wireless, …)

5 Structure of the Course (2 nd Half) And how to get the traffic from here to there –Internet routing architecture (the “inter” in Internet) –Intradomain and interdomain routing protocols Building applications –Web and content-distribution networks – –Peer-to-peer file sharing –Multimedia streaming and voice-over-IP Other approaching to building networks –Circuit switching (e.g., ATM, MPLS, …) –More on wireless networks, multicast, …

6 Learning the Material: People Lecture (Jennifer Rexford) –When: MW 1:30-2:50 in Friend 109 –Slides available online at course Web site –Office hours to be announced, and by appointment Teaching Assistant (Mike Wawrzoniak) –Office hours to be announced, and by appointment Lab TAs in the Friend Center 016/017 Mailing list – –Sign up: –Read often. Good place to ask (and answer!) questions

7 Contacting Us Jennifer Rexford –Room 306 in Computer Science Building – at –Phone: is better Mike Wawrzoniak –Room 216 In Computer Science Building – –Phone:

8 Learning the Material: Books Required textbook –Computer Networks: A Systems Approach (3rd edition), by Peterson and Davie –Mostly covers the material in the first half of the class Books on reserve –Networking text books  Computer Networking: A Top-Down Approach Featuring the Internet (3rd edition), by Kurose and Ross  Computer Networks (4th edition), by Tanenbaum –Network programming references  TCP/IP Illustrated, Volume 1: The Protocols, by Stevens  Unix Network Programming, Volume 1: The Sockets Networking API (3rd Edition), by Stevens, Fenner, & Rudolf Online resources and handouts –E.g. on socket programming

9 Programming Assignments Stanford Virtual Network System –Constructs virtual network topologies that integrate directly into physical networks –Traffic forwarded to your program, running in user space – Sequence of three assignments –File-transfer directory copy –IP router –Reliable transport protocol Some written questions in each assignment –Based on material from lecture and the reading Additional assignment during Reading Period

10 Facilities for Programming Recommended options: OIT “hats” Linux cluster –Friend Center 016 or 017 computer, secure shell to “hats” (hats.princeton.edu), or –Your own PC, secure shell to “hats” –Why: common environment, and access to lab TAs Other option: on your own PC (not recommended) –Running GNU tools on Linux, or –Running GNU tools on Windows, or –Running a standard C development environment Suggestion: test this week –Logging in to the “hats” cluster –Writing and running “Hello World” in C

11 Graduate Students: Two Choices Pick one of two options –Do the four programming assignments –Or, do the first two assignments, plus a research project Research projects –Networking-related research problem –Must have a programming component –Write-up of project due on Dean’s Date –Approach me about project ideas before spring break

12 Grading and Schedule Assignments (15% each) –Assignment 1 in week 3 or 4 –Assignment 2 in week 5 or 6 –Assignment 3 late in 2 nd half of the semester –Assignment 4 on Dean’s Date Two “midterm” exams (15% each) –One during midterm week (week 6) –Another during the last week of classes (week 12) Class participation (10%) –In lecture –On the listserv

13 Policies: Write Your Own Code Programming in an individual creative process much like composition. You must reach your own understanding of the problem and discover a path to its solution. During this time, discussions with friends are encouraged. However, when the time comes to write code that solves the problem, such discussions are no longer appropriate - the program must be your own work. If you have a question about how to use some feature of C, UNIX, etc., you can certainly ask your friends or the TA, but do not, under any circumstances, copy another person's program. Letting someone copy your program or using someone else's code in any form is a violation of academic regulations. "Using someone else's code" includes using solutions or partial solutions to assignments provided by commercial web sites, instructors, preceptors, teaching assistants, friends, or students from any previous offering of this course or any other course.

14 Okay, so let’s get started… with a crash course in data networking

15 Key Concepts in Networking Protocols –Speaking the same language –Syntax and semantics Layering –Standing on the shoulders of giants –A key to managing complexity Resource allocation –Dividing scare resources among competing parties –Memory, link bandwidth, wireless spectrum, paths, … –Distributed vs. centralized algorithms Naming –What to call computers, services, protocols, …

16 Protocols: Calendar Service Making an appointment with your advisor Specifying the messages that go back and forth –And an understanding of what each party is doing Please meet with me for 1.5 hours starting at 1:30pm on February 8, 2006? I can’t. Yes! Please meet with me for 1.5 hours starting at 3:00pm on February 8, 2006? Please meet with me for 1.5 hours starting at 4:30pm on February 8, 2006?

17 Okay, So This is Getting Tedious You: When are you free to meet for 1.5 hours during the next two weeks? Advisor: 10:30am on Feb 8 and 1:15pm on Feb 9. You: Book me for 1.5 hours at 10:30am on Feb 8. Advisor: Yes.

18 Well, Not Quite Enough Student #1: When can you meet for 1.5 hours during the next two weeks? Advisor: 10:30am on Feb 8 and 1:15pm on Feb 9. Student #2: When can you meet for 1.5 hours during the next two weeks? Advisor: 10:30am on Feb 8 and 1:15pm on Feb 9. Student #1: Book me for 1.5 hours at 10:30am on Feb 8. Advisor: Yes. Student #2: Book me for 1.5 hours at 10:30am on Feb 8. Advisor: Uh… well… I can no longer can meet then. I’m free at 1:15pm on Feb 9. Student #2: Book me for 1.5 hours at 1:15pm on Feb 9. Advisor: Yes.

19 Specifying the Details How to identify yourself? –Name? Social security number? How to represent dates and time? –Time, day, month, year? In what time zone? –Number of seconds since Jan 1, 1970? What granularities of times to use? –Any possible start time and meeting duration? –Multiples of five minutes? How to represent the messages? –Strings? Record with name, start time, and duration? What do you do if you don’t get a response? –Ask again? Reply again?

20 Example: HyperText Transfer Protocol GET /courses/archive/spring06/cos461/ HTTP/1.1 Host: User-Agent: Mozilla/4.03 CRLF HTTP/ OK Date: Mon, 6 Feb :09:03 GMT Server: Netscape-Enterprise/3.5.1 Last-Modified: Mon, 6 Feb :12:23 GMT Content-Length: 21 CRLF Site under construction Request Response

21 Example: IP Packet 4-bit Version 4-bit Header Length 8-bit Type of Service (TOS) 16-bit Total Length (Bytes) 16-bit Identification 3-bit Flags 13-bit Fragment Offset 8-bit Time to Live (TTL) 8-bit Protocol 16-bit Header Checksum 32-bit Source IP Address 32-bit Destination IP Address Options (if any) Payload 20-byteheader

22 IP: Best-Effort Packet Delivery Packet switching –Send data in packets –Header with source & destination address Best-effort delivery –Packets may be lost –Packets may be corrupted –Packets may be delivered out of order source destination IP network

23 Example: Transmission Control Protocol Communication service (socket) –Ordered, reliable byte stream –Simultaneous transmission in both directions Key mechanisms at end hosts –Retransmit lost and corrupted packets –Discard duplicate packets and put packets in order –Flow control to avoid overloading the receiver buffer –Congestion control to adapt sending rate to network load sourcenetworkdestination TCP connection

24 Protocol Standardization Communicating hosts speaking the same protocol –Standardization to enable multiple implementations –Or, the same folks have to write all the software Standardization: Internet Engineering Task Force –Based on working groups that focus on specific issues –Produces “Request For Comments” (RFCs)  Promoted to standards via rough consensus and running code  E.g., RFC 959 on “File Transfer Protocol” for Assignment #1 –IETF Web site is De facto standards: same folks writing the code –P2P file sharing, Skype, …

25 Layering: A Modular Approach Sub-divide the problem –Each layer relies on services from layer below –Each layer exports services to layer above Interface between layers defines interaction –Hides implementation details –Layers can change without disturbing other layers Link hardware Host-to-host connectivity Application-to-application channels Application

26 IP Suite: End Hosts vs. Routers HTTP TCP IP Ethernet interface HTTP TCP IP Ethernet interface IP Ethernet interface Ethernet interface SONET interface SONET interface host router HTTP message TCP segment IP packet

27 The Internet Protocol Suite UDPTCP Data Link Physical Applications The Hourglass Model Waist The waist facilitates interoperability FTPHTTPTFTPNV TCPUDP IP NET 1 NET 2 NET n …

28 Layer Encapsulation Get index.html Connection ID Source/Destination Link Address User AUser B

29 Problem: Packet size Solution: Split the data across multiple packets What if the Data Doesn’t Fit? On Ethernet, max IP packet is 1500 bytes Typical Web page is 10 kbytes GETindex.html GET index.html

30 Protocol Demultiplexing Multiple choices at each layer FTPHTTPTFTPNV TCPUDP IP NET 1 NET 2 NET n … TCP/UDPIP Port Number Network Protocol Field Type Field

31 Demultiplexing: Port Numbers Differentiate between multiple transfers –Knowing source and destination host is not enough –Need an id for each transfer between the hosts Specify a particular service running on a host –E.g., HTTP server running on port 80 –E.g., FTP server running on port 21 HTTP transfers FTP transfer

32 Is Layering Harmful? Layer N may duplicate lower level functionality –E.g., error recovery to retransmit lost data Layers may need same information –E.g., timestamps, maximum transmission unit size Strict adherence to layering may hurt performance –E.g., hiding details about what is really going on Some layers are not always cleanly separated –Inter-layer dependencies for performance reasons –Some dependencies in standards (header checksums) Headers start to get really big –Sometimes more header bytes than actual content

33 Resource Allocation: Queues Sharing access to limited resources –E.g., a link with fixed service rate Simplest case: first-in-first out queue –Serve packets in the order they arrive –When busy, store arriving packets in a buffer –Drop packets when the queue is full

34 What if the Data gets Dropped? Internet GET index.html Problem: Lost Data Internet GET index.html Solution: Timeout and Retransmit GET index.html

35 Solution: Add Sequence Numbers Problem: Out of Order What if the Data is Out of Order? GETx.htindeml GET x.htindeml GET index.html ml4inde2x.ht3GET1

36 Resource Allocation: Congestion Control What if too many folks are sending data? –Senders agree to slow down their sending rates –… in response to their packets getting dropped The essence of TCP congestion control –Key to preventing congestion collapse of the Internet

37 Transmission Control Protocol Flow control: window-based –Sender limits number of outstanding bytes (window size) –Receiver window ensures data does not overflow receiver Congestion control: adapting to packet losses –Congestion window tries to avoid overloading the network (increase with successful delivery, decrease with loss) –TCP connection starts with small initial congestion window time congestion window slow start congestion avoidance

38 Naming: Domain Name System (DNS) Properties of DNS –Hierarchical name space divided into zones –Translation of names to/from IP addresses –Distributed over a collection of DNS servers Client application –Extract server name (e.g., from the URL) –Invoke system call to trigger DNS resolver code  E.g., gethostbyname() on “ Server application –Extract client IP address from socket –Optionally invoke system call to translate into name  E.g., gethostbyaddr() on “ ”

39 Domain Name System comeduorgac uk zw arpa unnamed root bar westeast foomy ac cam usr in- addr generic domainscountry domains my.east.bar.edu usr.cam.ac.uk /24

40 DNS Resolver and Local DNS Server Application DNS resolver Local DNS server 1 10 DNS cache DNS query 2 DNS response 9 Root server 3 4 Top-level domain server 5 6 Second-level domain server 7 8 Caching based on a time-to-live (TTL) assigned by the DNS server responsible for the host name to reduce latency in DNS translation.

41 Conclusions Course objectives –Network programming, how the Internet works, and key concepts in networking Key concepts in networking –Protocols, layers, resource allocation, and naming Next lecture: network programming –Socket abstraction (important for assignment #1) –Read Chapter 1 of the Peterson/Davie book –Skim the online reference material on sockets –(Re)familiarize yourself with C programming on “hats”