©2000-2008 Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 1 CT3020: Network Planning and Simulation Week 6b Prof.DrTech. Algirdas Pakštas.

Slides:



Advertisements
Similar presentations
Katz, Stoica F04 EECS 122 Introduction to Computer Networks (Fall 2004) Network simulator 2 (ns-2) Department of Electrical Engineering and Computer Sciences.
Advertisements

Wireless Communication : LAB 3
NS-2 (network simulator) NS by example παρουσίαση Κων/νος Τρούλος.
Introduction to Network Simulator NS-2 Part I
Network Simulation One tool to simulation network protocols for the Internet is the network simulator (NS) The simulation environment needs to be set-
An Introduction to NS-2 * Gayatri Swamynathan CS 276 TA *some slides are from a presentation by Haobo Yu & Nader Salehi, USC/ISI.
NS-2 Shahin Shayandeh December 2004 Session 2. Ns programming  Create the event scheduler  Turn on tracing  Create network  Setup routing  Insert.
Brief Intro to ns2: The most widely used Network Simulator COMP5416 Advanced Network Technologies Based on: Marc Greis's
Ns-2 Tutorial Exercise (1) Multimedia Networking Group, The Department of Computer Science, UVA Jianping Wang Adopted from Nicolas’s slides Jianping Wang,
Ns-2 tutorial Karthik Sadasivam Banuprasad Samudrala CSCI 5931 Network Security Instructor : Dr. T. Andrew Yang.
5-Jul-141 S.Pushpalatha, Associate Professor, PSNACET.
Introduction to NS. Information Main website Documentation, mailing list archive, tutorial Location of Source codes –C++ files.
Dongsoo S. Kim 1.
Winter 2008 Evaluation Tools1 Brief Overview of Networking Evaluation Methods and Tools.
NS TUTORIAL Padma Haldar USC/ISI 09/04/02.
15-744: Computer Networking ns-2 Tutorial Based on slides from John Heidemann, Polly Huang, and Amit Manjhi.
Katz, Stoica F04 EECS 122 Introduction to Computer Networks (Fall 2003) Network simulator 2 (ns-2) Department of Electrical Engineering and Computer Sciences.
CprE 543x – ns-2 Tutorial Zak Abichar, Dept of Electrical and Computer Engineering Iowa State University Ames,
Computer Networks NS. Features F Event driven simulator –developed at UC Berkeley F Network Topologies –nodes (connectivity), links (bandwidth, delay)
1 Ns Tutorial Alhussein A. Abouzeid Elect. Eng. Dept./U. of Washington Parts of this educational presentation use examples available.
Day 3 Outline Multicast example (from Day 2) Wireless Misc. utilities
15-744: Computer Networking L-3 The network simulator ns-2 Slides loosely based on a tutorial by Polly Huang, ETH Zurich.
1 Modified Schedule Day 2 Network AniMator (nam) Examples simple.tcl mcast.tcl Day 3 Wireless (ad-hoc)
Submitters: Stella Pantofel Michael Halperin Igor Berman
1 Network Simulator (NS-2) Tutorial These slides can be downloaded from:
1 2nd European ns-2 Workshop Polly Huang ETH Zurich April 18 & 19, 2001.
Wireless Sensor Network for Tracking the Traffic in INTERNET Network Routers Supervisor: Mark Shifrin Students: Yuriy Kipnis Nir Bar-Or Networked Software.
EECS122 - UCB1 Measurements and Modeling Table of Contents 1. Measurements Measurements 2. Modeling and its Shortcomings Modeling and its Shortcomings.
Ns Simulation of IEEE SC546 Project (Fall 2002) SOO IL KIM JISUN YOON
Network Simulator 2(NS2) Yingyue Xu 8/25/2015. Overview: The Network simulator (NS): discrete event simulator for networks. supports wired, wireless,
Network Simulator (NS2) 1 Tutorial on Network Simulator (NS2) Hemant Kumar Rath Infonet Lab, Dept of Electrical Engineering IIT Bombay, Mumbai
Wireless Networking and Systems CSE 590 ns2 tutorial.
10b_ns: CSci551 SP2002 Friday © 2002 John Heidemann1 NS Tutorial, Class 10 CSci551: Computer Networks SP2002 Friday Section John Heidemann.
Introduction to NS2 -Network Simulator- -Prepared by Changyong Jung.
1 Introduction to Ns-2 Zhibin WU WINLAB, ECE Dept. Rutgers U.
NS2 - Appendix Ming-Feng Yang. 2 2 Outline NS2 Models NS2 Directory Structure Extending NS2 in OTcl Extending NS2 in C++ NS2 related links.
JIA-HUI HUANG INSTITUTE OF COMPUTER SCIENCE AND INFORMATION ENGINEERING NATIONAL TAIPEI UNIVERSITY OF TECHNOLOGY Network Simulator – NS-2 1.
Network Simulator-2 Sandeep singla 1998A2A7540. NS-2 A discrete event simulator Focused on modeling network protocols –Wired, wireless –TCP,UDP,unicast,multicast.
TNK092: Network Simulation - Nätverkssimulering Lecture 3: TCP Vangelis Angelakis.
NetFlow Very useful for traffic analysis Very useful for traffic analysis Standard sampler: Standard sampler: –Cisco Netflow –Juniper Traffic Sampling.
1 Network Simulator Tutorial. 2 Network Simulation * Motivation: Learn fundamentals of evaluating network performance via simulation Overview: fundamentals.
Internet Computing KUT Youn-Hee Han
NS-2 Tutorial. Motivation What’s NS-2 Network simulator –Discrete event simulator It covers multiple layers –Application layer, transport layer, network.
1 Network Simulation and Testing Polly Huang EE NTU
1 ns-2 Tutorial Haobo Yu, Nader Salehi USC/ISI
1 NS Fundamentals. USC INFORMATION SCIENCES INSTITUTE 2 OTcl and C++: The Duality C++ OTcl Pure C++ objects Pure OTcl objects C++/OTcl split objects ns.
Ns-2 Tutorial (1) Multimedia Networking Group, The Department of Computer Science, UVA Jianping Wang Jianping Wang, 2002 cs757 1.
1 Introduction to NS-2 r Tutorial overview of NS m Create basic NS simulation r Walk-through a simple example m Model specification m Execution and trace.
1 ns-2 Tutorial Polly Huang AT&T Labs Research 11 August, 1999.
Lab 2, Network Simulator ns2 Shiv Kalyanaraman Yong Xia (TA) Satish Raghunath Sept 4,
Network Simulator Tutorial Wireless Networks. Acknowledgements Material is taken from the presentations by Jim Kurose, University of Massachusetts, Amherst.
CDA6530: Performance Models of Computers and Networks Chapter 10: Introduction to Network Simulator (NS2) TexPoint fonts used in EMF. Read the TexPoint.
University of Texas at Arlington CSE 5346/4346 High Performance Networks 1 NS-2 Tutorial Choe, Hyun Jung (Stella) Spring 2008 Spring 2008 High Performance.
The Creation of NS2 Simulated Environment ( 1 ) LI Chengbo
TNK092: Network Simulation - Nätverkssimulering Lecture #1: Course basics and a first taste of NS2 Vangelis Angelakis Ph.D.
The New NS2 Emulation Facility Kevin Fall NS2 is the simulation vehicle for the VINT project: –USC/ISI: Deborah Estrin, Mark Handley,
July 7, 2003 Building a Wireless LAN traffic test case in ns2 Radio Science Laboratory Department of Electrical and Computer Engineering The University.
NS-2 Shahin Shayandeh December 2004 Session 1. Ns-2, the Network Simulator  A discrete event simulator Simple model  Focused on modeling network protocols.
Applications and transport agent API 許庭瑋.
Lab 2, Network Simulator ns2
DMET 602: Networks and Media Lab Amr El Mougy Yasmeen EssamAlaa Tarek.
NS-2 Simulator 최 종 훈 Contents  About NS  Installation  Based on Linux  Based on Windows  Architecture  Using NS-2  Example  References.
DMET 602: Networks and Media Lab
(Modified from Polly Huang’s and last year’s original)
Choe, Hyun Jung (Stella)
Introduction to ns-2: “The” Network Simulator
NS2 (and possible directions for mobile routing simulation) Kevin Fall
Introduction to NS Srinath Perur.
Ns By Kulveer Singh.
Karthik Sadasivam Banuprasad Samudrala
Presentation transcript:

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 1 CT3020: Network Planning and Simulation Week 6b Prof.DrTech. Algirdas Pakštas London Metropolitan University Faculty of Computing

2 ns-2 Tutorial FOR SELF-STUDIES (This Lecture complements practical Tutorial 3 in the Labs) Adopted from the ns Workshop 2000 Tutorial by Haobo Yu, Nader Salehi USC/ISI

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 3 Overview Project goals and status What is ns History and status

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 4 Goals VINT: Virtual InterNet Testbed A collaborative simulation platform –Provide common reference  promote sharing –Test suites  increase confidence in results Intended audience –Researchers –Developers –Educators

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 5 What is NS Discrete event simulator Packet-level Link layer and up Wired and wireless

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 6 History and Status Columbia NEST UCB REAL ns-1 ns-2 –100K lines of C++ –70K lines of OTcl –30K lines of test suite –20K lines of documentation

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 7 Platforms Most UNIX and UNIX-like systems FreeBSD or *BSD Linux Sun Solaris  HP, SGI Window 95/98/NT –Some work, some does not (Emulation only for FreeBSD for now)

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 8 Related Research intserv/diffserv Multicast –Routing –Reliable multicast Transport –TCP –Congestion control Application –Web caching –Multimedia

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 9 Resources Tcl (Tool Command Language) – OTcl (MIT Object Tcl) –~otcl/doc/tutorial.html (in distribution) ns manual –Included in distribution: ~ns/doc –

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 10 Cautions People tried best to validate ns with regression tests However: abstraction of the real world is necessary for a simulator  You must justify the usage of this simulator based on your research goals

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 11 History and Status Users from approximately –600 institutes –50 countries Releases –Periodic releases (currently 2.1b7, Dec 2000) –Nightly snapshots (probably compiles and works, but “unstable”) –Available from: USC/ISI, UC Berkeley, UK mirror

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 12 Functionality of ns Wired world –Point-to-point link, LAN –Unicast/multicast routing –Transport –Application layer Wireless –Mobile IP –Ad hoc routing Tracing, visualization, various utilities

13 Part I: Fundamentals

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 14 ns Primer – Wired World Basic ns –Architecture –Basic Tcl, OTcl –Elements of ns Visualization

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 15 ns Architecture Object-oriented (C++, OTcl) Scalability + Extensibility –Control/”data” separation –Split C++/OTcl object Modular approach –Fine-grained object composition

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 16 Object-Oriented +Reusability +Maintenance –Performance (speed and memory) –Careful planning of modularity

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 17 C++ and OTcl Separation C++ for “data” –Per packet action OTcl for control –Periodic or triggered action +Compromise between composibility and speed –Learning and debugging

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 18 OTcl and C++: The Duality C++ OTcl Pure C++ objects Pure OTcl objects C++/OTcl split objects ns

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 19 Extending Tcl Interpreter OTcl: object-oriented Tcl TclCL: C++ and OTcl linkage Discrete event scheduler Data network components –Link layer and up –Emulation support Tcl OTclTclCL ns-2 Event Scheduler Network Components C/C++

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 20 Hello World - Interactive Mode swallow 71% ns % set ns [new Simulator] _o3 % $ns at 1 “puts \“Hello World!\”” 1 % $ns at 1.5 “exit” 2 % $ns run Hello World! swallow 72%

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 21 Hello World - Batch Mode simple.tcl set ns [new Simulator] $ns at 1 “puts \“Hello World!\”” $ns at 1.5 “exit” $ns run swallow 74% ns simple.tcl Hello World! swallow 75%

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 22 Basic tcl set a 43 set b 27 proc test { a b } { set c [expr $a + $b] set d [expr [expr $a - $b] * $c] for {set k 0} {$k < 10} {incr k} { if {$k < 5} { puts “k < 5, pow = [expr pow($d, $k)]” } else { puts “k >= 5, mod = [expr $d % $k]” } } } test 43 27

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 23 Basic OTcl Class Mom Mom instproc greet {} { $self instvar age_ puts “$age_ years old mom: How are you doing?” } Class Kid -superclass Mom Kid instproc greet {} { $self instvar age_ puts “$age_ years old kid: What’s up, dude?” } set mom [new Mom] $mom set age_ 45 set kid [new Kid] $kid set age_ 15 $mom greet $kid greet

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 24 Elements of ns-2 Create the event scheduler [Turn on tracing] Create network Setup routing Insert errors Create transport connection Create traffic Transmit application-level data

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 25 Creating Event Scheduler Create event scheduler –set ns [new Simulator] Schedule events –$ns at – : any legitimate ns/tcl commands Start scheduler –$ns run

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 26 Tracing Trace packets on all links –$ns trace-all [open test.out w] Format: -- EXAMPLES: cbr cbr r cbr Trace packets on all links in nam-1 format –$ns namtrace-all [open test.nam w] Must appear immediately after creating scheduler

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 27 Tracing Turn on tracing on specific links –$ns trace-queue $n0 $n1 –$ns namtrace-queue $n0 $n1

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 28 Creating Network Nodes –set n0 [$ns node] –set n1 [$ns node] Links and queuing –$ns duplex-link $n0 $n1 – : DropTail, RED, CBQ, FQ, SFQ, DRR

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 29 Creating Network: LAN LAN –$ns make-lan – : LL – : Queue/DropTail, – : MAC/802_3 – : Channel

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 30 Inserting Errors Creating Error Module –set loss_module [new ErrorModel] –$loss_module set rate_ 0.01 –$loss_module unit pkt –$loss_module ranvar [new RandomVariable/Uniform] –$loss_module drop-target [new Agent/Null] Inserting Error Module –$ns lossmodel $loss_module $n0 $n1

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 31 Network Dynamics Link failures –Hooks in routing module to reflect routing changes Four models $ns rtmodel Trace $n0 $n1 $ns rtmodel Exponential { } $n0 $n1 $ns rtmodel Deterministic { } $n0 $n1 $ns rtmodel-at up|down $n0 $n1 Parameter list [ ]

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 32 Setup Routing Unicast –$ns rtproto – : Static, Session, DV, cost, multi-path Multicast –$ns multicast (right after [new Simulator]) –$ns mrtproto – : CtrMcast, DM, ST, BST

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 33 Creating Connection: UDP UDP –set udp [new Agent/UDP] –set null [new Agent/Null] –$ns attach-agent $n0 $udp –$ns attach-agent $n1 $null –$ns connect $udp $null

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 34 Creating Traffic: On Top of UDP CBR –set src [new Application/Traffic/CBR] Exponential or Pareto on-off –set src [new Application/Traffic/Exponential] –set src [new Application/Traffic/Pareto]

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 35 Creating Connection: TCP TCP –set tcp [new Agent/TCP] –set tcpsink [new Agent/TCPSink] –$ns attach-agent $n0 $tcp –$ns attach-agent $n1 $tcpsink –$ns connect $tcp $tcpsink

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 36 Creating Traffic: On Top of TCP FTP –set ftp [new Application/FTP] –$ftp attach-agent $tcp Telnet –set telnet [new Application/Telnet] –$telnet attach-agent $tcp

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 37 Creating Traffic: Trace Driven Trace driven –set tfile [new Tracefile] –$tfile filename –set src [new Application/Traffic/Trace] –$src attach-tracefile $tfile : –Binary format (native!) –inter-packet time (msec) and packet size (byte)

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 38 Application-Level Simulation Features –Build on top of existing transport protocol –Transmit user data, e.g., HTTP header Two different solutions –TCP: Application/TcpApp –UDP: Agent/Message

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 39 Application/TcpApp Abstraction: TCP as a FIFO pipe Before sending: S notifies about R data size After receiving: R gets data (arbitrary string) from S SR } Out-of- band Expect N bytes Get first N bytes of data pkt (empty) ack

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 40 Application/TcpApp Step 1: FullTcp connection set tcp1 [new Agent/TCP/FullTcp] set tcp2 [new Agent/TCP/FullTcp] $ns attach-agent $n1 $tcp1 $ns attach-agent $n2 $tcp2 $ns connect $tcp1 $tcp2 $tcp2 listen

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 41 Application/TcpApp Step 2: reliable, in-order user data transfer set app1 [new Application/TcpApp $tcp1] set app2 [new Application/TcpApp $tcp2] $app1 connect $app2 # : will be executed when received at the receiver TcpApp $ns at 1.0 “$app1 send \” \””

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 42 Agent/Message A UDP agent (without UDP header) Up to 64 bytes user message Good for fast prototyping a simple idea Usage requires extending ns functionality SR pkt: 64 bytes of arbitrary string Receiver-side processing

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 43 Summary: Generic Script Structure set ns [new Simulator] # [Turn on tracing] # Create topology # Setup packet loss, link dynamics # Create routing agents # Create: # - multicast groups # - protocol agents # - application and/or setup traffic sources # Post-processing procs # Start simulation

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 44 Other Examples Available in the Lab this afternoon Web traffic model Multicast routing RED Queueing

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 45 Visualization Tools nam-1 (Network AniMator Version 1) –Packet-level animation –Well supported by ns xgraph –Conversion from ns trace to xgraph format

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 46 nam Basic visualization –Topology layout –Animation control –Synchronous replay Fine-tune layout TCP/SRM visualization Editor: generate ns simulation scripts

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 47 ns  nam Interface Color Node manipulation Link manipulation Topology layout Protocol state Misc

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 48 nam Interface: Color Color mapping $ns color 40 red $ns color 41 blue $ns color 42 chocolate Color  flow id association $tcp0 set fid_ 40;# red packets $tcp1 set fid_ 41;# blue packets

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 49 nam Interface: Nodes Color $node color red Shape (can’t be changed after sim starts) $node shape box;# circle, box, hexagon Marks (concentric “shapes”) $ns at 1.0 “$n0 add-mark m0 blue box” $ns at 2.0 “$n0 delete-mark m0” Label (single string) $ns at 1.1 “$n0 label \”web cache 0\””

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 50 nam Interfaces: Links Color $ns duplex-link-op $n0 $n1 color "green" Label $ns duplex-link-op $n0 $n1 label "abced" Dynamics (automatically handled) $ns rtmodel Deterministic { } $n0 $n1 Asymmetric links not allowed

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 51 nam Interface: Topo Layout “Manual” layout: specify everything $ns duplex-link-op $n(0) $n(1) orient right $ns duplex-link-op $n(1) $n(2) orient right $ns duplex-link-op $n(2) $n(3) orient right $ns duplex-link-op $n(3) $n(4) orient 60deg If anything missing  automatic layout

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 52 nam Interface: Protocol State Monitor values of agent variables $ns add-agent-trace $srm0 srm_agent0 $ns monitor-agent-trace $srm0 $srm0 tracevar C1_ $srm0 tracevar C2_ # … … $ns delete-agent-trace $tcp1

© Algirdas Pakstas CS3026N Network Analysis, Design and Simulation 53 nam Interface: Misc Annotation –Add textual explanation to your simulation $ns at 3.5 "$ns trace-annotate \“packet drop\"“ Set animation rate $ns at 0.0 "$ns set-animation-rate 0.1ms"