组播实现失败检测(心跳)

来源:互联网 发布:淘宝玉石拍卖 编辑:程序博客网 时间:2024/06/05 11:50

原理概述     

      在分布式服务中,存在多个节点,而我们不能保证这些节点时刻都能正常运转,所以我们需要实现一种机制来检测新解冻的加入和正在运行节点的崩溃。为了检测节点崩溃,一种常用的方法是心跳(heart beat)。即,我们通过定时地发送消息到其他节点,来告诉其他人自己还活着,而   一段时间没有接收到原本存在的节点的心跳消息,我们就认为这个节点崩溃了。通过这种方式,我们实现了失败检测。

      多播是的优势网络数据包的数量减至最低。组播技术是基于UDP,比TCP更加轻量级。在一下实现里,节点每1秒发送一次心跳信息,若3秒没有收到信息,则认为节点崩溃。

 

 

实现细节

1.组播实现

参考了 http://ajava.org/code/Protocol/16181.html

上面的实现算是比较清楚了,我只是分别将server和client写成了线程,一台主机上既要有发送消息的服务,也要有接收消息的服务,也就是说,所有机器上运行的程序全都是一样的,并没有特定的server节点。

要提一下的是组播IP地址,IP组播地址,或称为主机组地址,由D类IP地址标记。D类IP地址的最高四位为“1110”,起范围从224.0.0.0到239.255.255.255。

接收步骤:

1.设置监听udp的端口,设置并加入组播组。

2.开始接收消息,receive()方法阻塞。

发送步骤:

1.生成要发送的数据

2.设置好要发送的组和端口,发送。

注意在同一个组里,组IP和接收端口都是相同的。

 

 

2.定时器

3秒进行一次扫描,将所有存在本地的节点信息扫描一遍。若在3秒内有收到心跳消息,则仅仅将其标记,若在3秒内没有收到消息,即标记还在,则认为该节点崩溃,从本地中删除该节点。

 

 

3.Map和序列化

在我的实现里,我用一个Map来保存组播消息和心跳标记这样一组键值对。心跳标记为boolean型,组播消息是自定义类MultiMsg。

因为该类要能够在网络中传输,所以要将其类型转换为byte[],这个时候我们要用到序列化(Serializable),将一个类变为可序列化只要加上implements Serializable即可。然后我们通过一些输出转换,就可以将该类转换为byte[],这个比较简单,可以直接看我的实现。

然而一般的序列化的类并不能满足map的操作,要将一个自定义类加入map中,则必须为该类实现equals和hashcode函数,以覆盖map中原有的函数。

 

 

实现代码

1.Send

 

2.Listen

 

3.MultiMsg