You are on page 1of 46

Communication Models in IoT (Internet of Things )

• IoT devices are found everywhere and will enable circulatory


intelligence in the future.
• For operational perception, it is important and useful to understand
how various IoT devices communicate with each other.
Communication models used in IoT have great value.
• The IoTs allow people and things to be connected any time, any
space, with anything and anyone, using any network and any service.
Types of Communication Model :

• Request & Response Model


• Publisher-Subscriber Model
• Push-Pull Model
• Exclusive Pair
Request & Response Model

This model follows a client-server architecture.
• The client, when required, requests the information from the server. This request is
usually in the encoded format.
• This model is stateless since the data between the requests is not retained and each
request is independently handled.
• The server Categories the request, and fetches the data from the database and its
resource representation. This data is converted to response and is transferred in an
encoded format to the client. The client, in turn, receives the response.
• On the other hand — In Request-Response communication model client sends a request
to the server and the server responds to the request. When the server receives the
request it decides how to respond, fetches the data retrieves resources, and prepares
the response, and sends it to the client.

Request & Response Model
Publisher-Subscriber Model

This model comprises three entities: Publishers, Brokers, and
Consumers.
• Publishers are the source of data. It sends the data to the topic which
are managed by the broker. They are not aware of consumers.
• Consumers subscribe to the topics which are managed by the broker.
• Hence, Brokers responsibility is to accept data from publishers and
send it to the appropriate consumers. The broker only has the
information regarding the consumer to which a particular topic
belongs to which the publisher is unaware of.
Publisher-Subscriber Model
Push-Pull Model
• The push-pull model constitutes data publishers, data consumers, and data
queues.
• Publishers and Consumers are not aware of each other.
• Publishers publish the message/data and push it into the queue. The
consumers, present on the other side, pull the data out of the queue. Thus,
the queue acts as the buffer for the message when the difference occurs in
the rate of push or pull of data on the side of a publisher and consumer.
• Queues help in decoupling the messaging between the producer and
consumer. Queues also act as a buffer which helps in situations where
there is a mismatch between the rate at which the producers push the data
and consumers pull the data.
Push-Pull Model
Exclusive Pair

• Exclusive Pair is the bi-directional model, including full-duplex


communication among client and server. The connection is constant
and remains open till the client sends a request to close the
connection.
• The Server has the record of all the connections which has been
opened.
• This is a state-full connection model and the server is aware of all
open connections.
• WebSocket based communication API is fully based on this model.
Exclusive Pair
IoT reference Architecture / Architecture
Reference Model (ARM)
Reference Model & Architecture
• An ARM consists of two main parts: a Reference model and a
Reference Architecture.

• •A reference model describes the domain using a number of sub-


models
IoT domain model

• The domain model captures the basic attributes of the main concepts
and the relationship between these concepts.
• A domain model also serves as a tool for human communication
between people working in the domain in question and between
people who work across different domains.
IoT domain model
Information Model

Virtual Entity in the IoT Domain Model is the “Thing” in the Internet of
Things, the IoT information model captures the details of a Virtual Entity-
centric model.
Similar to the IoT Domain Model, the IoT Information Model is presented
using Unified Modelling Language (UML) diagrams.
Information model
Relationship between core concepts of IoT
Domain Model and IoT Information Model.
Functional model

• The IoT Functional Model aims at describing mainly the Functional


Groups (FG) and their interaction with the ARM, while the Functional
View of a Reference Architecture describes the functional
components of an FG, interfaces, and interactions between the
components. The Functional View is typically derived from the
Functional Model in conjunction with high-level requirements.
Source: https://iotnotesbyparita.wordpress.com/architecture-reference-
model/#:~:text=A%20domain%20model%20also%20serves%20as%20a%20tool,have%20a%20correspondi
ng%20representation%20in%20the%20digital%20world.
References
• Chapter-5_Design_Methodology.pdf (iiita.ac.in)
• : https://iotnotesbyparita.wordpress.com/architecture-reference-
model/#:~:text=A%20domain%20model%20also%20serves%20as%20
a%20tool,have%20a%20corresponding%20representation%20in%20t
he%20digital%20world.
IoT Protocols
• IoT protocols are an integral part of the IoT technology stack.
• Without IoT protocols and standards, hardware would be deemed
useless. This is because IoT protocols enable hardware to exchange
data.
• And, out of these transferred pieces of data, useful information can
be extracted by the end-user.
What protocols do IoT-qualified devices use?

• IoT protocols and standards are broadly classified into two separate
categories. These are:
• IoT data protocols (Presentation / Application layers)
• Network protocols for IoT (Datalink / Physical layers)
IoT Data Protocols

• IoT data protocols are used to connect low-power IoT devices. They
provide communication with hardware on the user side – without the
need for any internet connection.
• The connectivity in IoT data protocols and standards is through a
wired or cellular network. Some examples of IoT data protocols are:
• MQTT (Message Queuing Telemetry Transport)
• An MQTT (Message Queuing Telemetry Transport) is a lightweight IoT data protocol. It
features a publisher-subscriber messaging model and allows for simple data flow
between different devices.
• MQTT’s main selling point is its architecture. Its genetic make-up is basic and lightweight
and, therefore, it’s able to provide low power consumption for devices. It also works on
top of a TCP/IP protocol.
• IoT data protocols were designed to tackle unreliable communication networks. This
became a need in the IoT world due to the increasing number of small, cheap, and
lower-power objects that have appeared in the network over the past few years.
• Despite MQTT’s wide adaptation – most notably as an IoT standard with industrial
applications – it doesn’t support a defined data representation and device management
structure mode. As a result, the implementation of data and device management
capabilities is entirely platform- or vendor-specific.
• MQTT has a lot of support from within the IoT community.
• Working on top of TCP/IP protocol, MQTT’s simple iot architecture has
been a game changer in an industry with an increasing number of
small, cheap, and low-power objects entering the market.
MQTT (Message Queuing Telemetry Transport)

• MQTT (message queuing telemetry transport) features a publisher-


subscriber messaging model. This model enables simple data flows
between different devices.
The Pros of MQTT The Cons of MQTT
• Doesn’t support streaming – MQTT doesn’t support
• Very lightweight – MQTT’s generic design is both streaming of any kind, either audio or video. Therefore, if
basic and lightweight. As a result, it’s able to you’re looking to stream anything on your IoT stack, you need
provide low power consumption for devices. This to look elsewhere.
is ideal for the number of smaller, lower-powered • Not ‘developer friendly’ – This is the biggest red flag when
devices that have appeared on the market over considering what IoT protocol you want to use. If you’re using
the past five years or so. an MQTT as a remote control, it’s not developer friendly at
all. Asynchronous publish-subscribe mechanisms in
• Ensures message delivery – MQTT is designed to conjunction with user interface programming can be very
ensure 100% message reliability under the worst cumbersome, i.e., when you send a command to your IoT
network conditions. What’s more, you can add device that potentially can take a long time to get a response
further message delivery reliability through its to, what do you tell the user? Do you make them wait?
three different flags (from highest to lowest) – • Latency issues – While reliability is one of the MQTT’s main
otherwise known as QOS (quality of service). strengths, speed and latency are not. If these aren’t massive
concerns for you, it shouldn’t present a problem. However, if
• Battery friendly – MQTT consumes 170 times less poor latency could have a detrimental effect on your IoT
energy on 3G networks and 47 times less energy device, it’s best to avoid MQTT for your IoT stack. The most
on Wi-Fi networks. As a result, MQTT is considered obvious examples are remote control of a drone. Even a
millisecond delay in action and video feed makes this use-
a suitable IoT protocol if you’re looking to build case impossible. Another more widespread use case is
devices that can stay connected to a battery for interaction with a video-based doorbell with audio. A delay of
years and years. seconds will be a great annoyance.
HTTP Protocol
• HTTP protocol is not preferred as an IoT standard because of its cost,
battery life, huge power consumption, and weight issues.
• That being said, it is still used within some industries. For example,
manufacturing and 3-D printing rely on the HTTP protocol due to the
large amounts of data it can publish. It enables PC connection to 3-D
printers in the network and printing of three-dimensional objects.
The Pros of HTTP The Cons of HTTP
• Addressing – HTTP uses an advanced scheme • As mentioned, some IoT developers believe
of addressing that’s extremely user friendly. It that HTTP is not suitable for use as an IoT
assigns IP addresses with recognizable protocol. Here’s why.
names. This enables them to be easily • Data integrity Issues – There aren’t
identified on the world wide web. This is any encryption methods used in HTTP. This
wildly different from the standard IP address, makes HTTP insecure and prone to data
which is just a series of numbers. integrity issues.
• The capability of processing large amounts • Data Privacy Concerns – If a hacker manages
of data – HTTP can process extremely large to intercept a request, they can view all the
quantities of data. This makes it an invaluable content present on the web page. On top of
IoT protocol within the world of that, they can also gather confidential
manufacturing and 3D printing. information present on the HTTP.
• Flexibility – HTTP has the capability to • Heavy power consumption – HTTP uses more
download extensions or plugins when system resources, which leads to more power
required, such as Flash players. consumption. This is the main reason why
• developers often recommend going with a
different protocol.
CoAP (Constrained Application Protocol)

• A CoAp (Constrained Application Protocol) is an application layer protocol.


• It’s designed to address the needs of HTTP-based IoT systems.
• HTTP stands for Hypertext Transfer Protocol, and it’s the foundation of data
communication for the World Wide Web.
• While the existing structure of the internet is freely available and usable by any
IoT device, it’s often too heavy and power-consuming for most IoT applications.
This has led to many within the IoT community dismissing HTTP as a protocol not
suitable for IoT.
• However, CoAp has addressed this limitation by translating the HTTP model into
usage in restrictive devices and network environments. It has incredibly low
overheads, is easy to employ, and has the ability to enable multicast support.
• Therefore, it’s ideal for use in devices with resource limitations, such as IoT
microcontrollers or WSN nodes. It’s traditionally used in applications involving
smart energy and building automation.
• CoAP (Constrained Application Protocol)
• CoAP (Constrained Application Protocol) is an application layer
protocol. This was designed to address the needs of HTTP-based IoT
systems.
• As mentioned before, HTTP is often considered too heavy and power
hungry for most IoT applications. CoAP has addressed this by moving
the HTTP model into usage in restrictive devices and network
environments – this gives it lower overheads while still enjoying the
easy implementation that HTTP has.
The Pros of CoAP The Cons of CoAP

• We’ve already mentioned some of the pros of • However, despite the above advantages,
choosing CoA. The good news is that there are a CoAP still has some weaknesses.
couple more to note.
• Low overheads – as mentioned before, a • Message unreliability – CoAP adds a
significant advantage of using a CoAP as an IoT method to confirm messages are
protocol is its low overheads. This means it uses received. However, this does still not
very little power and enables long battery life. verify that it was received in its entirety
• Encryption – CoAP uses a better data encryption and decoded properly.
model than HTTP and MQTT. It can be combined
with the DTLS (data transport layer security) • Issues with NAT and firewalls – CoAP can
encryption layer rather than SSL. As a result, it can have issues communicating with Network
provide greater data privacy and protection Address Translation (NAT) devices
compared to other IoT protocols. because the IP can become dynamic over
• time. For this reason, CoAP is only really
suited to devices with resource
limitations, such as IoT microcontrollers.
AMQP (Advanced Message Queuing Protocol)

• An Advanced Message Queuing Protocol (AMQP) is an open standard


application layer protocol used for transactional messages between
servers.
• The main functions of this IoT protocol are as follows:
• Receiving and placing messages in queues
• Storing messages
• Setting up a relationship between these components
• With its level of security and reliability, it’s most commonly employed in
settings that require server-based analytical environments, such as the
banking industry. However, it’s not widely used elsewhere. Due to its
heaviness, it’s not suitable for IoT sensor devices with limited memory. As a
result, its use is still quite limited within the world of the IoT.
AMQP (Advanced Message Queuing Protocol)

• An AMQP (Advanced Message Queuing Protocol) is an open standard


application layer IoT protocol.
• Developers primarily use it for transactional messages between
servers. Therefore, as you can imagine, it’s primarily used in the
banking industry.
The Pros of AMQP The Cons of AMQP

• It uses QoS to ensure message • Despite its high level of security and its
adaptability to other standards, there are
delivery – Much like MQTT, AMQP some drawbacks of the AMQP.
is extremely secure and reliable • Heaviness – The AMQP suffers from
due to the use of quality of service being extremely heavyweight. As a result,
(QoS) to ensure message delivery. it can’t be used in smaller or lower-
powered IoT devices. This is why its use
• Adaptable to other IoT within IoT remains limited and primarily
standards – AMQP has the within the banking industry.
capability of being adapted to • Not user friendly – Unlike HTTP – more
multiple IoT standards. That being on that later – AMQP is not user friendly.
This, along with its heavy weight, puts
said, it’s not very easy to do so. most developers off using it as an IoT
protocol.
DDS (Data Distribution Service)

• DDS (Data Distribution Service) is another scalable IoT protocol that


enables high-quality communication in IoT.
• Similar to the MQTT, DDS also works to a publisher-subscriber model.
• It can be deployed in multiple settings, from the cloud to very small
devices. This makes it perfect for real-time and embedded systems.
Moreover, unlike MQTT, the DDS protocol allows for interoperable
data exchange that is independent of the hardware and the software
platform.
• In fact, it’s considered the first open international middleware IoT
standard.
WebSocket

• WebSocket was initially developed back in 2011 as part of the HTML5


initiative. Via a single TCP connection, messages can be sent between
the client and the server.
• Like CoAp, WebSocket’s standard connectivity protocol helps simplify
many of the complexities and difficulties involved in the management
of connections and bi-direction communication on the internet.
• It can be applied to an IoT network where data is communicated
continuously across multiple devices. Therefore, you’ll find it used
most commonly in places that act as clients or servers. This includes
runtime environments or libraries.
IoT protocols Comparison
• Network Protocols for IoT
• Now we’ve covered IoT data protocols, we’re going to look at the
different network protocols for IoT.
• IoT network protocols are used to connect devices over a network.
These sets of protocols are typically used over the internet. Here are
some examples of various IoT network protocols.
WiFi

• There’s no denying that Wi-Fi is the most well-known IoT protocol on this list. However, it’s still worth
explaining how the most popular IoT protocol works.
• In order to create a Wi-Fi network, you need a device that can send wireless signals. These include:
• Telephones
• Computers
• Routers
• That being said, the list goes on.
• Wi-Fi provides an internet connection to nearby devices within a specific range. Another way to use Wi-Fi is
to create a Wi-Fi hotspot. Mobile phones or computers may share a wireless or wired internet connection
with other devices by broadcasting a signal.
• Wi-Fi uses radio waves that broadcast information on specific frequencies, such as 2.4 GHz or 5GHz
channels. Furthermore, both of these frequency ranges have a number of channels through which different
wireless devices can work. This prevents the overflowing of wireless networks.
• A range of 100 meters is typical of a Wi-Fi connection. That being said, the most common is limited to 10-35
meters. The main impacts on the range and speed of a Wi-Fi connection are the environment and whether it
provides internal or external coverage.
• Creating a Wi-Fi network requires devices that can send wireless signals which means devices
such as telephones, computers or routers, to name a few. At home, a router is used to transfer
the internet connection from a public network to a private home or office network. WiFi provides
an Internet connection to nearby devices that are within a certain range. Another way to use WiFi
is to create a WiFi hotspot, i.e. telephones or computers may share a wireless or wired internet
connection with other devices by broadcasting a signal.
• WiFi uses radio waves that broadcast information on specific frequencies, such as 2.4 GHz or 5
GHz channels. Both frequency ranges have a number of channels through which different wireless
devices can work, which helps to distribute the load so that the individual connections of the
devices are not interrupted. This largely prevents overflowing of wireless networks.
• A range of 100 meters is the typical range of a standard WiFi connection. The most common
range, however, is limited to 10-35 meters. The effective network coverage is greatly affected by
antenna strength or transmission frequency. The range and speed of a WiFi Internet connection
depends on the environment and whether it provides internal or external coverage. Thus, the
speed of various devices using the WiFi internet connection increases as the computer
approaches the main source, while the speed decreases as the computer moves away from the
source.
• Bluetooth
• When compared to other IoT network protocols listed here, Bluetooth tends to
frequency hop and has a generally shorter range.
• However, it’s gained a huge user base due to its integration into modern mobile
devices – smartphones and tablets, to name a couple – as well as wearable
technology, such as wireless headphones.
• Standard Bluetooth technology uses radio waves in the 2.4 GHz ISM frequency
band and is sent in the form of packets to one of 79 channels. However, the latest
Bluetooth 4.0 standard has 40 channels and a bandwidth of 2Mhz. This
guarantees a maximum data transfer of up to 3 Mb/s.
• This new technology is otherwise known as Bluetooth Low Energy (BLE) and can
be the foundation for IoT applications that require significant flexibility,
scalability, and low power consumption.
• ZigBee
• ZigBee-based networks are similar to Bluetooth in the sense that it already
has a significant user base in the world of IoT.
• However, it’s specifications slightly eclipse the more universally used
Bluetooth. It has lower power consumption, low data-range, high security,
and has a longer range of communication (ZigBee can reach 200 meters,
while Bluetooth maxes out at 100 meters)
• It’s a relatively simple packet data exchange protocol and is often
implemented in devices with small requirements, such as microcontrollers
and sensors. Furthermore, it easily scales to thousands of nodes. This
makes it no surprise that many suppliers are offering devices that support
ZigBee’s open standard self-assembly and self-healing grid topology
model.
• Z-Wave
• Z-Wave is an increasingly-popular IoT protocol. It’s a wireless, radio
frequency (RF) cased communication technology that’s primarily used for
IoT home applications.
• It operates on the 800-900MHz radiofrequency. On the other hand, Zigbee
operates on 2.4GHz, which is also a major frequency for Wi-Fi. By operating
in its own range, Z-Wave rarely suffers from any significant interference
problems. However, the frequency that Z-Wave devices operate on is
location dependent, so make sure you buy the right one for your country.
• Z-Wave is an impressive IoT protocol. However, like ZigBee, it’s best used
within the home and not within the business world.
• LoRaWAN
• LoRaWAN is a media access control (MAC) IoT protocol.
• LoRaWAN allows low-powered devices to communicate directly with
internet-connected applications over a long-range wireless
connection.
• Moreover, it has the capability to be mapped to both the 2nd and 3rd
layer of the OSI model.
• It’s implemented on top of LoRa or FSK modulation for industrial,
scientific, and medical (ISM) radio bands.
• Pros and cons https://www.nabto.com/mqtt-protocol-iot/
• COMMUNICATION OF PROTOCOLS :
• https://www.nabto.com/iot-protocols-comparison/
• https://www.nabto.com/guide-iot-protocols-standards/

You might also like