1、根据官方文档手册,在ns2中进行仿真,代码编写步骤:
创建网络模拟器
1、The preamble
set ns [new Simulator] ;#initialise the simulaion
创建跟踪文件,out.tr是数据跟踪文件,用于分析,out.nam是用于可视化的跟踪文件,即在模拟时使用
2、predefine tracing
set f [open out.tr w]
$ns trace-all $f 注意:在输出跟踪文件时,我们使用的是simulator对象
set nf [open out.nam w]
$ns namtrace-all $nf
根据问题的需求,去定义网络的拓扑结构
##
n0
# \
# 5Mb \
# 2ms \
# \
# n2 --------- n3
# / 1.5Mb
# 5Mb / 10ms
# 2ms /
# /
# n1
#
3、 定义节点
set n0 [$ns node]
set n1[$ns node] 在定义节点的时候,我们使用到的是Simulator的对象去定义的节点
set n2 [$ns node]
set n3 [$ns node]
#创建链路
$ns duplex-link $n0 $n2 5Mb 2ms DropTail
$ns duplex-link $n1 $n2 5Mb 2ms DropTail 在定义链路的时候,我们使用到的是Simulator的对象去定义的链路
$ns duplex-link $n2 $n3 1.5Mb 10ms DropTail
在完成以上的设置后,我们就基本上搭出了如图所示的拓扑结构,但此时还没有流量从各个节点发出,因为我们还没有设置;
目标:我们让n0节点使用udp协议,发送cbr流量,n3作为流量的接收端,同时n1使用tcp协议,发送ftp流量,n3作为流量的接收端,代码如下:
4、给n0绑定一个流量代理
set udp0 [new Agent/UDP]
$ns attach-agent $n0 $udp0
set cbr0 [new Application/Traffic/CBR]
$cbr0 attach-agent $udp0
$udp0 set class_ 0
#定义接收节点
set null0 [new Agent/Null]
$ns attach-agent $n3 $null0
#将其链接起来
$ns connect $udp0 $null0
$ns at 1.0 "$cbr0 start" 设定启动时间
#同理,我们定义TCP
# A FTP over TCP/Tahoe from $n1 to $n3, flowid 2
4、设置n1节点
set tcp [new Agent/TCP]
$tcp set class_ 1
$ns attach-agent $n1 $tcp
set sink [new Agent/TCPSink]
$ns attach-agent $n3 $sink
set ftp [new Application/FTP] ; # TCP does not gene
$ftp attach-agent $tcp
$ns connect $tcp $sink
$ns at 1.2 "$ftp start" #设定启动时间
$ns at 1.35 "$ns detach-agent $n1 $tcp ; $ns detach-agent $n3 $sink"
5、在3s后我们结束模拟,并且调用finish过程来将跟踪文件写入进去
$ns at 3.0 "finish"
proc finish {} {
global ns f nf
$ns flush-trace
close $f
close $nf
puts "running nam..."
exec nam out.nam &
exit 0
}
6、最后一步,开始仿真:
$ns run