分析peersim.chord

http://blog.sina.com.cn/s/blog_78ceb2bb0100ulwd.html

对Chord还不太熟悉,将源码分解之分析之。

peersim. chord的src包中有10个类或接口

(1)ChordInitilizer.java :初始化chord

1)ChordInitializer(String prefix)

2)initialize(Node n)

3)join(Node myNode)

 

(2)ChordMessage.java: 一个接口

 

(3)FinalMessage.java: 实现了 ChordMessage接口

1)FinalMessage(int hopCounter)

2)getHopCounter()

 

(4)ChordProtocol.java: 模拟Chord协议,进行主要的实现过程,处理FinalMessage和LookUpMessage

1)public ChordProtocol (String prefix): 构造方法,用于初始化

2)public void processEvent (Node node, int pid, Object event): event-driven模式的主要方法实现

3)public Object clone():

4)public int[] getLookupMessage():获取查找消息

5)public void stabilize(Node myNode):用于网络的稳定化

6)private void updateSuccessorList() throws Exception:更新后继列表

7)public void notify(Node node) throws Exception:通知前驱节点变更

8)private void updateSuccessor():更新后继节点

9)private boolean idInab(BigInteger id, BigInteger a, BigInteger b):判断ID=id是否在a和b之间。

10)public Node find_successor(BigInteger id):查找后继节点

11)private Node closest_preceding_node(BigInteger id):最近的前驱节点

12)private void printFingers():打印Finger表

 

(5)CreateNw.java: 实现了Control接口,对chord协议初始化,构造chord环的后继表(successor list),初始化Finger Table。主要的方法有:

1)CreateNw(String prefix)

2)execute():CreateNw.java的主方法

3)findId(BigInteger id, int nodeOne, int nodeTwo): 实现折半查找,查找在nodeOne和nodeTwo之间的ID=id的节点。

4)createFingerTable():初始化后继表successor list和FingerTable。

 

(6)LookUpMessage.java: 实现了 ChordMessage接口,负责查询消息

1)LookUpMessage(Node sender, BigInteger targetId)

2)increaseHopCounter()

3)getSender()

4)getTarget()

5)getHopCounter()

 

(7)MessageCounterObserver.java: 实现了Control接口,观察chord网络的消息量和查询成功率

1)MessageCounterObserver(String prefix)

2)execute()

3)meanCalculator(ArrayList list)

4)maxArray(int[] array, int dim)

5)minArray(int[] array, int dim)

 

(8)NodeComparator.java: 比较两个ChordId是否相同

1)NodeComparator(int pid)

2)compare(Object arg0, Object arg1)

 

(9)Parameters.java:参数类,包括协议Id、传输层Id(用于event-driven mode),无任何方法。

 

(10)TrafficGenerator.java: 实现了Control接口,随机产生查询消息,制造网络流量

1)TrafficGenerator(String prefix)

2)execute()


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Eclipse下PeerSim仿真(2010-07-24 14:21:16) 转载▼ 标签: 杂谈 Eclipse下PeerSim仿真 时间: 2010.06.25 23:00:00 标签: PeerSim ,Eclipse http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ******************** Eclipse下PeerSim仿真 ******************** ------------------------ 本文参考: http://peersim.sourceforge.net/ http://blog.sina.com.cn/s/blog_453a60170100hyno.html http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ------------------------ 0、关于PeerSim 主页:http://peersim.sourceforge.net/ 下载:http://sourceforge.net/projects/peersim/ P2P仿真软件,基于JAVA语言。 2004年发布0.0版,最新版本1.0.5发布于2009年9月29日。 1、安装JDK和Eclipse 网上很多资料,此处不多说。 关于JDK版本,没有找到相关说明,下载较新版本即可,如JDK1.6就可以。 Eclipse最新有一个Helios(太阳神)版。 2、示例(PeerSim的"hello world") (1)创建一个java project,命名为PeerSim。 (2)将下载的peersim-1.0.5.zip中的src目录下的文件都拷贝到工程主目录下的src目录下。 (3)将下载的peersim-1.0.5.zip中主目录下的jar文件拷贝到工程主目录下。 (4)添加libraries。Project--Properties--Java Build Path。 Add External JARs,将主目录下的jar文件都添加进去。 (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 解决方法: 在第6步,右键,Run as--Run Configurations,配置Classpath,使得User Entries中只保留djep-1.0.0.jar,peersim-1.0.5.jar,jep-2.3.0.jar,也就是删除peersim-doclet.jar。这个时候再运行,仿真就能正常结束了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值