I have grasped the general idea, but, I would like to understand the distinctions between Kura and Kapua.
If you’re planning to create an IoT gateway, then Kura could be a good option to consider. However, if you’re looking for a more complete IoT platform that can help you manage your devices and data, then Kapua might be a better choice for you.
Well, I hope that sorted out the confusion in your noggin!
Kura and Kapua are complementary. A complete solution will actually include both.
Sure, I agree with you. Eclipse Kura is focused on building IoT gateways, while Eclipse Kapua is focused on managing and analyzing data from IoT devices in the cloud. Both platforms can be used together to build a complete end-to-end IoT solution.
To give a practical example, consider a scenario where you want to build an IoT solution for monitoring the temperature and humidity levels in a greenhouse. You could use Eclipse Kura to build the gateway that collects data from the sensors and sends it to the cloud for analysis. Eclipse Kapua could then be used to manage the devices, store the data, and generate alerts if the temperature or humidity levels exceed a threshold.
In simple words, Kura is a framework for IoT gateways that provides the edge functionality while Kapua is a platform that provides a solution for managing IoT devices, and their data by cloud-based IoT services.
Kapua provides a cloud-based IoT integration platform with the following high-level functionality:
- Manages the connectivity for IoT devices and IoT gateways through a number of different protocols. Initial support will be offered to established IoT protocols like MQTT. Other protocols like AMQP, HTTP, and CoAP will be added over time. The connectivity layer is also responsible for managing device authentication and authorization.
- Manages the devices on the edge. Device management offers the ability to inspect device configuration, update device applications and firmware, and control the device remotely. The IoT platform exposes an open contract towards the target device being managed with no assumption on the device software stack. The device management will evolve to adopt emerging standard device management protocols like LWM2M.
- Data pipelines for data from IoT devices collecting large amounts of telemetry data. The data pipelines can offer data archival for dashboards or business intelligence applications andenable real-time analytics and business rules. An important feature is flexible and configurable data integration routes offering data storage options to collect the incoming data and make it available to upstream enterprise applications.
- Multi-tenant account management, user management, permissions and roles.
- Fully programmable via the RESTful API. A web-based administration console for a device operator is desirable.
Kura is a Java/OSGi-based container for M2M applications running in service gateways. Kura provides or, when available, aggregates open source implementations for the most common services needed by M2M applications. Kura components are designed as configurable OSGi Declarative Service exposing service API and raising events. While several Kura components are in pure Java, others are invoked through JNI and have a dependency on the Linux operating system.
Kura is currently planning this initial set of services:
- I/O Services
- Serial port access through javax.comm 2.0 API or OSGi I/O connection
- USB access and events through javax.usb, HID API, custom extensions
- Bluetooth access through javax.bluetooth or OSGi I/O connection
- Position Service for GPS information from a NMEA stream
- Clock Service for the synchronization of the system clock
- Kura API for GPIO/PWM/I2C/SPI access
- Data Services
- Store and forward functionality for the telemetry data collected by the gateway and published to remote servers.
- Policy-driven publishing system, which abstracts the application developer from the complexity of the network layer and the publishing protocol used. Eclipse Paho and its MQTT client provides the default messaging library used.
- Cloud Services
- Easy to use API layer for M2M application to communicate with a remote server. In addition to simple publish/subscribe, the Cloud Service API simplifies the implementation of more complex interaction flows like request/response or remote resource management.
- Allow for a single connection to a remote server to be shared across more than one application in the gateway providing the necessary topic partitioning.
- Configuration Service
- Leverage the OSGi specifications ConfigurationAdmin and MetaType to provide a snapshot service to import/export the configuration of all registered services in the container.
- Remote Management
- Allow for remote management of the M2M applications installed in Kura including their deployment, upgrade and configuration management. The Remote Management service relies on the Configuration Service and the Cloud Service.
- Networking
- Provide API for introspects and configure the network interfaces available in the gateway like Ethernet, Wifi, and Cellular modems.
- Watchdog Service
- Register critical components to the Watchdog Service, which will force a system reset through the hardware watchdog when a problem is detected.
- Web administration interface
- Offer a web-based management console running within the Kura container to manage the gateway.
Actually, the main difference between the two can be their focus and scope within the IoT system architecture. Kura is primarily focused on the edge computing layer of the IoT system, what i mean is that you are processing data locally before sending it to the cloud. additionally, like it can help you like a framework in building IOT gateways that you can connect to different types of IoT devices. but take the first one as the main distinction which is the data process.
On the other hand, Kapua is focused on like cloud based instead of local, so you are managing and analyzing the data collected from the edge devices. it provides a cloud platform for managing IoT devices, storing and processing data you need, and integrating with other cloud services. i hope it helps you.
Yeah, Kura is ideal for building IoT applications on edge devices and gateways, while Kapua excels in managing IoT devices and data in the cloud. Both platforms provide APIs and can be customized and integrated with other Eclipse IoT projects, making them highly flexible. When used together, Kura and Kapua offer complete IoT solutions, from edge to cloud.
Kura and Kapua are two separate open-source projects in the field of Internet of Things (IoT) and Industrial Internet of Things (IIoT) technologies.
Kura: Kura is an open-source Java/OSGi-based framework that provides a set of libraries and APIs for building IoT gateways. It is part of the Eclipse IoT project and is designed to simplify the development, deployment, and management of IoT edge devices. Kura enables communication between IoT devices and cloud platforms, as well as integration with various IoT protocols and technologies.
Kapua: Kapua is another open-source project within the Eclipse IoT ecosystem. It is an IoT integration platform that focuses on managing and integrating IoT data and devices. Kapua provides features such as device management, data collection, protocol integration, and cloud connectivity. It aims to streamline the process of connecting, configuring, and monitoring IoT devices in a scalable and secure manner.
Both Kura and Kapua are part of the Eclipse IoT ecosystem and are actively maintained by the Eclipse Foundation, an open-source software organization. These projects are intended to provide developers with tools and frameworks to build robust and scalable IoT solutions.