CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

48
CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010
  • date post

    15-Jan-2016
  • Category

    Documents

  • view

    214
  • download

    0

Transcript of CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Page 1: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

CSEE W4140Networking Laboratory

Opening Lecture

Jong Yul Kim01.25.2010

Page 2: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Computer Science in one word

Abstraction

“a mechanism and practice to reduce and factor out details so that one can focus on a few concepts at a time”

- wikipedia

Page 3: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Figure from Computer Networking: a top down approach

Page 4: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Figure from Computer Networking: a top down approach

Page 5: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Figure from Computer Networking: a top down approach

Page 6: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

INTERNETINTERNET

Page 7: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Details

Figure from “Google: A Behind-the-Scenes Tour” by Jeff Dean

Page 8: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Reality

Figure from “Google: A Behind-the-Scenes Tour” by Jeff Dean

Page 9: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Real Network Protocols

“RIP is a distance-vector protocol that operates in a manner very close to the idealized DV protocol we examined”

-Computer Networking: A Top-Down Approach 4/e

Page 10: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Course Objectives The main idea: learning by doing

Build a network using PCs, routers, cables Configure them properly Run the experiment Observe real network protocol behavior Gather data Analyze and evaluate

Explore how abstract concepts are designed to work in real life and to observe how they really behave

Page 11: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Course Objectives

Reinforce your knowledge of networks Gain first-hand experience and skills Learn how to use Linux for networks

Pre-requisite Computer Networks or equivalent

Page 12: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Required Textbook

Mastering Networks:An Internet Lab Manual (= The Manual)

You must have The Manual!

One reserved copy in the Engineering library.

Page 13: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Lab sequence

Core Labs:

Lab 2 - SingleSegment IPNetworks

Lab 1 -Introduction to

the Internet Lab

Lab 3 - StaticRouting

Lab 4 -DynamicRouting

Protocols

Lab 5 -TransportProtocols:

UDP and TCP

Advanced Labs:

Lab 7 - NATand DHCP

Lab 6 - LANswitching

Lab 8 - DomainName System

Lab 9 - SNMPLab 10 - IPMulticast

Page 14: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Lab Organization

Each lab has three parts Prelab HW - individually Lab session Lab report

You need to bring Your Lab Manual A USB drive to store your data

in groups of two

Page 15: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Lab Times

Tuesdays 10 am ~ 12 pm Tuesdays 4:10 ~ 6:40 pm Wednesdays 10 am ~ 12 pm

This one might be changed.

10 students in each lab time Please sign up!

Page 16: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Lab Equipment

Page 17: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Lectures

Mondays 2:30 ~ 4:00 pm at 327 Mudd

Go over topics in the upcoming lab Discussions on reading assignments Review of relevant Computer

Networks material

Page 18: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Grading

Prelab HW 10%

Lab performance & Lab reports 60%

Midterm 10%

Final 10%

In-class quiz & Participation 10%Open-book, open-notes,open to quiet discussions

Page 19: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Homework Policy Prelab HW

Individual work Due every Friday at 11:59 pm Don’t copy and paste from other sources

Lab reports Team work Due before next lab Don’t turn in 100 page reports! Avg.

5~20

Page 20: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Academic Honesty Policy Summary: Do your own work.

Do not copy other’s homework (past or current students).

Do not copy and paste from wikipedia or any other source including textbooks, web sites, etc.

If you cannot think of another way to explain your answer, you should give proper credit to the source.

http://www.cs.columbia.edu/education/honesty

Page 21: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Homework Policy

Late submission 20 points deducted per day But you can use 3 late days

At most 1 week for reconsideration after grades are announced

Page 22: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Contact and Office Hours

InstructorJong Yul Kim (jyk@cs)

TBA after lab sessions are fixed. TAs

Kyung Wha Kim (kk2515)Varun Mahendra (vum2001)Third TA (???)

Page 23: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

How to fail this class quickly #1

Connect any lab machine to the Internet.

ALWAYS be careful and ask yourselfbefore you plug it in:

“Where is the other end of the cable?”

Page 24: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

How to fail this class quickly #2

Leave the door to CRF open.

ALWAYS keep CRF entrance closed. Lab doors can be open while you’re in the lab.

Page 25: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

To get the most out of this course

Prepare for labs in advance Read the lab manual beforehand If you’re not familiar with something in

the lab, consult textbook, ask me or TAs during office hours or by email

Submit your prelab HW on time

Come to class

Page 26: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Review of Important Concepts

The following slides are from the texbook’s authors. Some content have been modified to fit this class.

Page 27: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Layers

The complexity of the communication task is reduced by using multiple protocol layers:

Each protocol is implemented independently Each protocol is responsible for a specific

subtask Protocols are grouped in a hierarchy

A structured set of protocols is called a communications architecture or protocol suite

Page 28: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

TCP/IP Protocol Suite

The TCP/IP protocol suite is the protocol architecture of the Internet

The TCP/IP suite has four layers: Application, Transport, Network, and Data Link Layer

End systems (hosts) implement all four layers. Gateways (Routers) only have the bottom two layers.

Application

Transport

Network Operating system

User-level programs

Data Link

Data Link

Media AccessControl (MAC)

Sublayer inLocal AreaNetworks

Page 29: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Functions of the Layers Data Link Layer:

Service: Reliable transfer of frames over a linkMedia Access Control on a LAN

Functions: Framing, media access control, error checking

Network Layer: Service: Move packets from source host to

destination host Functions: Routing, addressing

Transport Layer: Service: Delivery of data between hosts Functions: Connection establishment/termination,

error control, flow control Application Layer:

Service: Application specific (delivery of email, retrieval of HTML documents, reliable transfer of file)

Functions: Application specific

Page 30: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

TCP/IP Suite and OSI Reference Model

ApplicationLayer

ApplicationLayer

PresentationLayer

SessionLayer

TransportLayer

NetworkLayer

(Data) LinkLayer

PhysicalLayer

TransportLayer

NetworkLayer

OSIReference

Model

(Data) LinkLayer

TCP/IP Suite

The TCP/IP protocol stack does not define the lower layers of a complete protocol stack

Page 31: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Assignment of Protocols to Layers

NetworkLayer

Routing Protocols

PIM

OSPF

RIP

ApplicationLayer

Data LinkLayer

IP

ARP Ethernet

NetworkInterface

TransportLayer

TCP UDP

SNMPFTP DNSHTTP

ICMP

IGMP

pingapplication Telnet

DHCP

Page 32: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Layered Communications

N+1 LayerEntity

N+1 LayerEntity

N+1 Layer ProtocolN+1 Layer

N-1 LayerEntity

N-1 LayerEntity

N-1 Layer ProtocolN-1 Layer

N LayerEntity

N LayerEntity

N Layer ProtocolN Layer

layer N+1/Ninterface

layer N/N-1interface

Page 33: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Service Primitives

N+1 LayerEntity

N+1 LayerEntity

N LayerEntity

N LayerEntity

N+1 Layer Peer Protocol

Request Delivery

IndicateDelivery

Communication services are invoked via function calls. The functions are called service primitives

Page 34: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Service Primitives

Recall: A layer N+1 entity sees the lower layers only as a service provider

Service Provider

N+1 LayerEntity

N+1 LayerEntity

N+1 Layer Peer Protocol

Request Delivery

IndicateDelivery

Page 35: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Service Access Points A service user accesses services of the service

provider at Service Access Points (SAPs) A SAP has an address that uniquely identifies where

the service can be accessed

Layer-NEntityN Layer

Layer- N-1Entity

N-1Layer

layer N/N-1service interface

LayerN-1SAP

Page 36: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Layers in the ExampleHTTP

TCP

IP

argon.tcpip-lab.edu

128.143.137.144

Ethernet Ethernet Ethernet

IP

HTTP

TCP

IP

neon.tcpip-lab.edu128.143.71.21

Ethernet

router71.tcpip-lab.edu

128.143.137.100:e0:f9:23:a8:20

router137.tcpip-lab.edu

128.143.71.1

HTTP protocol

TCP protocol

IP protocol

Ethernet

IP protocol

Ethernet

Page 37: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Layers and Services Service provided by TCP to HTTP:

reliable transmission of data over a logical connection Service provided by IP to TCP:

unreliable transmission of IP datagrams across an IP network

Service provided by Ethernet to IP: transmission of a frame across an Ethernet segment

Other services: DNS: translation between domain names and IP addresses ARP: Translation between IP addresses and MAC addresses

Page 38: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing As data is moving down the protocol stack, each

protocol is adding layer-specific control information

HTTP

TCP

IP

Ethernet

User data

User dataHTTP Header

TCP Header

TCP HeaderIP Header

TCP HeaderIP HeaderEthernetHeader

EthernetTrailer

IP datagram

TCP segment

Ethernet frame

User dataHTTP Header

User dataHTTP Header

User dataHTTP Header

Page 39: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing in our Example Let us look in detail at the Ethernet frame

between Argon and the Router, which contains the TCP connection request to Neon.

This is the frame in hexadecimal notation.

00e0 f923 a820 00a0 2471 e444 0800 4500 002c 9d08 4000 8006 8bff 808f 8990 808f 4715 065b 0050 0009 465b 0000 0000 6002 2000 598e 0000 0204 05b4

Page 40: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing

Application dataTCP HeaderIP HeaderEthernet Header Ethernet Trailer

Ethernet frame

destination address

source address

type

6 bytes

CRC

4 bytes

Page 41: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

00:e0:f9:23:a8:20

0:a0:24:71:e4:44

0x0800

6 bytes

CRC

4 bytes

Encapsulation and Demultiplexing: Ethernet Header

Application dataTCP HeaderIP HeaderEthernet Header Ethernet Trailer

Ethernet frame

Page 42: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing: IP Header

Application dataTCP HeaderEthernet Header Ethernet Trailer

Ethernet frame

IP Header

DS ECNversion(4 bits)

headerlength

Total Length (in bytes)(16 bits)

Identification (16 bits)flags

(3 bits)Fragment Offset (13 bits)

Source IP address (32 bits)

Destination IP address (32 bits)

TTL Time-to-Live(8 bits)

Protocol(8 bits)

Header Checksum (16 bits)

32 bits

Page 43: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing: IP Header

Application dataTCP HeaderEthernet Header Ethernet Trailer

Ethernet frame

IP Header

0x0 0x00x4 0x5 4410

9d08 0102 00000000000002

128.143.137.144

128.143.71.21

12810 0x06 8bff

32 bits

Page 44: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing: TCP Header

Application dataEthernet Header Ethernet Trailer

Ethernet frame

IP Header TCP Header

Sequence number (32 bits)

Source Port Number Destination Port Number

Acknowledgement number (32 bits)

window sizeheaderlength

0 Flags

TCP checksum urgent pointer

32 bits

length Max. segment sizeoptiontype Option:

maximum segment size

Page 45: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing: TCP Header

Application dataEthernet Header Ethernet Trailer

Ethernet frame

IP Header TCP Header

60783510

162710 8010

010

819210610 0000002 0000102

0x598e 00002

32 bits

410 146010210

Page 46: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Encapsulation and Demultiplexing: Application data

Application dataEthernet Header Ethernet Trailer

Ethernet frame

IP Header TCP Header

No Application Data

in this frame

Page 47: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Main Points of Lab 1 Getting acquainted

Hardware setup Linux Network tools (ping, tcpdump, wireshark)

Lab reports How to capture data What to include / exclude in lab reports

Page 48: CSEE W4140 Networking Laboratory Opening Lecture Jong Yul Kim 01.25.2010.

Homework

Prelab 1 & 2 due on Friday (01.29.2010)

Lab report 1 due by next week

Read RFC 826 by next class