Methods for Using Message Queuing Telemetry Transport for Sensor Networks to Support Sleeping Devices
Methods support a sleep mode for an embedded device. Embedded devices like sensors and actuators used in wireless sensor networks have a limited power supply. To conserve energy and thus increase the lifetime of these devices, the devices should be put into a stand-by mode (also called sleep-mode) when they are not used. These methods support the sleep mode at a higher level than the MAC layer, thus avoiding the problems of prior art approaches. Methods are exemplarily described for the case of the message queuing telemetry transport protocol for sensor networks. They can easily be adapted to other protocols.
BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention generally relates to support of sleeping devices on wireless sensor networks, and more particularly, to methods for using message queuing telemetry transport for sensor networks (MQTT-S) to support sleeping devices.
2. Description of Background
Wireless sensor networks (WSNs) are gaining increased attention because of their potential for enabling novel and attractive solutions in areas such as industrial automation, asset management, environmental monitoring, and transportation. In many of these applications, sensors remain idle for long periods of time if no sensing event occurs. In the context of WSNs, these sensors include transmitters capable of transmitting sensed information using radio frequency (RF) energy. To save as much energy as possible, it would be desirable for sensors to turn off their transmitters and sleep during idle times. Sensors would need to wake up only when they have acquired new information to send.
Message queuing telemetry transport (MQTT) is a published protocol designed for use with simple devices such as sensors and actuators (SAs). MQTT-S is an extension of MQTT to sensor networks. MQTT-S is designed to operate in conjunction with low-cost, low-power SA devices running over bandwidth constrained WSNs such as Zigbee-based networks. Zigbee is an open, global standard for WSNs based on the IEEE 802.15.4 standard. Essentially, Zigbee adds networking, security, and application support functionalities to IEEE 802.15.4, with the aim of providing interoperability between products from different vendors. Zigbee and IEEE 802.15.4 are designed such that implementation on the client side (i.e., the SA side) is comparatively simple relative to implementation on the broker side.
MQTT and MQTT-S support basic end-to-end Quality of Service (QoS). Depending upon how reliably messages should be delivered to their receivers, they distinguish between three QoS levels. QoS level 0 is the simplest level. It offers a best effort delivery service, in which messages are delivered either once, or not at all, to a destination. No retransmission or acknowledgement is defined. Thus, QoS level 0 is appropriate for applications which can tolerate loss of a few messages. QoS level 1 provides a more reliable transport: messages with QoS level 1 are retransmitted until they are acknowledged by a receiver at the destination. Consequently, QoS level 1 messages are certain to arrive, but they may arrive multiple times at the destination because of the retransmissions. The highest QoS level, level 2, ensures not only the reception of messages, but also that they are delivered only once to the destination. It is up to an application to select an appropriate QoS level for its publications and subscriptions. For example, a temperature-monitoring application could decide to use QoS level 0 for the publication of normal and regular measurement reports, but QoS level 1 for transferring alarm messages when the temperature exceeds a certain threshold.
MQTT and MQTT-S are connection-oriented protocols in the sense that they require a client to set up a connection with the broker before the client can exchange publications and subscriptions with the broker. To this end, a CONNECT message is defined which contains a Client ID. The Client ID enables the broker to identify the connected client, and also to ensure that QoS level 1 and level 2 publications are delivered correctly even when the client reconnects after a network failure. The broker supervises the level of activity of the client connection using a keep-alive timer that defines the maximum allowable time interval that may elapse between two messages received from that client. If, during this time interval, the client has no data-related messages to be transmitted, the client has to send a PINGREQ message to the broker which is then acknowledged by the broker. Thus, the keep-alive timer enables the broker to detect a failure of either the client or a network link. A related feature is the support of the so-called Will concept. At connection time, the client may ask the broker to store a Will message together with a Will topic. The broker sends this Will message as a publication to subscribers when the broker loses its connection with the client by the keep-alive timer timing out. Applications could use this feature to detect persistent failures of links and devices.
There is a very important feature that is not supported by the current MQTT/MQTT-S protocol, namely the handling of duty cycles of the client devices. In many sensor applications, the sensor devices are idle for a long time if no sensing event occurs. To save as much energy as possible, it would be desirable for the client devices to enter a sleep mode when they are not used. The clients can wake up and publish data whenever the clients acquire new data. However, existing publish/subscribe protocols do not support sleeping devices. In the context of WSNs, support for sleeping devices has heretofore only been provided at the media access control (MAC) layer. Thus, prior art methods place a device into a sleep-mode state using protocols at a very low level. This causes problems as the upper protocol levels are unaware of these state changes.
It is difficult or impossible to utilize MAC-based sleep control mechanisms in networks where the broker is not connected directly to a wireless network, but instead connected through a gateway or router. Although a router could be used to buffer messages until a client device wakes up, the sleeping time could be quite long, on the order of several minutes to several hours. Since the router may serve a large number of clients, the number of messages to be buffered could easily exceed the storage capacity of the router. Moreover, as mentioned previously, in the case of QoS levels 1 and 2, the broker or gateway needs to receive an acknowledgment from the client to be sure that the client has correctly received a published message. It would not be possible to support QoS levels 1 and 2 if the published messages were to be stored for a long time at a router. In view of the foregoing shortcomings, what is needed is an improved technique for supporting sleeping devices on a WSN.
SUMMARY OF THE INVENTION
Methods for using message queuing telemetry transport for sensor networks (MQTT-S) to support a sleeping client device on a wireless sensor network operatively coupled to a broker through a gateway, the methods comprising the broker receiving a CONNECT message from the client device, the CONNECT message specifying a client identifier and a keep-alive duration; monitoring the client device using a keep-alive timer set to the keep-alive duration wherein, if the broker does not receive a message from the client device for a period longer than the keep-alive duration, the broker associates the client device with a lost status and activates a will feature for that client device; the broker receiving a DISCONNECT message from the client device, the DISCONNECT message specifying a sleep duration; the broker acknowledging receipt of the DISCONNECT message to the client device; the broker associating the client device with an asleep status wherein, if the broker does not receive any message from the client device for a period longer than the sleep duration, the broker associates the client device with a lost status and activates the will feature and wherein, during the asleep status, the broker stores any messages for the client device as buffered messages; the broker receiving a PINGREQ message from the client device, the PINGREQ message specifying the client identifier, and in response to receipt of the PINGREQ message, associating the client device with an awake status; wherein, if the broker has no buffered messages for the client, the broker sends a PINGRESP message to the client device and associates the client device with the asleep status; wherein, if the broker has one or more buffered messages for the client device, the broker sends the one or more buffered messages to the client device upon receipt of the PINGREQ message by the broker; and wherein, after the one or more buffered messages are sent to the client device, the broker sends a PINGRESP message to the client device and associates the client device with the asleep status.
DETAILED DESCRIPTION OF THE INVENTION
FIG. 1 is a block diagram setting forth an illustrative wireless sensor network (WSN) for use with the methods of the present invention. A traditional network 100, such as a local area network (LAN), wide area network (WAN), Ethernet, or wireless network, includes a broker 130 to which a plurality of applications 121, 122, 123 are connected. The broker 130 is operatively coupled to a first WSN 101 via a first gateway 140. The broker130 is operatively coupled to a second WSN 102 via a second gateway 150. The first WSN 101 includes a plurality of sensors 181, 182, 183, 184,185 operatively coupled to the first gateway 140 over one or more wireless links. First WSN 101 also includes an actuator 161. The sensors 181,182, 183, 184, 185 and the actuator 161 each represent client devices. Similarly, the second WSN 102 includes a plurality of sensors 171, 172,173, 174, 175 operatively coupled to the second gateway 150 over one or more wireless links. The second WSN 102 also includes an actuator 162. The sensors 171, 172, 173, 174, 175 and the actuator 162 each represent client devices.
Due to the fact that the broker 130 is not connected directly to the first WSN 101 or the second WSN 102, prior art techniques for supporting sleeping devices cannot be used. If the first and second WSNs 101, 102 were based upon the IEEE 802.15.4 or Zigbee standard, the first gateway140 or the second gateway 150 could be used to buffer messages until a client device to which the message is directed wakes up. However, as the sleeping times of client devices could be very large (on the order of several minutes to several hours) and a gateway 140, 150 may serve a large number of clients, problems will result. As time goes by, the number of messages to be stored may exceed the capacity of the gateway 140, 150. Moreover, as mentioned previously, QoS levels 1 and 2 require the gateway 140, 150 or the broker 130 to receive an acknowledgment from the client device to be sure that the client has correctly received the published message. It would not be possible to support QoS levels 1 and 2 if the published messages were to be stored for a long time on the gateway 140, 150. Accordingly, pursuant to an illustrative embodiment disclosed herein, at least one of the gateway 140, the gateway 150, or the broker 130 are made aware of one or more sleeping times of a client device, and to store messages for the client device during the one or more sleeping times.
FIG. 2 illustrates an exemplary message flow between a client 201 and a gateway/broker 203 for implementing the methods of the present invention, and FIG. 6 is a state diagram describing the manner in which a broker sees the state of a client. Client 201 may represent any of sensors 171, 172,173, 174, 175, 181, 182, 183, 184, 185, or actuators 161, 162 (FIG. 1). Likewise, gateway/broker 203 (FIG. 2) may represent any of the broker 130, the first gateway 140, or the second gateway 150 (FIG. 1). From the perspective of the gateway/broker 203 (FIG. 2), a client 201 may be in one of the following states: client active 205 (FIGS. 2 and 6), client asleep 207, client awake 209, client lost 211, or client disconnected 213. A client 201 is in the active 205 state when the gateway/broker 203 receives a first message from that client 201, illustratively in the form of a CONNECT 215message. As with the current MQTT/MQTT-S protocol specification, the active 205 state is supervised by the gateway/broker 203 using a keep-alive timer, also referred to as a sleep timer. If the gateway/broker 203 does not receive any message from the client 201 for a period longer than a keep-alive time duration determined by the keep-alive timer (as indicated in the CONNECT 215 message), the gateway/broker 203 will consider that client 201 as being in the client lost 211 state and, for example, activates the will feature for that client 201.
A client 201 goes to the client disconnected 213 state when the gateway/broker 203 receives a second message from that client 201, illustratively in the form of a DISCONNECT 217 message without a sleep duration indication. The disconnected 213 state is not time-supervised by the gateway/broker 203. If a client 201 wants to sleep, the client 201 sends a DISCONNECT 217 message which contains a sleep duration. The gateway/broker 203 acknowledges that message with a DISCONNECT 217 message and considers the client 201 for being in the asleep 207 state. The asleep 207 state is supervised by the gateway/broker 203 with the aforementioned sleep duration. If the gateway/broker 203 does not receive any message from the client 201 for a period longer than the sleep duration, the gateway/broker 203 will consider that client 201 as being in the lost211 state. Accordingly, as with the keep-alive procedure discussed previously, the gateway/broker 203 may activate the will feature for the lost client 201. During the asleep 207 state, all messages that need to be sent to the client are buffered at the broker/gateway.
The time "tolerance" of the sleep supervision at the gateway/broker 203 depends upon the value of the sleep duration. For example, the current MQTT implementation has a tolerance of 10% of the time for durations larger than one minute, and 50% if less.
The keep-alive timer is restarted when the gateway/broker 203 receives a third message, such as a PINGREQ 219 message, from the client 201. Like the CONNECT 215 message, the PINGREQ 219 message contains a client identifier (i.e., a client ID) identifying the client 201. The client 201is then in the awake 209 state. If the gateway/broker 203 does not have any messages buffered for the client 201, the gateway/broker 203 answers the PINGREQ 219 message with a fourth message, such as a PINGRESP 221 message, and returns the client 201 to the asleep 207 state. If the gateway/broker 203 has one or more messages for the client 201, then the broker/gateway 203 sends these one or more messages to the client201 when the gateway/broker 203 receives the PINGREQ 219 message. The transfer of messages is closed by the gateway/broker 203 by means of the PINGRESP 221 message. In other words, the gateway/broker 203 will consider the client 201 as being in the asleep 207 state after having sent the PINGRESP 221 message.
After having sent the PINGREQ 219 message to the gateway/broker 203, the client 201 uses a Tretry timer to supervise the arrival of messages sent by the gateway/broker 203. Essentially, the client 201 starts the Tretry timer when the client 201 receives any message other than a PINGRESP 221message, and stops the Tretry timer when it receives the PINGRESP 221 message. The PINGREQ 219 message is retransmitted and the Tretry timer is started when the Tretry timer times out. To avoid unnecessary current drain in situations where the client 201 is powered by a battery, the client201 may limit the retransmission of the PINGREQ 219 message. One illustrative method for limiting retransmission of the PINGREQ 219 message is by using a retry counter that initiates putting the client 201 back to sleep when a retry limit count of the retry counter is reached and the client still does not receive the PINGRESP 221 message.
From the asleep 207 state or the awake 209 state, a client 201 can return either to the active 205 state by sending a CONNECT 215 message, or to the disconnected 213 state by sending a DISCONNECT 217 message with no duration field included. The client 201 can also modify its sleep duration by sending a DISCONNECT 217 message with a duration field that specifies a new value of the sleep duration.
FIG. 3 describes the meanings of several symbols used in the flowchart of FIGS. 4-5. A first symbol 10 is used to represent a program state. A second symbol 20 is used to represent internal processing. A third symbol 30 is used to represent a timeout or an internal event. A fourth symbol 40is used to represent a sending of a message. A fifth symbol 50 is used to represent a receiving of a message. A sixth symbol 60 is used to represent a decision.
FIGS. 4-5 together comprise a flowchart setting forth an illustrative operational sequence performed by a sleeping client 201 (FIG. 2) where the client first connects to a broker (such as gateway/broker 203) and then initiates a sleep state. Essentially, FIGS. 4-5 depict a state diagram for the client 201 (FIG. 2) in the context of the sleeping methodology previously described with reference to FIGS. 2 and 6. While in the sleep state, the client interacts periodically with the broker to tell the broker that the client is still available, and possibly to receive updates from the broker.
Referring to block 401 of FIG. 4, the client first connects to a gateway/broker 203 (FIG. 2), waits to receive an acknowledgment of the connection from the gateway/broker (FIG. 4, block 403), and either times out (block 407) while waiting for the acknowledgment, or receives the acknowledgment (block 405). If the time out occurs (block 407), a decision is made at block 409 to either try again by looping back to block 401, or to not try again by advancing ahead to block 423 where the gateway/broker is considered to be lost.
If the acknowledgment is received (block 405), the procedure advances to block 411 where the client goes into the active state. The client sends a DISCONNECT message that includes a sleep duration to the broker (block 413). The procedure temporarily remains in a wait DISCONNECT state (block 415), and either times out (block 419) or receives a DISCONNECT message (block 417). If the time out occurs (block 419), a decision is made at block 421 to either try again by looping back to block 413, or to not try again by advancing ahead to block 423 where the gateway/broker is considered to be lost. If the DISCONNECT message is received (block 417), the client enters the asleep state, also referred to as "sleeping mode" (block 425).
Referring now to block 501 (FIG. 5), the client enters the asleep state (i.e., sleep mode). At block 503, a transponder or transceiver (i.e., a radio) of the client is turned off. The client sleeps at block 505. A timeout occurs at block 507. The radio is turned on at block 509. A PINGREQ message is sent at block 511. At block 513, the client waits for a PINGRESP message. A timeout may occur (block 517), or a PINGRESP message may be received by the client (block 519), or another message may be received by the client (block 521). If the time out occurs (block 517), a decision is made at block 523 to either try again by looping back to block 511, or to not try again by advancing ahead to block 527 where the gateway/broker is considered to be lost. If the PINGRESP message is received (block 519), the procedure loops back to block 501. If another message is received by the client (block 521), then the client deals with this message (block 525), and the procedure loops back to block 513.
The procedures described with reference to FIGS. 2-6 permit one or more clients (such as client 201) to be easily implemented by low cost sensor devices. These procedures release gateways 140, 150 (FIG. 1), which are illustratively implemented using wireless routers, from buffering messages for the sleeping devices, thus allowing the routers to serve large numbers of sensor devices which may have relatively lengthy sleeping periods. The gateway/broker 203 (FIG. 2) is able to detect the loss of a client device (e.g., a persistent failure) not only while the client device is actively communicating, but also while the client device is sleeping.
SRC=http://www.freepatentsonline.com/y2009/0172117.html
Methods for Using Message Queuing Telemetry Transport for Sensor Networks to Support Sleeping Devices的更多相关文章
- Message Queuing(MSMQ)
一.前言 MicroSoft Message Queuing(微软消息队列)是在多个不同的应用之间实现相互通信的一种异步传输模式,相互通信的应用可以分布于同一台机器上,也可以分布于相连的网络空间中的任 ...
- Advanced Message Queuing Protocol ( 1 ) 概述
The Advanced Message Queuing Protocol (AMQP)是一个标准开放的应用层的消息中间件(Message Oriented Middleware)协议.AMQP定义了 ...
- AMQP(Advanced Message Queuing Protocol)
一套确定的消息交换功能,也就是“高级消息交换协议模型”.AMQP模型包括一套用于路由和存储消息的功能模块,以及一套在这些模块之间交换消息的规则. 一个网络线级协议(数据传输格式),客户端应用可以通过这 ...
- Index
我主要在研究.NET/C# 实现 PC IMERP 和 Android IMERP ,目的在解决企业通信中遇到的各类自动化问题 分布式缓存框架: Microsoft Velocity:微软自家分布 ...
- Mosquitto搭建Android推送服务(一)MQTT简介
总体概要: MQTT系列文章分为4部分 1.MQTT简介 2.mosquitto服务器搭建 3.编写Mosquitto的可视化工具 4.使用Mosquitto完成Android推送服务 文章钢要: 对 ...
- TCP/IP, WebSocket 和 MQTT
按照OSI网络分层模型,IP是网络层协议,TCP是传输层协议,而HTTP和MQTT是应用层的协议.在这三者之间, TCP是HTTP和MQTT底层的协议.大家对HTTP很熟悉,这里简要介绍下MQTT.M ...
- GitHub上整理的一些工具
技术站点 Hacker News:非常棒的针对编程的链接聚合网站 Programming reddit:同上 MSDN:微软相关的官方技术集中地,主要是文档类 infoq:企业级应用,关注软件开发领域 ...
- GitHub上整理的一些工具[转载]
Source:http://segmentfault.com/q/1010000002404545 技术站点 Hacker News:非常棒的针对编程的链接聚合网站 Programming reddi ...
- MQTT for UWP
老规矩,先简单介绍下MQTT: MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议,有可能成为物联网的重要组成部分.该协 ...
随机推荐
- Testfan软件测试社区
1. http://ask.testfan.cn/article/902 Appium 服务端安装-windows2. http://ask.testfan.cn/article/1078 最新 ...
- Web--CSS控制页面(link与import方式差别)
先了解: [1] "Table"和"DIV"这两个网页元素诞生的目的不同,首先Table诞生的目的是为了存储数据,而DIV诞生的目的就是 ...
- C# AutoMapper
http://www.cnblogs.com/xlhblogs/p/3356748.html
- 过滤input框中的特殊字符
两种方式,我觉得是一样的效果,请看: var charFilter1 = function(str) { var pattern = new RegExp("[`~!@#$^&*() ...
- 【BZOJ 2754】[SCOI2012]喵星球上的点名
[链接]h在这里写链接 [题意] n个人; 由姓和名组成.s1[i]和s2[i]; 有m个询问串. 问你第j个询问串,是否为某个人的姓或者名的子串. 如果是的话 ...
- 【转】移动Web开发-点击事件及页面滚动
点击事件 移动端浏览器点击事件默认有300ms的延迟 移动端实现弹性滚动 安卓局部滚动 滚动条出现bug,解决方案:Android只是用全局滚动 模拟全局滚动,加上padding-top及paddin ...
- spring里头各种获取ApplicationContext的方法
为啥写这个文章呢?spring各个版本不同,以及和系统框架套在一起不同,导致获取的方式不同,网络上各种版本,太乱了,写获取方式的人都不写这个获取方式是在本地还是在WEB,在那种应用服务器下,在spri ...
- ASCII,Unicode和UTF-8终于找到一个能完全搞清楚的文章了
前言 平时喜欢写东西,看博客,一直对编码有些懵,今天下午也不知道看到了什么,突然想了解下,就找到了这个文章,看完真的豁然开朗,这个必须留下来做纪念. 点击打开链接 1.ASCII 我们知道,计算机内部 ...
- vs 2013 常用快捷键及常见问题的解决
1. 代码编辑 关闭当前文档:ctrl + F4 打开光标所在位置的文档:ctrl + G(shift + g) 返回上次编辑的位置:ctrl + -(键盘数字键 0 后的那个按键) 移动光标所在的行 ...
- Android的NDK开发(1)————Android JNI简介与调用流程
1.JNI简介 JNI全称为Java Native Interface(Java本地调用).从Java1.1开始,JNI成为java平台的一部分,它允许Java代码和其他语言写的代码(如C&C ...