Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Table of Contents

...

Introduction

ELIOT is "Enterprise Edge Lightweight and IOT" project under Akraino approved blueprint family and part of Akraino Edge Stack, which intends to develop provide an platform  for a fully integrated edge network infrastructure and running edge computing applications, on lightweight Edge Nodes. ELIOT targets on making the edge node a lightweight software stack which can be deployed on edge nodes which have limited hardware capacity by leveraging lightweight OS, a container running environment and container orchestration applications.

In addition, ELIOT stack focuses to have an infrastructure for edge computing which will enable high performance, high availability, security and reduce latency.

Use Case

 IOT Gateway and uCPEs (universal CPE) are the  use cases which will be covered

IoT Gateway Blueprint will provide an infrastructure platform for an edge node to provide features of an IoT Gateway.  This is achieved by leveraging the upstream opensource application like Dockers, Kubernetes , Prometheus , cAdvisor, KubeEdge and EdgeX.  Companies having applications to be deployed on edge nodes related to IoT application , can use the IoT Gateway platform to have a functional end to end to ecosystem of IoT.

Use Case

1. IOT Gateway - Many diverse business applications require a converged IoT gateway. In this use case, the plan is to support the following scenarios:

...

Industry Sector: WAN edge, enterprise, diverse IoT applications in various vertical market segments, Carrier

Where on the Edge

Many diverse business applications require a converged IoT gateway. Enterprise WAN edge use of SD-WAN solutions or universal CPU (uCPE)

Business use cases:

1. IoT gateway

  • Smart cities
  • Smart homes
  • Connected vehicles
  • Connected farming, agriculture
  • Logistics
  • Industrial, IIoT

Overall Architecture

ELIOT IoT Gateway Blueprint  Architecture consists of an ELIOT Manager and multiple ELIOT Nodes (edge nodes). The scale of ELIOT (edge) Nodes can range from 1 single node to 10, 100, 10K 1K or more. For development environment we have tested with one ELIOT Manager Node and two ELIOT Worker Nodes.

ELIOT Manager is the central controller which manages the orchestration, life cycle, management and networking of edge nodes (IoT Gateway). It can be installed on a bare metal server or cloud VM with Ubuntu 16.04 /18.04 or Cent OS 7.5 version (currently supported OS in IoT Gateway Blueprint).

The node  Kubernetes Master (kubeadm, kubectl, kubelet), Kubeedge-EdgeController node ELIOT Manager  is to facilitate auto deploy, high availability, orchestration, self-healing of the ELiot Edge nodesIoT Gateway Nodes.

ELIOT Nodes - IoT Gateway are Edge compute processing nodes which will provide the software stack for deploying IoT applications.  

The IoT Gateway can function as a Kubernetes worker node or a KubeEdge - Edge node when used as Kubernetes or KubeEdge respectively.

can be on an IOT Gateway or uCPE hardware or VM's. As the edge nodes can have restricted hardware resources of CPU , Memory etc, ELIOT uses ELIOT Minimal OS for the Edge nodes which is basically tailored version of CentOS minimalCent OS.  ELIOT Minimal OS is a lightweight OS suitable for ELIOT Edge nodes.

...

Many cloud native monitoring applications can be used to collect container matrix and show them in a graphical manner, like cadvisor , grafana , prometheus.

ELIOT ArchitectureImage Removed

Platform Architecture

<Hardware components should be specified with model numbers, part numbers, etc>

prometheus.

The overall architecture In Release 2.0 is same as Release 1.0 architecture,  there are enhancements  added in the Release 2.0 which are listed below :

  • Deployment of ELIOT Platform on Tailored OS.
  • Integrated with EdgeX foundry platform.
  • Integration with OPC-UA (unified protocol framework for IoT Devices).


Note

ELIOT Minimal OS has been integrated with ELIOT - IoT Gateway Blueprint.



ELIOT IoT Gateway Bluepint ArchitectureImage Added


Image Added

Platform Architecture

ELIOT IoT Gateway is focusing on providing a platform stack on which IoT applications can be deployed, monitored and scale.  The detailed platform architecture of IoT Gateway blueprint is shown in the below diagram.

                     


Image Added

ELIOT Manager

ELIOT Portal: 

ELIOT Portal is new feature added on the ELIOT Blueprint which is currently applicable for both IoT Gateway and uCPE Blueprint. ELIOT Portal main objective is  to have a dashboard for operations and management of ELIOT Cluster. It consists of ELIOT UI and ELIOT API Gateway.

In  Release 2.0 the portal is giving the following operations:-

  1. Display ELIOT Nodes
  2. Display ELIOT Services
  3. Display ELIOT PODS. 

Other options like Application Deployments,   are currently in design phase, which will be developed for future releases.

ELIOT CLI: 

ELIOT CLI (Command Line Interface) is a new feature added in ELIOT Blueprint which is currently applicable only for IoT Gateway Blueprint.  It is providing a command line interface option to setup the ELIOT Cluster. Currently this feature is supported only for Ubuntu OS.

The ELIOT CLI application currently provides the following operations:

  1. ELIOT Cluster Setup.
  2. ELIOT Cluster Cleanup.
  3. ELIOT Cluster Reset.

Node Monitoring: 

Node Monitoring main task is to collect the container performance metrics from various IoT Gateway Nodes and display on a dashboard in graphical representation. 

Network Controller & Node Resource Manager:

The core part of the ELIOT Cluster which controls the Node health, high availability , overlay networking , cluster management. To manage the same Kubernetes and KubeEdge are being used for Node Resource Management with Calico for Container Networking.

Software Platform Architecture

ELIOT Blueprint Overall Software Stack Architecture

Image Added

ELIOT Manager

...

S. No.Software NameCategoryVersion Number
Node
Remarks
1.

Ubuntu

OS16.04
or 18.04Eliot Manager

IoT Gateway Blueprint supports both Ubuntu and Cent OS

2.CentOSOSCentOS 7 or greater
ELIOT Manager2.ELIOT Minimal OSOS

Modified

CentOS 7 Minimal

ELIOT Edge Node
IoT Gateway Blueprint supports both Ubuntu and Cent OS
3.DockerCRI18.06
4.KubernetesOrchestration1.16.0
5.Kubeedge

Orchestration/

Lightweight Kubelet

1.1.0
6PrometheusMonitoring
Running as Docker Container


ELIOT Edge Node - IoT Gateway Node

S. No.Software NameCategoryVersion NumberRemarks
1.UbuntuOS16.04IoT Gateway supports both Ubuntu and Cent OS
2.CentOSOS7 or greaterIoT Gateway supports both Ubuntu and Cent OS
3
2
.DockerCRI18.06
Eliot Manager and Eliot Edge Node3.KubernetesOrchestration1.13Eliot Manager4.Kubeedge

Orchestration/

Lightweight Kubelet

0.3Eliot Manager and Eliot Edge Node5GOOrchestrationELIOT Manager

...


4.KubernetesOrchestration1.16.0When Kubernetes is being used for the IoT Gateway Blueprint
5.Go LangRuntime Environment > 1.12Go Lang is required when KubeEdge is being used at Edge Node
6.KubeEdgeOrchestration and IoT Platform1.1.0
7.EdgeXIoT PlatformEdinburghEdgeX Platfrom. This will be running on the IoT Gateway Node
8.cAdvisorContainer MetricsLatest Container version in Docker HubRunning as Docker Container.
9.OPC-UAIoT protocol frameworkEdgex/HoldingTo Support OPC-UA Protocol.


APIs

Not Applicable

Hardware and Software Management

Currently in IoT Gateway Blueprint virtual machines are being used in public cloud. Currently no dedicated bare metal are being used.

Software Management:-

ELIOT gerrit

Licensing

  • GNU/common license