本申请属于物联网技术领域,尤其涉及一种通信方法及通信装置。
背景技术:
物联网技术是目前迅速发展的互联网技术之一。目前运用物联网技术在智能家居、工业生产、楼宇控制、环境监测、智慧城市等领域运用最广。而在这些领域的物联网网络不仅要进行数据的传输,而且要进行数据采集和融合、任务的协同控制。低成本、低功耗、多功能逐渐成为这些领域必不可少的特性。目前在这些领域运用最多的通信协议包括wifi、蓝牙、紫蜂(zigbee)。wifi设备通信时占用的频点较多、功耗大,使得大多数的wifi设备需要常规充电;蓝牙技术传输距离短,只适合近距离的数据通信,无法满足大多数物联网设备的通信需求;zigbee技术在非信标模式下工作时,只有终端子节点能够进入休眠模式,协调器和路由节点必须处于活跃状态来接收处理来自终端子节点的数据信息,大大的增加了网络的整体功耗。
此外,物联网设备大多要面对复杂多变的通信环境,在通过路由节点来通信的过程中,随时可能因位置变动、天气变化或出现障碍物等而影响实际信号的发送和接收效果,一旦此类情况发生,往往会使一条原先可用的路由通信路径变得不再可靠(甚至不可用),进而需要一个较为耗时的通信路径建立过程来恢复通信。为此,现有技术亟需一种能够在变化的环境中保证通信信号收发效果的通信手段。
技术实现要素:
本申请实施例提供一种可靠实用的自组网路由方案。
在一种可能的实施方式中,提供了一种通信方法,所述方法包括:
以第一预设功率,发送与通信路径建立相关联的消息;
响应于通信路径的建立,以第二预设功率发送通信数据;
其中,所述第一预设功率小于所述第二预设功率。
可选地,所述方法还包括:
获取至少一广播消息,所述广播消息用于建立源节点与目的节点之间的通信路径,且所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
所述发送与通信路径建立相关联的消息包括:
至少响应于所述跳数计数不超过一预设值,将所述跳数计数增加1,并在第一预定延迟后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述预设值为零。
可选地,所述广播消息为一源节点通过广播的方式向一目的节点发送的,且所述路由信息还包括:源节点地址、目的节点地址、以及上一跳节点地址;
所述方法还包括:
存储与所述广播消息关联的所述路由信息;
所述通过广播的方式转发所述广播消息还包括:
将所述上一跳节点地址修改为本地节点地址后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述路由信息中还包括:用于标识所述广播消息的第一消息标识;
所述方法还包括:
根据所述第一消息标识,判断是否转发过所述广播消息;
响应于转发过所述广播消息,丢弃所述广播消息。
可选地,所述方法还包括:
响应于一广播消息对应的目的节点地址与本地节点地址相同,通过广播的方式向所述广播消息对应的源节点发送应答消息;
其中,所述应答消息中包括对应的广播消息的路由信息。
可选地,所述方法还包括:
获取至少一应答消息,所述应答消息为一目的节点通过广播的方式发出的,且所述应答消息中包括对应的广播消息的路由信息;
根据与所述应答消息对应的路由信息,转发所述应答消息。
可选地,所述转发所述应答消息包括:
至少响应于所述应答消息中的跳数计数不超过一预设值,将所述应答消息中的跳数计数增加1,在第二预定延迟后,转发所述应答消息。
可选地,所述转发所述应答消息进一步包括:
根据所述应答消息对应的路由信息中的源节点地址,确定所述对应的广播消息的上一跳节点地址;
根据所述上一跳节点地址,向所述上一跳节点转发所述应答消息。
可选地,所述方法还包括:
响应于所述应答消息中包括的路由信息对应的源节点地址为本地节点地址,根据所述应答消息对应的上一跳节点地址,以所述第一预设功率,发送到目的节点的确认消息;
其中,所述确认消息用于确定与所述上一跳节点地址关联的路径为所述源节点与所述目的节点之间的通信路径。
可选地,所述应答消息中还包括:所述对应的广播消息的总跳数;
所述发送到目的节点的确认消息进一步包括:
至少根据所述总跳数,确定所述上一跳节点地址。
可选地,所述发送到目的节点的确认消息进一步包括:
至少根据获取所述至少一应答消息的时间,确定所述上一跳节点地址。
在本申请另一种可选的实施方式中,还提供一种消息转发装置,包括:
第一功率发送单元,用于以第一预设功率,发送与通信路径建立相关联的消息;
第二功率发送单元,用于响应于通信路径的建立,以第二预设功率发送通信数据;
其中,所述第一预设功率小于所述第二预设功率。
可选地,所述装置还包括:
广播获取单元,用于获取至少一广播消息,所述广播消息用于建立源节点与目的节点之间的通信路径,且所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
所述第一功率发送单元包括:
广播转发模块,用于至少响应于所述跳数计数不超过一预设值,将所述跳数计数增加1,并在第一预定延迟后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述预设值为零。
可选地,所述广播消息为一源节点通过广播的方式向一目的节点发送的,且所述路由信息还包括:源节点地址、目的节点地址、以及上一跳节点地址;
所述装置还包括:
存储单元,用于存储与所述广播消息关联的所述路由信息;
所述广播转发模块包括:
路由信息更新模块,用于将所述上一跳节点地址修改为本地节点地址后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述路由信息中还包括:用于标识所述广播消息的第一消息标识;
所述装置还包括:
消息识别单元,用于根据所述第一消息标识,判断是否转发过所述广播消息;
丢弃单元,用于响应于转发过所述广播消息,丢弃所述广播消息。
可选地,所述装置还包括:
应答单元,用于响应于一广播消息对应的目的节点地址与本地节点地址相同,通过广播的方式向所述广播消息对应的源节点发送应答消息;
其中,所述应答消息中包括对应的广播消息的路由信息。
可选地,所述装置还包括:
应答获取单元,获取至少一应答消息,所述应答消息为一目的节点通过广播的方式发送的,且所述应答消息中包括对应的广播消息的路由信息;
应答转发单元,用于根据与所述应答消息对应的路由信息,转发所述应答消息。
可选地,所述应答转发单元包括:
应答延迟模块,用于至少响应于所述应答消息中的跳数计数不超过一预设值,将所述应答消息中的跳数计数增加1,在第二预定延迟后,转发所述应答消息。
可选地,所述应答转发单元包括:
上一跳确定模块,用于根据所述应答消息对应的路由信息中的源节点地址,确定所述对应的广播消息的上一跳节点地址;
上一跳转发模块,用于根据所述上一跳节点地址,向所述上一跳节点转发所述应答消息。
可选地,所述装置还包括:
应答确认单元,用于响应于所述应答消息中包括的路由信息对应的源节点地址为本地节点地址,根据所述应答消息对应的上一跳节点地址,以所述第一预设功率,发送到目的节点的确认消息;
其中,所述确认消息用于确定与所述上一跳节点地址关联的路径为所述源节点与所述目的节点之间的通信路径。
可选地,所述应答消息中还包括:所述对应的广播消息的总跳数;
所述应答确认单元包括:
总跳数选择模块,至少根据所述总跳数,确定所述上一跳节点地址。
可选地,所述应答确认单元包括:
应答时间选择模块,用于至少根据获取所述至少一应答消息的时间,确定所述上一跳节点地址。
在本申请另一种可选的实施方式中,还提供一种通信设备,包括:
存储器以及一个或多个处理器;
其中,所述存储器与所述一个或多个处理器通信连接,所述存储器中存储有可被所述一个或多个处理器执行的指令,所述指令被所述一个或多个处理器执行,以使所述一个或多个处理器能够实现如上所述的方法。
本申请实施例提供的方法及装置在路径建立过程中,通过使用小于通信过程的发射功率来发送通信路径建立消息,使得通信过程中的有效通信距离大于原先规划的路由距离,以使建立的通信路径可适应更为复杂的通信环境,在通信环境发生一定变化的情况下也可保证信号的收发,而不用频繁进行路由规划,保证了通信路径的可靠性和实用性。本申请实施例提供的方案有效解决了发射功率不对等的问题,可避免由于环境变化造成的未来的通讯不稳定。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例。
图1为依照本申请实施例的消息转发方法的一种示例的流程图;
图2为依照本申请实施例的广播方法的一种示例的流程图;
图3为依照本申请实施例的消息转发方法的又一种示例的流程图;
图4为依照本申请实施例的广播方法的又一种示例的流程图;
图5为依照本申请实施例的广播方法建立通信路径的过程示意图;
图6-9为依照本申请实施例的通信节点的四种示例的结构框图。
具体实施方式
为使得本申请的发明目的、特征、优点能够更加的明显和易懂,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而非全部实施例。基于本申请中的实施例,本领域技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本领域技术人员可以理解,本申请中的“第一”、“第二”等术语仅用于区别不同设备、模块或参数等,既不代表任何特定技术含义,也不表示它们之间的必然逻辑顺序。
本申请各实施例的技术方案适用于包括多个通信节点的任意无线传感网络,在下文的描述中,广播消息以为了建立源节点和目的节点之间的通信路径而发起的路径建立消息为例,但本申请不限于此。依照本申请各实施例的技术方案,无线传感网络中的各通信节点能够采用一种无中心、自组织、对等式、多跳和按需路由的通信机制来进行组网,使得网络部署简单快速。
请参照图1,为依照本申请实施例的消息转发方法的一种示例的流程图,该方法可由网络中的任一通信节点执行。如1所示的,本实施例的方法可包括步骤:
s120.获取至少一广播消息,所述广播消息为一源节点通过广播的方式向一目的节点发送的,且所述广播消息中包括与所述广播消息关联的路由信息。
以广播消息为路径建立消息为例,在本申请实施例的方法中,任一通信由节点期望与另一通信节点通信时(在本申请的描述中,发起通信/路径建立的通信节点称为源节点,通信/路径的终端通信节点称为目的节点),若网络中已存在二者之间的可用通信路径,则源节点可根据自身存储的到达该目的节点时经过的下一跳节点的物理地址进行数据的点对点发送,由下一跳节点根据存储的再下一跳节点的物理地址继续转发,直至数据发送到该目的节点。否则,源节点将通过广播的方式发送广播消息,即路径建立消息。路径建立消息中可包括与其关联的路由信息,包括但不限于:源节点地址、目的节点地址、以及跳数计数,跳数计数即广播消息在网络中被转发的次数,源节点广播的路径建立消息的初始跳数计数记为零。在源节点的信号范围内的通信节点,都可能获取到该路径建立消息。
s140.响应于所述跳数计数不超过一预设值,在第一预定延迟后,通过广播的方式转发所述路径建立消息。
在一种可能的实现方式中,该预设值为零,获取到任意路径建立消息后,若该消息当前的跳数计数为0,表示本地节点(接收到该路径建立消息的通信节点)为该路径建立消息的第一跳节点,依照本申请实施例的方法,将所述跳数计数增加1,并在一定的延迟时间之后再对该路径建立消息进行再次广播,此时,跳数计数即为1。此后接收到该路径建立消息的通信节点可根据相应的机制继续广播(不进行延迟)或丢弃该路径建立消息,使得路径建立消息在网络中传递像神经网络中传导一样,直至该路径建立消息通过网络中的任意路径到达对应的目的节点。
其中,第一预定延迟可为预先设置的延迟时间,用于避免无线电碰撞,从而避免因此造成的消息无法在网络中发送。对于任意通信节点,这样的时间可设置为一随机数。
综上,本实施例的方法在路径建立过程中,通过仅有限的通信节点对路径建立消息进行延迟广播,能够使得后续所有的转发都会对应这个延迟,避免无线电碰撞的同时路径建立速度更快。
此外,为了建立源节点和目的节点之间的通信路径,通信节点还应对接收到的路径建立信息的路由信息进行记录,以与周围的通信节点建立有效的联系,有助于通信路径的构建,以及不需要负责路径存储、管理和维护的专门节点。所述路由信息还包括:上一跳节点地址,对于第一跳节点来说,该上一跳节点地址即为源节点地址。具体地,本实施例的方法还包括:
s130.存储与所述路径建立消息关联的所述路由信息,包括上一跳节点地址、源节点地址、目的节点地址。
此外,在步骤s140中修改要发送的路由建立消息的路由信息:将所述上一跳节点地址修改为本地节点地址后,再通过广播的方式转发所述路径建立消息。
为了防止广播消息帧在网络中传递形成环路,所述路由信息中还可包括:用于标识所述广播消息的第一消息标识。这样,每个接收到广播消息的通信节点均会根据该第一消息标识判断是否已经对同样的消息进行了转发,并在是时,丢弃该消息。在这样的实现方式中,所述方法还包括:
s112.根据所述第一消息标识,判断是否转发过所述广播消息。
s114.响应于转发过所述特别消息,丢弃所述广播消息。
此外,如上所述的,本申请实施例的方法可由网络中的任意通信节点执行,执行本实施例的方法通信节点在参与一源节点到目的节点之间的通信路径的构建的同时,可能其本身还是另一通信的目的节点。因此,接收到任意广播消息时,通信节点将依照本申请实施例的方法,根据该消息的路由信息进行判断,并在目的节点地址即为本身的地址时,通过广播的方式发送对该广播消息的应答消息,该应答消息可能通过多条路径传回源节点,源节点可据此寻找到与源节点之间的最终通信路径,同时排除无线收发性能不对等造成的消息无法回传。在这样的实现方式中,本申请实施例的方法还包括:
s150.响应于一广播消息对应的目的节点地址与本地节点地址相同,通过广播的方式向所述广播消息对应的源节点发送应答消息。其中,所述应答消息中包括对应的广播消息的路由信息,还包括:用于标识所述应答消息的第二消息标识。
需要说明的是,对于任一通信节点,其可能接收到来自多条路径的同一广播消息,因此,也要根据第一消息标识丢弃重复接收到的广播消息。此外,为了避免应答消息与目的节点信号范围内还未停止的广播消息的信号冲突,在步骤s150中对应答消息的广播也可延迟一定的时间。具体地:
在步骤s150中,可在第二预定延迟后,通过广播的方式转发所述应答消息。第二预定延迟也可为任意预先设置的延迟时间,例如,根据历史传播信息,将该第二预定延迟设置为一跳传播所需要的时间。
实施本申请实施例的方法的通信节点可能处于任一目的节点信号范围内,此时,依照本申请实施例的方法,将接收到该目的节点广播的应答消息。在本申请实施例的方法中,接收到这样的应答消息的通信节点将通过点对点的单播方式转发该应答消息。具体地,本申请实施例的方法还可包括:
s160.获取至少一应答消息,所述应答消息为一目的节点通过广播的方式发送的,且所述应答消息中包括对应的广播消息的路由信息,还包括:用于标识所述应答消息的第二消息标识。
s180.根据与所述应答消息对应的路由信息,转发所述应答消息。
对于已经建立和/或参与过与应答消息对应的路由信息中指示的源节点之间的通信的通信节点,可以复用之前的路径,直接向该源节点转发所述应答消息。这样做能够降低每个通信节点需要存储的路由信息量。如果之前已存储过路由信息,则不会浪费新的存储空间。
而对于未曾存储过与对应的源节点之间的通信路径的通信节点,可根据与广播消息关联的记录,根据对应的上一跳节点地址,向上一跳节点转发该路径建立应答消息。具体地:
步骤s180可进一步包括:
s182.根据所述应答消息对应的路由信息中的源节点地址,确定对应的广播消息的上一跳节点地址;
s184.根据所述上一跳节点地址,向所述上一跳节点转发所述应答消息。
类似地,对于应答消息,为了防止形成环路,所述应答消息中也可包括:用于标识所述应答消息的第二消息标识。这样,每个接收到应答消息的通信节点可根据该第二消息标识判断是否已经对同样的消息进行了转发,并在是时,丢弃该消息。在这样的实现方式中,所述方法还包括:
s172.根据所述第二消息标识,判断是否转发过所述应答消息;
s174.响应于转发过所述应答消息,丢弃所述应答消息。
类似地,实施本申请实施例的方法的通信节点在构建一源节点与一目的节点之间的通信路径的同时,其本身也可能为另一广播消息对应的源节点,在接收到任一应答消息之后,需要根据对应的源节点地址,实施判断。并且,在本申请实施例的方法中,由于应答消息是从目的节点广播出来的,因此,应答消息可能是通过多条路径到达源节点的,源节点在选择出最终通信路径之后,沿该路径向目的节点发送确认消息,以完成通信路径的建立。相应地,本申请实施例的方法还可包括:
s190.响应于所述应答消息中包括的路由信息对应的源节点地址为本地节点地址,根据所述应答消息对应的上一跳节点地址,发送到目的节点的确认消息。所述确认消息用于确定与所述上一跳节点地址关联的路径为所述源节点与所述目的节点之间的最终通信路径。
在申请本实施例的方法中,可根据任意合适的原则确定源节点与目的节点之间的最终通信路径。在一种可能的实现方式中,所述路径建立应答消息中还可包括:所述对应的路径建立消息的总跳数。在这样的实现方式中,步骤s190中可至少根据所述至少一应答消息的总跳数,确定所述上一跳节点地址。例如,可确定总跳数最少的应答消息对应的路径为最终通信路径。在另一种可能的实现方式中,可根据应答消息到达源节点的时间确定最终通信路径,例如,选择最早到达源节点的应答消息对应的路径作为最终通信路径。在这样的实现方式中,步骤s190中可至少根据获取所述至少一应答消息的时间,确定所述上一跳节点地址。
此外,在本申请实施例的方法中,为了防止未来由于天气等环境因素造成的无线性能差异,导致通信不稳定,所有通信节点对路径建立过程中的消息发送均使用不超过一预设功率的发射功率进行发送,包括上述广播消息、应答消息、以及确认消息,且广播消息、应答消息、以及确认消息的发射功率可相同也可不同。该预设功率可例如为用户设定的发射功率的80%,而在通信路径建立之后,通信数据的传输可使用用户设定的发射功率的100%。
综上,本申请实施例的方法采用无中心、自组织、对等式、多跳和按需路由的方式建立源节点和目的节点之间的通信路径,能够不需要路径存储、管理和维护的节点,每个通信节点仅仅保存到达源节点和到达目的节点所经过的相邻节点信息,最终构建一个源节点和目的节点的双向传输路径,能够实现快速节点间通信。当进行二次数据传输时就不需要进行路径的寻找和建立,直接依据各节点存储的信息就可完成节点间的通信任务。
现在参照2,为依照本申请实施例一种实现方式的广播方法的一种示例的流程图,该方法可由作为源节点的任一通信节点执行。如2所示的,该方法可包括步骤:
s220.通过广播的方式向一目的节点发送广播消息,所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:源节点地址、目的节点地址、以及跳数计数。如结合图1所描述的,源节点期望与目的节点通信时,若网络中已存在二者之间的可用通信路径,则源节点可根据自身存储的到达该目的节点时经过的下一跳节点的物理地址进行数据的点对点发送,由下一跳节点根据存储的再下一跳节点的物理地址继续转发,直至数据发送到该目的节点。否则,源节点将通过广播的方式发送一广播消息,用于建立源节点与目的节点之间的通信路径。所述广播消息中包括与所述广播消息关联的路由信息,包括但不限于:源节点地址、目的节点地址、以及跳数计数,所述跳数计数配置为由转发所述路径建立消息的转发节点修改,且所述跳数计数不超过预设值(例如,零)时,所述广播消息被配置为由转发节点在第一预定延迟后转发。在源节点的信号范围内的转发节点,都可能获取到该广播消息,并依照参照图1所描述的消息转发方法协助建立源节点与目的节点之间的通信路径。
s240.获取响应于所述广播消息的至少一应答消息,所述应答消息为所述目的节点通过广播的方式发送的,且所述应答消息中包括对应的广播消息的路由信息以及用于标识所述应答消息的第二消息标识。
s260.根据所述应答消息的上一跳节点地址,发送到目的节点的确认消息,用于确定与所述上一跳节点地址关联的路径为所述源节点与所述目的节点之间的通信路径。
如结合图1所描述的,源节点可根据接收到的应答消息确定到目的节点的最终通信路径,并向目的节点发送确认消息。在申请本实施例的方法中,可根据任意合适的原则确定源节点与目的节点之间的最终通信路径。在一种可能的实现方式中,所述应答消息中还可包括:所述对应的广播消息的总跳数。在这样的实现方式中,步骤s260中可至少根据所述至少一应答消息的总跳数,确定所述上一跳节点地址。例如,可确定总跳数最少的应答消息对应的路径为最终通信路径。在另一种可能的实现方式中,可根据应答消息到达源节点的时间确定最终通信路径,例如,选择最早到达源节点的应答消息对应的路径作为最终通信路径。在这样的实现方式中,步骤s260中可至少根据获取所述至少一应答消息的时间,确定所述上一跳节点地址。
由于各通信节点的接收范围有限,为了尽可能实现通信路径的建立,本实施例的方法还设置了一定的重发机制,源节点在一预设时间内未获取到来自目的节点的应答消息,则重新发起路径建立,即再次广播发送到该目的节点的广播消息。具体地,本实施例的方法还可包括:
s280.响应于在预设时间内未获取到所述至少一应答消息,再次通过广播的方式向所述目的节点发送所述广播消息。
此外,为了尽可能避免尤其在较大网络规模的情况下可能出现的碰撞,可在一预定延迟时间之后重新发送广播消息。具体地,在步骤s280中,在预设时间内未获取到应答消息,可在第三预定延迟之后重新广播所述广播消息。
需要说明的是,本申请各实施例中的第一、第二、以及第三预定延迟均可为根据需要任意设置的,且对于每一通信路径(同一对源节点和目的节点)的建立,考虑到路径建立失败而重新发起通信路径建立的可能,每次路径建立过程中的第一、第二、和/或第三预定延迟可做相应调整。
现在参照图3,为依照本申请实施例另一种实现方式的消息转发方法的示例的流程图,该方法可由作为目的节点的任一通信节点执行。如3所示的,该方法可包括步骤:
s320.获取至少一广播消息,所述广播消息为一源节点通过广播的方式发送的,且所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:源节点地址、目的节点地址、以及跳数计数。
s340.通过广播的方式向所述源节点发送应答消息,所述应答消息中包括对应的广播消息的路由信息以及用于标识所述应答消息的第二消息标识;
其中,所述跳数计数配置为由转发所述广播消息的转发节点修改,且所述跳数计数不超过预设值时,所述广播消息被配置为由转发节点在第一预定延迟后转发。
为了避免应答消息与目的节点信号范围内还未停止的广播消息的信号冲突,在步骤s340中对应答消息的广播也可延迟一定的时间。具体地,在步骤s340中在第二预定延迟后,通过广播的方式转发所述应答消息。
此外,如参照图1所描述的,对于任一目的节点,其可能接收到来自多条路径的同一广播消息,因此,需要根据广播消息对应的第一消息标识丢弃重复接收到的广播消息。具体地,本申请实施例的方法还可包括:
s332.根据所述第一消息标识,判断是否接收过所述广播消息;
s334.响应于接收过所述广播消息,丢弃所述广播消息。
需要说明的是,在参照图2和图3所做的描述中,为避免赘述,对与结合图1所做的描述中已经记载的部分相同或相应的特征未作描述,这样的相同或相应的技术特征可参照图1所做的描述。
如4所示,本申请实施例还提供了一种通信方法,该方法包括:
s420.以第一预设功率,发送与通信路径建立相关联的消息,这样的信息如结合图1-3描述的广播消息、应答消息以及确认消息。
s440.响应于通信路径的建立,以第二预设功率发送通信数据,也即通信路径建立后,源节点和目的节点之间沿该路径所传输的数据。
其中,所述第一预设功率小于所述第二预设功率。在一种可能的实现方式中,第一预设功率不超过对应的通信节点的预设功率(例如,用户设定的功率)的80%,第二预设功率为通信节点的预设功率的100%。
本领域技术人员可以理解,在本申请具体实施方式的上述方法中,各步骤的序号大小并不意味着执行顺序的先后,各步骤的执行顺序应以其功能和内在逻辑确定,而不应对本申请具体实施方式的实施过程构成任何限定。
与上述各实施例中的方法相对应地,在本申请另一种可选的实施方式中,还提供一种消息转发装置,包括:
第一功率发送单元,用于以第一预设功率,发送与通信路径建立相关联的消息;
第二功率发送单元,用于响应于通信路径的建立,以第二预设功率发送通信数据;
其中,所述第一预设功率小于所述第二预设功率。
可选地,所述装置还包括:
广播获取单元,用于获取至少一广播消息,所述广播消息用于建立源节点与目的节点之间的通信路径,且所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
所述第一功率发送单元包括:
广播转发模块,用于至少响应于所述跳数计数不超过一预设值,将所述跳数计数增加1,并在第一预定延迟后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述预设值为零。
可选地,所述广播消息为一源节点通过广播的方式向一目的节点发送的,且所述路由信息还包括:源节点地址、目的节点地址、以及上一跳节点地址;
所述装置还包括:
存储单元,用于存储与所述广播消息关联的所述路由信息;
所述广播转发模块包括:
路由信息更新模块,用于将所述上一跳节点地址修改为本地节点地址后,以所述第一预设功率,通过广播的方式转发所述广播消息。
可选地,所述路由信息中还包括:用于标识所述广播消息的第一消息标识;
所述装置还包括:
消息识别单元,用于根据所述第一消息标识,判断是否转发过所述广播消息;
丢弃单元,用于响应于转发过所述广播消息,丢弃所述广播消息。
可选地,所述装置还包括:
应答单元,用于响应于一广播消息对应的目的节点地址与本地节点地址相同,通过广播的方式向所述广播消息对应的源节点发送应答消息;
其中,所述应答消息中包括对应的广播消息的路由信息。
可选地,所述装置还包括:
应答获取单元,获取至少一应答消息,所述应答消息为一目的节点通过广播的方式发送的,且所述应答消息中包括对应的广播消息的路由信息;
应答转发单元,用于根据与所述应答消息对应的路由信息,转发所述应答消息。
可选地,所述应答转发单元包括:
应答延迟模块,用于至少响应于所述应答消息中的跳数计数不超过一预设值,将所述应答消息中的跳数计数增加1,在第二预定延迟后,转发所述应答消息。
可选地,所述应答转发单元包括:
上一跳确定模块,用于根据所述应答消息对应的路由信息中的源节点地址,确定所述对应的广播消息的上一跳节点地址;
上一跳转发模块,用于根据所述上一跳节点地址,向所述上一跳节点转发所述应答消息。
可选地,所述装置还包括:
应答确认单元,用于响应于所述应答消息中包括的路由信息对应的源节点地址为本地节点地址,根据所述应答消息对应的上一跳节点地址,以所述第一预设功率,发送到目的节点的确认消息;
其中,所述确认消息用于确定与所述上一跳节点地址关联的路径为所述源节点与所述目的节点之间的通信路径。
可选地,所述应答消息中还包括:所述对应的广播消息的总跳数;
所述应答确认单元包括:
总跳数选择模块,至少根据所述总跳数,确定所述上一跳节点地址。
可选地,所述应答确认单元包括:
应答时间选择模块,用于至少根据获取所述至少一应答消息的时间,确定所述上一跳节点地址。
此外,本申请实施例还提供了一种存储设备,例如,计算机可读介质,包括在被执行时进行以下操作的计算机可读指令:执行上述图1中所示实施方式中的方法的各步骤的操作。
此外,本申请实施例还提供了一种存储设备,例如,计算机可读介质,包括在被执行时进行以下操作的计算机可读指令:执行上述图2中所示实施方式中的方法的各步骤的操作。
此外,本申请实施例还提供了一种存储设备,例如,计算机可读介质,包括在被执行时进行以下操作的计算机可读指令:执行上述图3中所示实施方式中的方法的各步骤的操作。
此外,本申请实施例还提供了一种存储设备,例如,计算机可读介质,包括在被执行时进行以下操作的计算机可读指令:执行上述图4中所示实施方式中的方法的各步骤的操作。
下面通过具体示例进一步说明本申请各实施例的技术方案。
参照图5,为依照本申请各示例的方法建立通信节点(源节点)a到通信节点(目的节点)s的通信路径的过程示意图。
如图5所示,当节点a期望与节点s进行通信时,如果节点a中存储了到达节点s经过的下一跳节点的物理地址,则表明在网络中已经存在节点a与节点s之间的通信路径(如图5中的a→c→i→j→s)。节点a根据存储的节点c的物理地址将数据发送给节点c,节点c根据存储的节点i的物理地址继续将数据发送给节点i,直到此数据传输给节点s,通信任务完成。
如果节点a中没有存储到达节点s经过的下一跳的物理地址,则依照本申请各实施例的技术方案,通过如下步骤建立通信路径。
1、节点a通过广播的方式发出路径建立消息,该消息中包含:消息id(区分每一次广播)、源节点地址、目的地址、跳数计数(当前为零)、上一跳的转发节点地址。
2、假设整个网络中节点b、c、d收到了这一路径建立消息:
首先各节点b、c、d记录如下路由信息:广播的消息id、上一跳节点地址、源节点地址、目的节点地址。
然后,各节点b、c、d各自随机延迟一段时间,并将路径建立消息中包含的跳数计数加1,然后二次广播,二次广播的路径建立消息中的跳数计数为1。
3、接着,网络中的节点e、f收到了来自节点d的广播,而节点g收到了来自节点b的广播。虽然节点g也能收到来自节点c的广播,但是由于节点对同一id广播消息不重复接收,之前的广播由节点b、c、d转发时进行了随机延迟,因此节点c的消息到达较晚,所以被丢弃(图4中虚线箭头所示为被丢弃的消息对应的传递路径)。
收到消息的节点e、f、g同样记录如下信息:路径建立请求消息id、上一跳节点地址、源节点地址、目的节点地址。然后,节点e、f、g不再进行延迟,直接将广播消息中包含的跳数计数再次加1,然后三次广播(此时跳数计数为2)。
4、最终,直到节点s收到首个广播的路径建立消息(节点s同样对于同一id的消息不重复接收),之后节点s延迟一跳传播所需要的时间,启动最佳通讯路径确认过程,以有助于节点a寻找最佳路径、同时排除无线收发性能不对等造成的消息无法回传。
最佳通讯路径确认过程如下:
1、节点s广播路径建立应答请求,该广播消息中包含:路径建立应答请求消息id、路径建立请求消息id、源节点地址、目的节点地址、总跳数(节点s收到对应的路径建立消息时的跳数计数),启动反向通信路径发现过程。
2、假设节点n、j、q收到了这一广播消息。
首先节点n、j、q各自查询是否记录过到达节点a的上一跳节点的物理地址,如果记录过,则可随机延迟一段时间后,直接向记录中的上一级节点发送s给a的应答消息;
如果节点n、j、q查询后没有记录过去往节点a的上一跳地址,则可随机延迟一段时间后,根据路径建立请求消息对应的路由消息中的上一跳节点地址,向上一跳节点发送给a的应答消息。
3、假设上一跳节点包括节点l、k、i、h,节点l、k、i、h收到这个点对点应答消息后,同样按照上述步骤,首先查询自己是否记录过到达a的上一跳地址记录,如果没有,则继续向路径建立请求消息对应的上一跳节点发送给a的应答消息。
4、以此类推,直到节点a首次收到节点s发来的应答消息(图4中由粗箭头示意),则不再处理其他节点发来应答消息(如图4中由d到a以及由b到a的粗虚线箭头所示),并启动最终路径确认。
5、节点a向收到的路径建立应答消息的上一跳节点c发送去往节点s的路径建立确认信息,节点c将之前临时记录的去往节点s的上一跳地址及下一条地址保存到自己的路由表中,然后向下一节点i继续发送路径建立确认消息,节点i也将之前的临时记录进行最终确认保存,直到节点s收到路径建立确认消息,整个路径建立过程完成。
说明,在整个路径建立过程汇总,所有的节点使用用户设定的发射功率的80%进行发射,防止未来由于天气等环境因素造成的无线性能差异,导致通讯不稳定。节点a向节点s发出路径建立消息、及节点s向节点a进行路径建立应答、以及节点a向节点s发送路径建立确认消息,都有超时机制,如果指定时间内没有相应,则可重新启动路径建立过程。
路径建立成功后,节点a向节点s发送数据时,直接向下一跳节点发送数据,节点s收到后进行确认应答,以确保通讯可靠,这里如果超时没有收到回应,则重新启动路径发现过程。
在某些情况下,有可能出现节点间通信的两个方向发射功率不对等导致路由失败的情况。假设现在有abcd四个节点,发起路由请求时:a发出的消息只有b能收到,b发的只有c可以收到,c发的目的节点d收到。返回路由请求时:由于功率不对等问题,d发送的b和c都收到了,然后b会先把消息发给a,这是a进行路径确认时路径就变成了a→b→d,而实际上b到d是无法通讯的,最终导致d收不到消息,路由失败。为解决这个问题,采用了更一步的方案。根据进一步的方案,在上述情况中,当d发送广播返回路由请求时,b和c侦听d返回的路由请求,并可以做一个记录。当a发送路由确认消息的时候,b收到发给d的时候,c侦听该确认消息,并启动一定时器。启动定时器后,c侦听到响应于所述确认消息的至少一确认相应信息。该确认相应信息由目的节点发出。若定时器到期后,c如果没有收到d给a的确认相应消息,则c会发送一个确认消息给d,d将路由确认相应消息,会先给c,然后c继续给b,再给a。
图6为本申请实施例的通信节点的又一种示例的结构示意图,本申请具体实施例并不对通信节点的具体实现做限定。如图6所示,该通信节点600可以包括:
处理器(processor)610、通信接口(communicationsinterface)620、存储器(memory)630、以及通信总线640。其中:
处理器610、通信接口620、以及存储器630通过通信总线640完成相互间的通信。
通信接口620,用于与比如客户端等的网元通信。
处理器610,用于执行程序632,具体可以执行上述方法实施例中的相关步骤。
具体地,程序632可以包括程序代码,所述程序代码包括计算机操作指令。
处理器610可能是一个中央处理器cpu,或者是特定集成电路asic(applicationspecificintegratedcircuit),或者是被配置成实施本申请实施例的一个或多个集成电路。
存储器630,用于存放程序632。存储器630可能包含高速ram存储器,也可能还包括非易失性存储器(non-volatilememory),例如至少一个磁盘存储器。程序632具体可以用于使得所述通信节点600执行以下步骤:
获取至少一广播消息,所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
至少响应于所述跳数计数不超过一预设值,将所述跳数计数增加1,并在第一预定延迟后,通过广播的方式转发所述广播消息。
程序632中各步骤的具体实现可以参见上述实施例中的相应步骤和单元中对应的描述,在此不赘述。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。
图7为本申请实施例的通信节点的又一种示例的结构示意图,本申请具体实施例并不对通信节点的具体实现做限定。如图7所示,该通信节点700可以包括:
处理器(processor)710、通信接口(communicationsinterface)720、存储器(memory)730、以及通信总线740。其中:
处理器710、通信接口720、以及存储器730通过通信总线740完成相互间的通信。
通信接口720,用于与比如客户端等的网元通信。
处理器710,用于执行程序732,具体可以执行上述方法实施例中的相关步骤。
具体地,程序732可以包括程序代码,所述程序代码包括计算机操作指令。
处理器710可能是一个中央处理器cpu,或者是特定集成电路asic(applicationspecificintegratedcircuit),或者是被配置成实施本申请实施例的一个或多个集成电路。
存储器730,用于存放程序732。存储器730可能包含高速ram存储器,也可能还包括非易失性存储器(non-volatilememory),例如至少一个磁盘存储器。程序732具体可以用于使得所述通信节点700执行以下步骤:
通过广播的方式向一目的节点发送广播消息,所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
获取响应于所述广播消息的至少一应答消息,所述应答消息为一目的节点通过广播的方式发送的,且所述应答消息中包括对应的广播消息的路由信息以及用于标识所述应答消息的第二消息标识;
根据所述至少一应答消息的上一跳节点地址,发送到所述目的节点的确认消息;
其中,所述跳数计数配置为由转发所述广播消息的转发节点修改,且所述跳数计数不超过一预设值时,所述广播消息被配置为由转发节点在第一预定延迟后转发。
程序732中各步骤的具体实现可以参见上述实施例中的相应步骤和单元中对应的描述,在此不赘述。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。
图8为本申请实施例的通信节点的又一种示例的结构示意图,本申请具体实施例并不对通信节点的具体实现做限定。如图8所示,该通信节点800可以包括:
处理器(processor)810、通信接口(communicationsinterface)820、存储器(memory)830、以及通信总线840。其中:
处理器810、通信接口820、以及存储器830通过通信总线840完成相互间的通信。
通信接口820,用于与比如客户端等的网元通信。
处理器810,用于执行程序832,具体可以执行上述方法实施例中的相关步骤。
具体地,程序832可以包括程序代码,所述程序代码包括计算机操作指令。
处理器810可能是一个中央处理器cpu,或者是特定集成电路asic(applicationspecificintegratedcircuit),或者是被配置成实施本申请实施例的一个或多个集成电路。
存储器830,用于存放程序832。存储器830可能包含高速ram存储器,也可能还包括非易失性存储器(non-volatilememory),例如至少一个磁盘存储器。程序832具体可以用于使得所述通信节点800执行以下步骤:
获取至少一广播消息,所述广播消息为一源节点通过广播的方式发送的,且所述广播消息中包括与所述广播消息关联的路由信息,所述路由信息包括:跳数计数;
通过广播的方式向所述源节点发送应答消息,所述应答消息中包括对应的广播消息的路由信息以及用于标识所述应答消息的第二消息标识;
其中,所述跳数计数配置为由转发所述广播消息的转发节点修改,且所述跳数计数不超过预设值时,所述广播消息被配置为由转发节点在第一预定延迟后转发。
程序832中各步骤的具体实现可以参见上述实施例中的相应步骤和单元中对应的描述,在此不赘述。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。
图9为本申请实施例的通信节点的又一种示例的结构示意图,本申请具体实施例并不对通信节点的具体实现做限定。如图9所示,该通信节点900可以包括:
处理器(processor)910、通信接口(communicationsinterface)920、存储器(memory)930、以及通信总线940。其中:
处理器910、通信接口920、以及存储器930通过通信总线940完成相互间的通信。
通信接口920,用于与比如客户端等的网元通信。
处理器910,用于执行程序932,具体可以执行上述方法实施例中的相关步骤。
具体地,程序932可以包括程序代码,所述程序代码包括计算机操作指令。
处理器910可能是一个中央处理器cpu,或者是特定集成电路asic(applicationspecificintegratedcircuit),或者是被配置成实施本申请实施例的一个或多个集成电路。
存储器930,用于存放程序932。存储器930可能包含高速ram存储器,也可能还包括非易失性存储器(non-volatilememory),例如至少一个磁盘存储器。程序932具体可以用于使得所述通信节点900执行以下步骤:
以第一预设功率,发送与通信路径建立相关联的消息;
响应于通信路径的建立,以第二预设功率发送通信数据;
其中,所述第一预设功率小于所述第二预设功率。
程序932中各步骤的具体实现可以参见上述实施例中的相应步骤和单元中对应的描述,在此不赘述。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述装置实施例中的对应描述,在此不再赘述。
尽管此处所述的主题是在结合操作系统和应用程序在计算机系统上的执行而执行的一般上下文中提供的,但本领域技术人员可以认识到,还可结合其他类型的程序模块来执行其他实现。一般而言,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、组件、数据结构和其他类型的结构。本领域技术人员可以理解,此处所述的本主题可以使用其他计算机系统配置来实践,包括手持式设备、多处理器系统、基于微处理器或可编程消费电子产品、小型计算机、大型计算机等,也可使用在其中任务由通过通信网络连接的远程处理设备执行的分布式计算环境中。在分布式计算环境中,程序模块可位于本地和远程存储器存储设备的两者中。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及方法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对原有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例所述方法的全部或部分步骤。而前述的计算机可读取存储介质包括以存储如计算机可读指令、数据结构、程序模块或其他数据等信息的任何方式或技术来实现的物理易失性和非易失性、可移动和不可因东介质。计算机可读取存储介质具体包括,但不限于,u盘、移动硬盘、只读存储器(rom,read-onlymemory)、随机存取存储器(ram,randomaccessmemory)、可擦除可编程只读存储器(eprom)、电可擦可编程只读存储器(eeprom)、闪存或其他固态存储器技术、cd-rom、数字多功能盘(dvd)、hd-dvd、蓝光(blue-ray)或其他光存储设备、磁带、磁盘存储或其他磁性存储设备、或能用于存储所需信息且可以由计算机访问的任何其他介质。
以上实施方式仅用于说明本发明,而并非对本发明的限制,有关技术领域的普通技术人员,在不脱离本发明的精神和范围的情况下,还可以做出各种变化和变型,因此所有等同的技术方案也属于本发明的范畴,本发明的专利保护范围应由权利要求限定。