ELEC / COMP 177 – Fall 2016
Some slides from Kurose and Ross, Computer Networking, 5th Edition
ELEC / COMP 177 Fall 2016 Some slides from Kurose and Ross, Computer - - PowerPoint PPT Presentation
ELEC / COMP 177 Fall 2016 Some slides from Kurose and Ross, Computer Networking , 5 th Edition Application Layer Transport Layer Network Layer Link Layer Physical Layer 2 Application Layer Transport Layer Network Layer Link Layer
Some slides from Kurose and Ross, Computer Networking, 5th Edition
2
“Bits on a wire” Encoding schemes fight: attenuation distortion clock skew
3
Framing Error Detection Media Access Control Ethernet! MAC addresses Hubs & Switches Transfer between neighbors
4
IP – Internet Protocol! Packet Headers IP Addresses ICMP for error reporting and router signaling Routers Routing Protocols End-to-End packet transfer
5
TCP UDP End-to-End message transfer
Sockets
Flow Control Congestion Control
6
HTTP DNS IMAP
Sockets
… and many more! Skype BitTorrent RDP SSH LDAP NFS
7
8
9
10
application transport network data link physical application transport network data link physical application transport network data link physical
11
12
13
14
15
16
17
18
19
20
21
¡ Process sends/receives
¡ Socket analogous to door § Sending process shoves
§ Transport infrastructure on
§ Imagine you are just writing to
¡ API allow customization of
§ Choose transport protocol § Choose parameters of protocol
22
process TCP with buffers, variables socket host or server process TCP with buffers, variables socket host or server Internet controlled by OS controlled by app developer
23
24
25
26
27
Application Data Loss?
(OK or not?)
Throughput?
(Min required or elastic?)
Time Sensitive?
(Low delay required?)
File transfer Email Web pages Real-time audio / video Stored audio/video Gaming Instant messaging
28
Application Data Loss?
(OK or not?)
Throughput?
(Min required or elastic?)
Time Sensitive?
(Low delay required?)
File transfer No data loss Elastic “Normal” delay OK Email No data loss Elastic “Normal” delay OK Web pages No data loss Elastic “Normal” delay OK Real-time audio / video Loss tolerant Minimum Time sensitive Stored audio/video Loss tolerant Minimum “Normal” delay OK Gaming No data loss Minimum Time sensitive Instant messaging No data loss Elastic “Normal” delay OK
¡ Connection-oriented
§ Setup required between client
and server processes
¡ Reliable transport between
¡ Flow control
§ Sender won’t overwhelm
receiver
¡ Congestion control
§ Sender won’t overwhelm the
network
¡ Does not provide
§ Timing, minimum throughput
guarantees, security
¡ Unreliable data transfer
¡ Does not provide
§ Connection setup § Reliability § Flow control § Congestion control § Timing § Throughput guarantee § Security
29
Why bother with UDP then?
30
Application Data Loss?
(OK or not?)
Throughput?
(Min required or elastic?)
Time Sensitive?
(Low delay required?)
Transport Protocol
File transfer No data loss Elastic “Normal” delay OK TCP Email No data loss Elastic “Normal” delay OK TCP Web pages No data loss Elastic “Normal” delay OK TCP Real-time audio / video Loss tolerant Minimum Time sensitive UDP Stored audio/video Loss tolerant Minimum “Normal” delay OK TCP or UDP Gaming No data loss Minimum Time sensitive UDP Instant messaging No data loss Elastic “Normal” delay OK TCP
31
32
host name path name
33
PC running Chrome Server running Apache Web server Mac running Safari
34
Server accepts TCP connection from client HTTP messages (application-layer protocol messages) exchanged between browser (HTTP client) and Web server (HTTP server) Client initiates TCP connection (creates socket) to server, port 80
TCP connection closed by client or server
35
36
connection to HTTP server (process) at www.someCompany.com
message (containing URL) into TCP connection socket. Message indicates that client wants object someDept/index.html
www.someCompany.com waiting for TCP connection at port
notifying client
message, forms response message containing requested object, and sends message into its socket time (contains text and references to 10 jpeg images)
37
message containing html file, displays html. Parsing html file, finds 10 referenced jpeg objects
jpeg objects
connection. time
38
¡ Total = 2RTT+transmit time
39
time to transmit file initiate TCP connection RTT request file RTT file received time time
40
41
42
43
44
45
§ request succeeded, requested object later in this message
§ requested object moved, new location specified later in this
§ request message not understood by server
§ requested document not found on this server
In first line in server->client response message. A few sample codes:
46
47
Opens TCP connection to port 80 (default HTTP server port) at www.google.com Anything typed in sent to port 80 at www.google.com telnet www.google.com 80
GET /about/ HTTP/1.1 Host: www.google.com By typing this in (hit carriage return twice), you send this minimal (but complete) GET request to HTTP server
¡ Manual file request
¡ Filtering on protocol
¡ Viewing request/response ¡ HTTP conversation
48
49
50
client server usual http response msg usual http response msg
usual http request msg
access
ebay 8734
usual http request msg
create entry usual http response
ebay 8734 amazon 1678
usual http request msg
access
ebay 8734 amazon 1678
backend database
51