peersim如何安装使用

转载:http://blog.sina.com.cn/s/blog_54eb9d9e0101asqy.html

不同于周期驱动,事件驱动的引擎,通过事件来安排协议等执行的顺序。事件或者消息发送到不同的协议后,相应的协议能够处理这些消息并作出正确的反应。由于它依赖于信息,事件驱动的模拟器能够模拟运输层,因此给该模拟器添加了更加实用的功能。它基于peesim.edsim包的EDSimulator类。

    PeerSim作为一种P2P仿真平台,包含方法和接口、配置文件、主函数三大部分:   

    PeerSim里面的程序包定义了许多方法和接口,对等网络仿真实验中,用到的方法要么继承包里面的某些方法,要么实现包里面的某些接口,要么用到类包的某些变量,从而在PeerSim平台上构建出复杂的、功能全面的P2P网络系统,从而准确地仿真P2P网络。

    配置文件是一种简单的ASCII码文件,它的功能是定义了一些运行过程中的初始化类、协议类、控制类,以及一些常数[12]。这个配置文件会被ParsedProperties解析出来,在运行过程中将定义的各种类进行实例化。

    simulator.java中的主函数main()为整个模拟器的入口。main()函数依次执行载入配置文件、初始化输出函数、载入实验次数、判断引擎类型CD/ED、执行CDSimulator.nextExperiment( )方法五个操作。


1 在命令行中运行peersim

       a.从官方网站http://sourceforge.net/projects/peersim/?source=dlp上下载最新的peersim-1.0.5.zip,解压到你所需的目录中,本人使用的目录是F:\sim\

       b.运行cmd,进入到F:\sim

       c.运行cd peersim-1.0.5,进入到主目录下

       d.在主目录中有个README文件,用写字板打开,可以看见里面运行模拟的方法,其中有一句运行命令如下:

java -cp "peersim-1.0.5.jar:jep-2.3.0.jar:djep-1.0.0.jar" peersim.Simulator example/config-example1.txt。将其中的“:”改成“;”(windows下),不然运行会报错。NoDefClassFound。

 

-cp 可选项是classpath的简写,既编译时需要后面的jar文件。

peersim.Simulator是PeerSim运行的主函数,所有的协议模拟都需要从它开始。

Example/config-example1.txt 指定了你要运行的协议的配置文件。每个需要模拟的协议提供了配置文件。

输出结果:当运行以上语句后就可以查看输出结果了。

 

Chord等协议的模拟:

a.       需要从官方网站http://sourceforge.net/projects/chord/?source=dlp上下载对应的Chord和Pastry协议的压缩包

b.       解压

c.       将chord源码生成.jar,命名为chord.jar,放在chord目录下

d.       从peersim-1.0.5.jar中将peersim-1.0.5、jar:jep-2.3.0.jar、djep-1.0.0.jar三个包拷到chord目录下

e.       运行java -cp "peersim-1.0.5.jar:jep-2.3.0.jar:djep-1.0.0.jar;chord.jar" peersim.Simulator example.cfg 即可看到模拟结果

第c步需要打包的原因:

Chord目录下提供的readMe-chord.pdf是不需要对chord源码打包,但是这样做的话是会报NoDefClassFound错误的,因为Chord源码本没有编译过,没有.class文件。

Pastry类似。

 

2 将工程导入到Eclipse中

       a.新建一个工程,可以命名为PeerSim

       b.从将peersim-1.0.5\src\目录下将所有的源码拷到PeerSim中

       c.将peersim-1.0.5目录下所有的jar包拷到PeerSim工程下

       d.通过Build Path将所需的jar关联上。

 

       运行:

       主函数在peersim包下,直接运行里面的Simulator类,此时会报如下的错误:

Simulator: loading configuration

Simulator: unable to determine simulation engine type

这是因为没有添加配置文件的原因。

方法:

Run as->Run Configurations:

在main中选择刚才运行的Simulator

在arguments的program arguments中输入config-example1.txt,然后点击apply  run即可。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验经验: 1、安装JDK和Eclipse 网上很多资料,此处不多说。 关于JDK版本,没有找到相关说明,下载较新版本即可,如JDK1.6就可以。 Eclipse最新有一个Helios(太阳神)版。 2、示例(PeerSim的"hello world") (1)创建一个java project,命名为PeerSim。 (2)将下载的peersim-1.0.5.zip中的src目录下的文件(注意:将scr目录下的peersim和example这两个文件拷贝到scr目录下,而不是将它们的上级文件scr拷贝到scr目录下那样就会出现错误,因为那样两个scr的名字重了,肯定会出错,而是将peersim的scr的下级文件拷贝到java文件的scr文件下)都拷贝到工程主目录下的src目录下。 (3)将下载的peersim-1.0.5.zip中主目录下的jar文件拷贝到工程主目录下。 (4)添加libraries。Project--Properties--Java Build Path--Libraries-- Add External JARs(add jars),将主目录下的jar文件(4个,djep-1.0.0.jar, jep2.3.0.jar, peersim1.0.5.jar,peersimdclet.jar)都添加进去。Libraries中才是程序运行所需要的配置文件,所以先要放在主目录下,然后再将它放在properties的Libraries中,这样程序才能运行。 (5)编写仿真配置文件。这里使用peersim-1.0.5的example目录下的config-example1.txt。将这个txt文件拷贝到工程主目录下。 (6)运行,在Eclipse的Package Explore栏找到这个txt文件,右键,Run as--Run Configurations。 Main:在Name中输入Application名称,比如PeerSimApp;在main class中输入peersim.Simulator,或者搜索之。 Arguments:在Program arguments中输入config-example1.txt,也就是配置文件。配置一下配置文件的名字。要不程序找不到。 (7)第6步完成之后,点击运行,会出现错误: peersim.config.IllegalParameterException: Parameter "protocol.lnk": The class peersim.core.IdleProtocol appears more than once in the classpath; please check your classpath to avoid duplications. At peersim.config.ConfigContainer.getClazz:582 解决方法: Project--Properties--Java Build Path--Libraries使得Libraries(因为Libraries中的配置文件既不能多也不能少)中只保留djep-1.0.0.jar,,jep-2.3.0.jar,也就是删除peersim-doclet.jar,peersim-1.0.5.jar(在Libraries中删除而不是在主目录中删除,因为运行所需的配置都是在Libraries中完成,主目录都保留就可以了,与程序运行的配置无关)。这个时候再运行,仿真就能正常结束了。
Peersim是一个用于模拟P2P(对等网络)的开源框架。它提供了一个灵活、可扩展的平台,用于构建和运行对等网络仿真实例。借助Peersim,研究人员可以方便地调查不同算法和策略在P2P网络中的行为和性能。 以一个简单的P2P文件共享系统为例,我们可以使用Peersim进行仿真实验。在这个实例中,我们假设有一个包含多个节点的P2P网络,每个节点具有上传和下载文件的能力。我们可以设置每个节点的带宽和存储空间。 首先,我们需要定义节点的行为和通信协议。节点可以选择是一个文件的提供者(有该文件的副本)还是一个文件的请求者。当一个节点成为一个文件的请求者时,它可以向其他节点发出请求,并从上传者那里下载文件。节点之间的通信可以使用经典的请求-响应模式。 接下来,我们可以设置节点和网络的参数。例如,我们可以设置节点的初始文件和索引,以及它们之间的邻居关系。我们还可以设置节点的带宽和存储空间大小,以模拟实际情况中的资源限制。 然后,我们可以定义仿真实验的评价指标。例如,我们可以测量文件传递的延迟、节点之间的负载平衡、系统的容错性等。这些指标可以帮助我们评估不同的算法和策略在P2P文件共享系统中的性能。 最后,我们可以使用Peersim运行仿真实验并收集数据。Peersim提供了一个简单易用的仿真引擎,可以在真实时间或步骤数的基础上运行仿真。通过分析收集到的数据,我们可以评估不同算法和策略的优劣,并提出改进和优化的建议。 总而言之,Peersim是一个强大的工具,可用于实现P2P网络的仿真实例。通过使用Peersim进行仿真实验,我们可以更好地理解和改进P2P网络的行为和性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值