组建一个完整的Z I GBEE网状网络需要包含两个步骤:第一,进行网络初始化;第二,把节点加入网络。那么对于节点加入网络 设计的时候又包括两个步骤:通过与协调 器连接入网和通过已有的父节点入网。
一、网络初始化
ZIGBEE 网络的建立是由协调器发起的,任何一个ZIGBEE节点要组建一个网络必须要满足以下两点要求:
(1)节点是FFD(Full Function Device )节点,拥有ZIGBEE协调器的功能。
(2)节点还没有与其他网络建立连接,如果当节点已经与其他网络连接时,那么此节点就只能作为该网络的子节点了,因为,在一个ZIGBEE网络中有且只能有一个网络协调器。
确定了需要满足的要求之后,接下来就是确定网络协调器,首先判断节点是否是FFD 节点,接着判断此 FFD节点是否在其他网络里或者是否已经在网络中存在一个协调器。我们可以通过主动扫描的方式,发送一个信标请求命令(Beacon request command),然后设置一个扫描期限(T_scan_duration),若在扫描期限的时间里设备都没有检测到信标,那么就认为FFD在其网络内没有协调器,那么此时就可以建立自己的 ZIGBEE网络了,并且作为这个网络的协调器不断地产生信标并广播出去,另外我们需要注意的是,在一个网络里面,只能有一个协调器。
确定了网络协调器之后,我们接下来要做的就是信道扫描的过程。其中包括能量扫描和主动扫描这两个过程。
首先对指定的信道或者默认的信道进行能量上面的检测,为的就是避免可能的干扰。并且要以递增的方式对所测量的能量值进行信道排序,在这个过程中我们要舍弃一些能量值超过了可允许能量水平的那些信道,选择那些可以允许能量水平的信道,并且标记这些信道是可用的信道。接着再进行主动的扫描,搜索节点通信半径内的网络信息。这些信息将会以信标帧的形式在网络中广播,节点通过主动信道扫描方式获得这些信标帧,然后会根据这些信息提示,找到一个稳定的、相对安静的信道,通过记录的结果,会选择一个存在最少的ZIGBEE设备的网络,当然最好是没有ZIGBEE设备。在主动扫描期间,MAC层将会丢弃PHY层数据服务接收到的除信标以外的所有帧。
那么之后我们就该设置我们的网络ID。首先我们找到合适的信道后,协调器会 为网络选定一个网络标识符 ,也就是经常说的通道,信道。这个ID在所使用的信道内必须是唯一的 ,通时也不能和其他ZIGBEE网络冲突,而且不能为广播地址0xFFFF,因为广播地址是保留地址,不能使用。PAN ID可以通过侦听其他网络的ID 然后选择一个不会冲突的 ID的方式来获取,也可以人为的指定扫描的信道后,来确定不和其他网络冲突的网络号。
另外我们需要知道的是ZIGBEE网络中有两种地址模式:扩展地址(64位)和短地址(16位),其中扩展地址由IEEE组织分配,用于唯一的设备标识。短地址用于本地网络中设备标识,一个网络中,每个设备的短地址必须是唯一的,当节点加入网络时由其 父节点分配并通过使用短地址来进行通信。对于协调器来说,短地址通常设定为0x0000,还记得之前说的吧,协调器是一个ZIGBEE网络中唯一的节点,一个网络中只能有一个协调器的存在。
经过上面的步骤,我们就成功的初始化了ZIGBEE网状网络,那么之后就等待其他节点的加入了。节点入网时将选择范围内信号最强的父节点(包括协调器)加入网络,成功后将得到一个网络短地址并通过这个地址进行数据的发送和接收,网络拓扑关系和地址就会保存在各自的内存之中。
说完了组建一个完整的Z I GBEE网状网络需要包含的两个步骤之一,接下来我们继续说第二个步骤。
二、节点通过协调器加入网络
当节点协调器确定之后,节点首先需要和协调器建立连接以加入网络。
为了建立这个连接,FFD节 点需要向协调器提出一个请求,协调器接收到节点的连接请求之后,会根据情况决定是否允许其进行连接,然后对请求连接的节点做出相应的响应,节点与协调器建立连接后,才能实现数据的收发功能。
那么节点与协调器连接加入网络的具体流程如以下几个步骤:
(1)查找网络协调器
首先我们的ZIGBEE设备会主动的扫描并查找周围网络的协调器,若是在扫描期限内检测到有信 标的存在,那么就将会获得了协调器的相关信息,此时就会向协调器发出连接的请求。在选择合适的网络之后,上层就会请求MAC层对物理层PHY和MAC层的PHY Current Channel、mac PAN ID等PIB属性进行相应的设置。若没有检测到信标的存在,那么就会间隔一段的时间,之后节点会重新的发起又一次的扫描了,这就是查找网络协调器的过程。
(2) 发送关联请求命令(Associate request command)。
查找到网络中的协调器之后,节点将把关联请求命令发送给查找到的网络协调器,协调器收到后立即回复一个确认帧(ACK),与此同时也将向它的上层发送连接指示原语,这个原语表示已经收到节点的连接请求。但是这个时候并不意味着已经建立了连接,只是表示协调器已经收到节点的连接请求。当协调器的mac层的上层接收到连接指示原语后,将根据自己的资源情况 (通常的是存储空间以及能量) 决定是否同意此节点的加入请求,然后会给节点的mac层发送响应。
(3) 等待协调器处理。
发送请求之后,当节点收到协调器加入关联请求的ACK后,节点mac将等待一段时间,接受协调器的连接响应。在预定的时间内,如果接收到连接响应,那么之后就将这个响应(ACK)向它的上层通告。然而协调器通常会给节点的mac层发送响应时会设置一个等待的响应时间(T_Response Wait Time)用来等待协调器对其加入请求命令的处理,若协调器的资源足够,那么协调器就会给节点分配一个16位的短地址 ,并产生包含新地址和连接成功状态的连接响应命令,则此时此节点将成功的和协 调器建立连接并可以开始通信。如果协调器的资源不够,那么待加入的节点将会重新的发送链接请求信息,一直到入网成功为止。
(4) 发送数据请求命令。
若协调器在响应时间内同意新节点的加入,那么将会产生关联响应命令(Associate response command),并把该命令进行存储。当响应的时间过后,节点发送数据请求命令(Data request command)给协调器,协调器收到后立即回复ACK,之后将存储的关联响应命令发给节点。若在响应时间到后,协调器还是没有决定是否同意节点加入,那么该节点将会试图从协调器的信标帧中提取关联响应命令,如果成功的话该节点就会入网成功,否则就重新发送请求信息直到入网成功,这就像是一个不断申请的过程,直到申请加入成功之后才不申请。
(5)回复信息。
相关节点收到关联响应的命令之后,就会立即向协调 器回复一个确认帧(ACK),用来确认接收到的连接响应命令,此时节点将保 存协调器的短地址以及扩展地址,并且节点的MLME向上层发送连接确认原语,宣告关联加入成功的信息。
上面就是节点与协调器连接加入网络的具体流程,那么我们上文又说道,加入网络有两种方式的,即通过与协调器连接入网和通过已有的父节点入网。那么通过已有的父节点加入网络具体是怎样实现的呢,具体的我们可以继续往下面看。
当靠近协调器的FFD节点和协调器关联成功之后,处于这个网络范围内的其他节点就以这些FFD节点作为父节点加入网络,具体加入网络有两种方式,一种是通过关联(associate)方式,就是待加入的节点发起加入网络;另一种是直接(direct)方式,就是 待加入的节点具体加入到哪一个节点下,作为该节点的子节点。其中关联方式是ZIGBEE网络中新节点加入 网络的主要途径。我们知道对于一个节点来说,只有没有加入过网络的节点才能进行加入网络的操作。在这些节点中,有些是曾经加入过网络中的,但是却与它的父节点失去了联系像这样的节点,通常被称为孤儿节点,而有些则是新的节点。当是孤儿节点的时候,在它的相邻表中会存有原父节点的信息,于是乎它可以直接给原父节点发送加入网络的请 求信息。
如果这个子节点的父节点有能力同意它的加入,那么就会直接告诉它以前被分配的网络地址,于是它便成功加入网络;如果此时子节点原来的父节点的网络之中,子节点数已经达到了最大的值,也就是说父节点的网络地址已经分配满了,此时父节点便无法批准孤儿节点的加入,而孤儿节点之后加入网络只能以新节点的身份重新寻找并加入网络;而对于新节点来说,他首先会在预先设定好的一个或多个信道上通过主动或者被动扫描周围的方式,使它可以找到的网络,寻找 有能力批准自己加入网络的父节点,并把可以找到的父节点 的资料存入自己的相邻表。存入相邻表的父节点的资料包括ZIGBEE协议的版本、协议栈的规范、PAN ID以及可以加入的相关信息。在相邻表中所有的父节点中会选择一个相对深度最小的,并对其发出请求连接的信息,那么如果出现最小深度一样的两个以上的父节点,那么就会随机选取一个发送请求。
如果相邻表中没有合适的父节点信息,表示入网失败,终止过程。如果发出的请求被批准,那么父 节点会同时分配一个16位的网络地址,此时入网便成功,子节点就可以开始通信。如果请求失败了,那么就会重新查找相邻表,继续发送请求信息,直到加入网络为止,这就是通过已有的父节点加入网络的具体实现流程和原理。