CN106302032B - 一种点对多点轮询通讯方法 - Google Patents
一种点对多点轮询通讯方法 Download PDFInfo
- Publication number
- CN106302032B CN106302032B CN201610934309.7A CN201610934309A CN106302032B CN 106302032 B CN106302032 B CN 106302032B CN 201610934309 A CN201610934309 A CN 201610934309A CN 106302032 B CN106302032 B CN 106302032B
- Authority
- CN
- China
- Prior art keywords
- terminal device
- response
- poll
- polled
- list
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/10—Active monitoring, e.g. heartbeat, ping or trace-route
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/1607—Details of the supervisory signal
- H04L1/1685—Details of the supervisory signal the supervisory signal being transmitted in response to a specific request, e.g. to a polling signal
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Small-Scale Networks (AREA)
- Health & Medical Sciences (AREA)
- Cardiology (AREA)
- General Health & Medical Sciences (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本发明提供一种点对多点轮询通讯方法,主控节点向终端设备发出轮询开始应答指令;终端设备在收到轮询开始应答指令后,根据事先获得的被轮询终端设备列表中规定的应答次序依次应答;或者,所述轮询开始应答指令中含第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。本发明轮询效率高,对于需要传送大量相同的重要数据至客户端且需要客户端进行回应时效率可大幅度提高。
Description
技术领域
本发明属于通信技术领域,尤其涉及一种点对多点轮询通讯方法。
背景技术
传统的轮询问答方式主要采用主控节点依据轮询列表依次询问、客户端收到询问指令后作出回应的方式,即,主控节点向第一个客户端发送查询数据指令→第一个客户端回应;主控节点向第二个客户端发送查询数据指令→第二个客户端回应……直至,主控节点向第N个客户端发送查询数据指令→第N个客户端回应。
申请号02131775.5的发明专利提供了一种设备数据轮询调度方法,采用如下步骤:A、读取设备数据,所有设备按其类型和内部模块分类,并赋予相应的优先级和轮询间隔,生成轮询任务列表;B、按轮询间隔为设备周期轮询数据,根据轮询任务列表启动轮询调度线程,同时启动连通状态检测线程;C、根据轮询优先级和轮询间隔依次对设备的相应模块进行轮询。该方法根据预订轮询列表对设备进行轮询,主控节点需要不断发出轮询指令,通知相应的客户端进行应答,完成一次轮询所需时间很长,轮询效率低。
发明内容
为解决现有技术存在的问题,本发明提供一种点对多点轮询通讯方法,该轮询通讯方法效率高,对于需要传送大量相同的重要数据至客户端且需要客户端进行回应时效率可大幅度提高。
本发明提供的点对多点轮询通讯方法,包括以下步骤:
主控节点向终端设备发出轮询开始应答指令;
终端设备在收到轮询开始应答指令后,根据事先获得的被轮询终端设备列表中规定的应答次序依次应答,即,被轮询终端设备列表中规定的第一个应答的终端设备首先应答,其余终端设备在侦听到排在其前面的终端设备应答完毕后应答;或者,所述轮询开始应答指令中含第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。
本发明对传统的轮询方式作出重大改进,将传统轮询方法中的主控节点根据轮询任务列表依次向各终端设备发出轮询指令、终端设备根据轮询指令应答的方式,调整为,由主控节点直接向所有终端设备广播轮询开始应答指令,终端设备根据设定好的被轮询终端设备列表中的应答次序依次应答,或者在轮询开始应当指令中指定第一个应答的终端设备,由该终端设备首先应答,其余终端设备根据被轮询终端设备列表中的应答次序依次应答。本发明减少主控节点与终端设备之间的轮询通讯次数,使得轮询效率大幅度提升。
为避免后一终端设备侦听到前一终端设备已经完成应答,但主控节点尚未完成相关数据存储等工作,导致出现冲突等问题,所述被轮询终端设备列表中还包括数据保护间隔时长,终端设备在侦听到排在其前面的终端设备应答完毕,等待数据保护间隔时长规定的时间届满后再应答。
由于终端设备或通讯存在发生故障的可能,为避免一个或多个终端设备应答超时导致轮询中断,本发明采用技术方案进行调整,当一个或多个终端设备未应答,主控节点重新发出轮询开始应答指令,该轮询开始应答指令中含有第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。当各终端设备根据被轮询终端设备列表中规定的应答次序依次应答时,通过含有第一个应答的终端设备的序号的轮询开始应答指令进行调整,跳过发生故障的终端设备。当主控节点发出的轮询开始应答指令含有第一个应答的终端设备的序号时,此时发生终端设备或通讯故障,主控节点再次发送轮询开始应答指令,相当于本发明点对多点轮询通讯方法重新启动。
本发明还采用以下方案来避免一个或多个终端设备应答超时导致轮询中断,当一个或多个终端设备未应答,排在未应答终端设备后的终端设备自行启动应答。考虑到通讯效率以及防止通讯死锁,本发明约定最大可允许的连续故障终端设备的数量,当连续未应答终端设备数量超过预设值时,由主控节点重新发出轮询开始应答指令,轮询开始应答指令中含第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。
为实现全部终端设备有序完成应答,当所述轮询开始应答指令中指定第一个应答的终端设备的序号,自该序号的终端设备、以及所述被轮询终端设备列表中排在该序号之后其余终端设备全部应答完毕后,所述被轮询终端设备列表中排在第一位的终端设备开始应答,直至所述被轮询终端设备列表中排在该序号前面的终端设备全部应答完毕。
终端设备可以通过多种方式获得被轮询终端设备列表,如,在主控节点发出轮询应答指令之前,所述主控节点向终端设备广播被轮询终端设备列表;或者,所述被轮询终端设备列表事先存储在终端设备中。
本发明提供的点对多点轮询通讯方法,由终端设备自行根据被轮询终端设备列表中的顺序依次应答,避免主控节点单独给每个终端设备发送轮询指令,再由终端设备应答,大大提高了轮询效率,节约了资源。本发明可用于对现有系统的改进,如消防设施、通讯设备轮询,无需改变硬件环境,改造成本低廉。
附图说明
图1为实施例一流程图;
图2为实施例二流程图;
图3为终端设备应答超时流程图。
具体实施方式
实施例一:
如图1所示,由主控节点广播被轮询终端设备列表(被轮询终端设备列表也可以事先存储在终端设备中),该被轮询终端设备列表中含有各终端设备的应答次序以及数据保护间隔时长;主控节点向所有终端设备广播轮询开始应答指令;终端设备根据被轮询终端设备列表规定的应答次序依次应答,具体的实现是:被轮询终端设备列表中设定的第一个终端设备总是立即应答,其它终端设备在侦听到其上一个终端设备数据应答完毕后,延时一段时间(即数据保护间隔时长)后,自动开始应答,直至被轮询终端设备列表中最后一个终端设备应答完毕后轮询结束。
以下表为例进行说明,:
序号 | 1 | 2 | 3 | 4 | 5 |
终端设备号 | A | C | B | D | E |
表1:被轮询终端设备列表
当收到主控节点发出的轮询开始应答指令后,A首先应答,C其次应答,B、D、E依次应答。
实施例二:
如图2所示,由主控节点广播被轮询终端设备列表(被轮询终端设备列表也可以事先存储在终端设备中),该被轮询终端设备列表中含有各终端设备的应答次序以及数据保护间隔时长;主控节点向所有终端设备广播轮询开始应答指令,轮询开始应答指令中含有第一个应答的终端设备的序号;终端设备依次应答,具体的实现是:轮询开始应答指令中指定的第一个应答的终端设备立即应答,其余终端设备依据被轮询终端设备列表中规定的应答次序依次应答,更具体地说,被轮询终端设备列表中规定的排在轮询开始应答指令中指定的第一个应答的终端设备后的终端设备,在侦听到轮询开始应答指令中指定的第一个应答的终端设备应答完毕,延时一段时间(即数据保护间隔时长)后,自动开始应答,依此类推,直至排在第一个应答的终端设备后的终端设备全部应答完毕,此时,并非所有的终端设备都应答完毕,被轮询终端设备列表中排在轮询开始应答指令中指定的第一个应答的终端设备前的终端设备尚未应答,那么,被轮询终端设备列表中规定的第一个应答终端设备首先应答,依此类推,直至排在轮询开始应答指令中指定的第一个应答的终端设备前的终端设备全部应答完毕。
以下表为例进行说明:
序号 | 1 | 2 | 3 | 4 | 5 |
终端设备号 | A | C | D | B | E |
表2:被轮询终端设备列表
序号 | 3 |
终端设备号 | D |
表3:轮询开始应答指令中含有的应答序号
当收到主控节点发出的轮询开始应答指令后,终端设备D首先应答,终端设备B侦听到终端设备D应答完毕后应答,终端设备E侦听到终端设备B应答完毕后应答,由于仍有终端设备尚未应答,此时,由被轮询终端设备列表中排在第一位的终端设备A应答,终端设备C侦听到终端设备A应答完毕后应答。
如图3所示,当发生通讯故障或终端设备故障,一个或多个终端设备应答超时,此时可采用两种方式解决,避免轮询终端:
其一,由主控节点根据业务逻辑进行判断处理后重新发送轮询开始应答指令,轮询开始应答指令中含有第一个应答的终端设备的序号。以表2为例进行说明,终端设备A应答完毕后,按照次序,应该由终端设备C应答,但终端设备C发生故障,主控节点发出含有表3的轮询开始应答指令,此时,从终端D开始应答,B、E依次应答。在不同的轮询环境中,业务逻辑存在不同,例如,在消防喷淋设备轮询中,部分喷淋设备的优先级较高,则,重新发送的轮询开始应答指令可以指定优先级最高的终端设备首先应答。
其二,被轮询终端设备列表中,排在应答超时的终端设备后的终端设备自行启动应答,依次类推,直至终端设备全部应答完毕。以表2为例,终端设备A应答完毕后,按照次序,应该由终端设备C应答,但终端设备C发生故障,终端设备D在系统设定的时间内未侦听到终端设备C应答完毕的状态,那么终端设备D自行启动应答,依此类推。如果终端设备D也发生故障,那么终端设备B在系统设定的时间未侦听到终端设备D应答完毕的状态,那么终端设备B自行启动应答。考虑到系统的通讯效率以及防止通讯死锁,本发明设计有最大可允许的连续故障终端设备数量,当连续未应答终端数量超出最大可允许的连续故障终端设备数量时,由主控节点重新发送轮询开始应答指令,轮询开始应答指令中含有第一个应答的终端设备的序号。
以下举例说明本发明与传统方式之间的效果差异:
代号 | 全称 | 单位 |
PB | 物理线路波特率 | bit/s |
MDL | 主控节点发出的指令/数据长度 | bits |
CDL | 客户端地址长度 | bits |
SDL | 客户端应答数据长度 | bits |
N | 客户端数量 | unit |
SLOT | 数据保护间隔时长 | s |
表4轮询效率计算依据
以简单轮询通讯为例(楼宇温度探头轮检),物理通讯波特率为9600bit/s,主控节点发出的指令长度为16bits,客户端地址长度为16bits,客户端应答数据长度为16bits,数据保护间隔时长为1毫秒(0.001秒),并假设对1000个探头进行轮检。
传统轮询方式:
主控节点向第一个客户端发送查询数据指令→第一个客户端回应,
主控节点向第二个客户端发送查询数据指令→第二个客户端回应,
……
主控节点向第N个客户端发送查询数据指令→第N个客户端回应。
传统方式对N个客户端完成一次轮询通讯时长为:
N*((MDL+CDL)/PB+(SDL+CDL)/PB+SLOT)=1000*((16+16)/9600+(16+16)/9600+0.001)=7.667秒。
本发明方式:
主控节点发送被轮询客户端列表及数据保护间隔时长,主控节点发送轮询开始应答指令,
第一个客户端回应,
第二个客户端回应,
……
第N个客户端回应。
本发明对N个客户端完成一次轮询通讯时长为:
MDL/PB+N*((SDL+CDL)/PB+SLOT)=16/9600+1000*((16+16)/9600+0.001)=4.335秒。
本发明与传统轮询方式相比,轮询效率提升至原来的1.768倍,对于需要传送大量相同的重要数据至客户端且需要客户端进行回应时效率甚至可成百上千倍地提升。
Claims (6)
1.一种点对多点轮询通讯方法,其特征在于:
主控节点向终端设备发出轮询开始应答指令;
所述轮询开始应答指令中含第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答,当该序号的终端设备、以及所述被轮询终端设备列表中排在该序号之后其余终端设备全部应答完毕后,所述被轮询终端设备列表中排在第一位的终端设备开始应答,直至所述被轮询终端设备列表中排在该序号前面的终端设备全部应答完毕。
2.如权利要求1所述的点对多点轮询通讯方法,其特征在于:所述被轮询终端设备列表中还包括数据保护间隔时长,终端设备在侦听到排在其前面的终端设备应答完毕,等待数据保护间隔时长规定的时间届满后再应答。
3.如权利要求1或2所述的点对多点轮询通讯方法,其特征在于:当一个或多个终端设备未应答,主控节点重新发出轮询开始应答指令,该轮询开始应答指令中含有第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。
4.如权利要求1或2所述的点对多点轮询通讯方法,其特征在于:当一个或多个终端设备未应答,排在未应答终端设备后的终端设备自行启动应答。
5.如权利要求4所述的点对多点轮询通讯方法,其特征在于:当连续未应答终端设备数量超过预设值时,由主控节点重新发出轮询开始应答指令,轮询开始应答指令中含第一个应答的终端设备的序号,该序号对应的终端设备首先应答,其余终端设备根据被轮询终端设备列表中规定的应答次序、侦听到排在其前面的终端设备应答完毕后应答。
6.如权利要求1或2所述的点对多点轮询通讯方法,其特征在于:在主控节点发出轮询应答指令之前,所述主控节点向终端设备广播被轮询终端设备列表;或者,所述被轮询终端设备列表事先存储在终端设备中。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610934309.7A CN106302032B (zh) | 2016-10-25 | 2016-10-25 | 一种点对多点轮询通讯方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610934309.7A CN106302032B (zh) | 2016-10-25 | 2016-10-25 | 一种点对多点轮询通讯方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106302032A CN106302032A (zh) | 2017-01-04 |
CN106302032B true CN106302032B (zh) | 2019-09-17 |
Family
ID=57720323
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610934309.7A Active CN106302032B (zh) | 2016-10-25 | 2016-10-25 | 一种点对多点轮询通讯方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106302032B (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107323266B (zh) * | 2017-06-23 | 2019-09-13 | 无锡锐祺通讯技术有限公司 | 一种数字化电动自行车控制调度方法 |
CN108712244B (zh) * | 2018-04-26 | 2021-08-03 | 烽火通信科技股份有限公司 | 一对多半双工通信方法及系统 |
CN111475439A (zh) * | 2020-04-08 | 2020-07-31 | 北京龙鼎源科技股份有限公司 | 基于异步传输协议的通讯控制方法及装置、电子设备 |
CN112996045B (zh) * | 2021-02-04 | 2022-11-29 | 深圳市吉祥腾达科技有限公司 | 一种mesh多频组网路径的维链包转发方法与系统 |
CN113094321B (zh) * | 2021-04-30 | 2022-04-26 | 中煤科工集团重庆研究院有限公司 | 一种基于群呼和时隙分配的rs485总线通信方法 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1565100A (zh) * | 2001-08-03 | 2005-01-12 | 库克斯媒体有限公司 | 检测及轮询下行调制解调器的方法 |
CN101093549A (zh) * | 2007-07-27 | 2007-12-26 | 北京华大恒泰科技有限责任公司 | 射频识别系统的读写器的数据读取及标签的数据发送方法 |
CN101207839A (zh) * | 2006-12-19 | 2008-06-25 | 展讯通信(上海)有限公司 | 数字对讲系统中多方通话发言权的预约切换方法 |
CN101232420A (zh) * | 2008-02-27 | 2008-07-30 | 南京新联电子股份有限公司 | 电力数据采集系统的无线组网方法 |
JP2010134550A (ja) * | 2008-12-02 | 2010-06-17 | Kenwood Corp | 基地局、移動局、無線通信システム、方法及びプログラム |
CN102026396A (zh) * | 2009-09-11 | 2011-04-20 | 原相科技股份有限公司 | 兼容于蓝牙协议且具有提升传输效率的轮询方法与系统 |
US7953056B2 (en) * | 2009-08-26 | 2011-05-31 | Pixart Imaging Inc. | Polling method compliant to bluetooth protocol for increasing transfer efficiency and system thereof |
-
2016
- 2016-10-25 CN CN201610934309.7A patent/CN106302032B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1565100A (zh) * | 2001-08-03 | 2005-01-12 | 库克斯媒体有限公司 | 检测及轮询下行调制解调器的方法 |
CN101207839A (zh) * | 2006-12-19 | 2008-06-25 | 展讯通信(上海)有限公司 | 数字对讲系统中多方通话发言权的预约切换方法 |
CN101093549A (zh) * | 2007-07-27 | 2007-12-26 | 北京华大恒泰科技有限责任公司 | 射频识别系统的读写器的数据读取及标签的数据发送方法 |
CN101232420A (zh) * | 2008-02-27 | 2008-07-30 | 南京新联电子股份有限公司 | 电力数据采集系统的无线组网方法 |
JP2010134550A (ja) * | 2008-12-02 | 2010-06-17 | Kenwood Corp | 基地局、移動局、無線通信システム、方法及びプログラム |
US7953056B2 (en) * | 2009-08-26 | 2011-05-31 | Pixart Imaging Inc. | Polling method compliant to bluetooth protocol for increasing transfer efficiency and system thereof |
CN102026396A (zh) * | 2009-09-11 | 2011-04-20 | 原相科技股份有限公司 | 兼容于蓝牙协议且具有提升传输效率的轮询方法与系统 |
Also Published As
Publication number | Publication date |
---|---|
CN106302032A (zh) | 2017-01-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106302032B (zh) | 一种点对多点轮询通讯方法 | |
EP2661050B1 (en) | Efficient firmware update in a narrow bandwidth system | |
CN103516690B (zh) | 一种业务处理状态信息查询方法及装置 | |
CN106878488A (zh) | 一种Modbus RTU总线地址自动分配方法 | |
CN108834215B (zh) | 一种适用于上行小数据包的无连接传输方法及终端 | |
CN112583677A (zh) | 一种为从设备分配地址的方法、装置、存储介质和系统 | |
CN109842919A (zh) | 一种终端与基站的通信、终端的入网方法和装置 | |
CN103716420A (zh) | Modbus ASCII从站自动获取站地址方法及从站 | |
CN102065152A (zh) | 拼接墙系统及其通信装置 | |
CN104950829A (zh) | 一种总线系统功耗控制方法及装置 | |
CN108696937B (zh) | 一种适用于上行小数据包的无连接传输方法及基站 | |
CN109150766A (zh) | 基于udp组播的局域网内动态寻址服务器的方法和装置 | |
CN112491675A (zh) | 一种数据通信方法、装置、设备及计算机可读存储介质 | |
CN107454208A (zh) | 一种为从节点设备分配网络地址的方法 | |
CN109286537B (zh) | 一种用于框式多业务板卡的板卡管理系统及管理方法 | |
CN106982156B (zh) | 优先级设置方法、装置、通信系统、设备及可读存储介质 | |
CN105024897A (zh) | Rs485总线上网络设备的扫描方法 | |
CN103974224A (zh) | 一种信用控制的方法和设备 | |
CN106254040A (zh) | 命令的应答处理方法及装置 | |
CN112512131B (zh) | 一种数据传输的省电方法及系统 | |
CN110119111B (zh) | 通信方法及装置、存储介质、电子装置 | |
CN103532850A (zh) | 一种上行报文转发方法、装置及接入点ap设备 | |
CN114520827A (zh) | 一种消息接收方法、推送方法、系统及介质 | |
CN109799758B (zh) | 一种can总线应用系统及处理节点的编号方法 | |
CN102739464B (zh) | 具服务器监视功能的客户端及方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |