PeerSim的配置文件 ※
配置文件的功能是定义一些协议类、控制类、初始化类以及一些常数,这个配置文件会被ParsedProperties解析出来,在运行过程中将定义的各种类进行实例化。
配置文件是一个明文文本文件,扩展名为*.txt,基本由一些字符型键值对来表示java中的java.util.Properties。
调用配置文件可用以下方式:
(1)命令行:java peersim.Simulatorconfig_file.txt
(2)在“run configurations”的“programarguments”中填入配置文件的名字
(3)main方法中使用语句:Stringargs[]={“example/config_flooding.txt”}
配置实例解读:
# PEERSIM EXAMPLE 1
02
03
04 simulation.cycles 30
05
06 control.shf Shuffle
07
08 network.size 50000
09
10 protocol.lnkIdleProtocol
11
12 protocol.avgexample.aggregation.AverageFunction //定义一个名为avg的AverageFunction协议组件,用于计算平均值。AverageFunction是聚集协议的求平均数版本。它的参数(linkable)是很重要的,aggregation协议需要与邻居节点交流但是本身没有邻居节点列表。它能应用于任何覆盖网络;定义覆盖网的协议栈应当在这里指定,参数linkable的值是实现了Linkable接口的协议的类名(在这里是IdleProtocol)。
13 protocol.avg.linkablelnk
14
15 init.rnd WireKOut
16 init.rnd.protocol lnk
17 init.rnd.k20
18
19 init.peakexample.aggregation.PeakDistributionInitiali
20 init.peak.value 10000
21 init.peak.protocol avg
22
23 init.linLinearDistribution
24 init.lin.protocol avg
25 init.lin.max 100
26 init.lin.min 1
27
28 # you can change thisto select the peak initializer instead
29
30
31
32 control.avgo.protocolavg
注意:
定义组件的格式:
<protocol|init|control>.string_id[full_path_]classname
定义组件参数的格式:
<protocol|init|control>.string_id.parameter_name
每个组件有一个名字,例如lnk,如果是协议组件,该名字由PeerSim引擎与一个数值型索引号(protocolID)映射起来,这个索引号不会出现在配置文件中,但在模拟过程中访问协议时非常必要。