COS 461: Computer Networks: Spring 2011 Lectures: MW 10 10:50am in Bowen 222 Prof. Mike Freedman
COS 461: Computer Networks: Spring 2011 Lectures: MW 10 10:50am in Bowen 222 Prof. Mike Freedman
COS 461: Computer Networks: Spring 2011 Lectures: MW 10 10:50am in Bowen 222 Prof. Mike Freedman
Spring
2011
Lectures:
MW
10‐10:50am
in
Bowen
222
Prof.
Mike
Freedman
Precepts:
F
10‐10:50am,
11‐11:50am
Preceptors:
Matvey
Arye,
Jacopo
Cesareo,
Prem
Gopalan
hNp://www.cs.princeton.edu/courses/archive/spr11/cos461/
What
You
Learn
in
This
Course
• Knowledge:
how
the
Internet
works
– IP
protocol
suite
– Internet
architecture
– ApplicaTons
(Web,
DNS,
P2P,
…)
• Insight:
key
concepts
in
networking
– Protocols,
layering,
resource
allocaTon,
naming
• Skill:
network
programming
– Many
nodes
are
general‐purpose
computers
• And
increasingly,
even
special‐purpose
switches
are
programmable!
– You
can
program
the
nodes
– Very
easy
to
innovate
and
develop
new
uses
of
network
– Contrast:
Ma
Bell
owned
the
telecom
network,
no
innovaTon
2
Learning
the
Material:
People
• Lecture
(Prof.
Mike
Freedman)
– Slides
available
online
at
course
Web
site
– Office
hours:
Immediately
following
lectures
• Teaching Assistants office hours TBD
• Main
email:
cos461‐staff
at
lists.cs.princeton.edu
– Email
to
individual
TAs
will
not
be
answered
• Main
Q&A
form:
www.piazzza.com
– We
will
add
all
your
email
addresses
to
the
course
– Graded
on
class
parTcipaTon:
so
ask
*and*
answer!
3
Learning
the
Material:
Books
• Required
textbook
– Computer
Networks:
A
Systems
Approach
(4th
edi9on),
by
Peterson
and
Davie
[Okay
to
use
the
3rd
ediTon]
•
Books
on
reserve
– Networking
text
books
• Computer
Networking:
A
Top‐Down
Approach
Featuring
the
Internet
(3rd
edi9on),
by
Kurose
and
Ross
• Computer
Networks
(4th
edi9on),
by
Tanenbaum
– Network
programming
references
• TCP/IP
Illustrated,
Volume
1:
The
Protocols,
by
Stevens
• Unix
Network
Programming,
Volume
1:
The
Sockets
Networking
API
(3rd
Edi9on),
by
Stevens,
Fenner,
&
Rudolf
4
Grading
and
Schedule
• Four
assignments
(10%
each)
– 95%
3
hours,
70%
2
days
late,
50%
>
3
days
late
– One
free
late
day
during
semester
– Must
complete
all
assignments
to
pass
• Two
exams
(50%
total)
– Midterm
exam
before
spring
break
(25%)
– Final
exam
during
exam
period
(25%)
• Class
parTcipaTon
(10%)
– In
lecture
and
precept
– In
the
forums
5
Graduate
Students:
Two
Choices
• Pick
one
of
two
opTons
– Do
the
four
programming
assignments
– Or,
first
two
assignments,
plus
research
project
• Research
projects
– Networking‐related
research
problem
– Must
have
a
systems
programming
component
– Talk
to
me
6
Policies:
Write
Your
Own
Code
Programming
in
an
individual
creaTve
process.
While
thinking
about
a
problem,
discussions
with
friends
are
encouraged.
However,
when
the
Tme
comes
to
write
code
that
solves
the
problem,
the
program
must
be
your
own
work.
If
you
have
a
quesTon
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.
Lerng
someone
copy
your
program
or
using
someone
else's
code
in
any
form
is
a
viola7on
of
academic
regula7ons.
7
Networking
is
Relevant
8
Informa7on
wants
to
be
free
because
it
has
become
so
cheap
to
distribute,
copy,
and
recombine...
It
wants
to
be
expensive
because
it
can
be
immeasurably
valuable
to
the
recipient.
(1985)
9
http://www.google.com/transparencyreport/traffic/
The
monolithic
view
3 THE 4
INTERNET 5
2
!!!!
7 6
Web server
Client
Browser
14
Why
“Internet”
• Network
of
networks
• Standardized
format
and
protocols
for
speaking
between
HETEROGENOUS
networks
15
Why
“Internet”
• Network
of
networks
• Standardized
format
and
protocols
for
speaking
between
HETEROGENOUS
networks
16
The
monolithic
view
3 THE 4
INTERNET 5
2
!!!!
7 6
Web server
Client
Browser
17
A
network
of
“Autonomous
Systems”
4
3
5
2
7 6
Web server
Client
Browser
•
How
do
you
name?
•
How
do
you
find
a
name?
18
Announcing
a
traffic
route
4
3
5
2
7 6
Web server
Client
Browser
“Egypt
is
in
this
direcTon”
19
“RouTng”
traffic
to
a
desTnaTon
4
3
5
2
7 6
Web server
Client
Browser
20
Withdrawing
a
traffic
route
4
3
5
2
7 6
1 ???
Web server
Client
Browser
“Egypt
is
not
in
this
direcTon”
21
Key
Concepts
in
Networking
• Protocols
– Speaking
the
same
language
– Syntax
and
semanTcs
• Layering
– Standing
on
the
shoulders
of
giants
– A
key
to
managing
complexity
• Resource
allocaTon
– Dividing
scare
resources
among
compeTng
parTes
– Memory,
link
bandwidth,
wireless
spectrum,
paths,
• Naming
– What
to
call
computers,
services,
protocols,
…
24
Key
Concepts
in
Networking
• Protocols
– Speaking
the
same
language
– Syntax
and
semanTcs
All
speak
IPv4
“Internet
Protocol
version
4”
25
Protocol
design
is
about
tradeoffs
• How
should
hosts
and
routers
communicate?
– Standard
protocol
– Fast:
Machine
readable
in
hardware
at
line
rates
• Browsers,
web
servers,
and
proxies?
– Can
be
slower:
sowware
readable
– Human
readable
– Extensible
and
forward‐compaTble
– Not
everybody
might
be
familiar
with
extensions
26
IPv4
Packet
4-bit
4-bit Header 8-bit Type of 16-bit Total Length (Bytes)
Version Length Service (TOS)
3-bit
16-bit Identification 13-bit Fragment Offset
Flags
Payload
27
Example:
HyperText
Transfer
Protocol
HTTP/1.1 200 OK
Date: Mon, 2 Feb 2009 13:09:03 GMT
Server: Netscape-Enterprise/3.5.1
Last-Modified: Mon, 42 Feb 2009 11:12:23 GMT
Response Content-Length: 21
CRLF
Site under construction
28
Key
Concepts
in
Networking
• Protocols
– Speaking
the
same
language
– Syntax
and
semanTcs
• Layering
– Standing
on
the
shoulders
of
giants
– A
key
to
managing
complexity
29
Layering
=
FuncTonal
AbstracTon
• Sub‐divide
the
problem
– Each
layer
relies
on
services
from
layer
below
– Each
layer
exports
services
to
layer
above
• Interface
between
layers
defines
interacTon
– Hides
implementaTon
details
– Layers
can
change
without
disturbing
other
layers
Application
Application-to-application channels
Host-to-host connectivity
Link hardware 30
The
Internet
Protocol
Suite
Waist
IP
Data Link
NET1 NET2 … NETn
Physical
User A User B
Get index.html
Application
App-to-app
Connection ID
channels
Host-to-host
Source/Destination
connectivity
Link Address
Link hardware
32
IP
Suite:
End
Hosts
vs.
Routers
host host
HTTP message
HTTP HTTP
TCP segment
TCP TCP
router router
IP packet IP packet IP packet
IP IP IP IP
33
Conclusions
• Internet
is
a
network
of
networks
– How
hosts
and
networks
name
one
another,
find
one
another,
and
talk
with
one
another
• Key
concepts
in
networking
– Protocols,
layers,
resource
allocaTon,
and
naming
• Next
lecture:
– How
does
YouTube
and
Neylix
serve
you
videos?
– E.g.,
HTTP,
DNS,
and
content
distribuTon
networks
• Next
week:
– Back
to
the
1960s
34