Skip to main content

FastIoT Platform

Project description

Fast-IoT (fastiot)

FastIoT is a framework for rapid development of IIoT-Systems using Python as main programming language. It helps to set up a micro-service architecture and create services. The development has been started as basis for various research projects at Fraunhofer IVV, Dresden, Germany.

To get started quickly it is equipped with a powerful command line interface (CLI): fiot. This helps setting up a new project, create new services and run tests. It also supports creating cross-architecture Docker-containers and deployment configurations with docker-compose files and Ansible playbooks to bring the software to the systems they belong. Run fiot --help for a full list of features.

As for now the overall framework has only been used and tested on Linux systems.

A full documentation is available at http://docs.dev.ivv-dd.fhg.de/fastiot/_latest/

If you use this framework in your scientific projects please cite:

Konstantin Merker, Tilman Klaeger, Lukas Oehm. "A Holistic Approach for Rapid Development of IIoT Systems"“", 2022. https://doi.org/10.48550/arXiv.2201.13243.

License

Copyright 2022 Fraunhofer IVV, Dresden and contributors

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Requirements

These are the requirements you need to setup:

  • Python 3.8 or newer and the possibility to create virtual environments.

If you want to build services or do integration tests with databases or other services you also need to have a working docker setup:

  • Docker
  • docker-compose

If you want to use Ansible for deploying your services you also need to Ansible installed.

Getting started

It is always recommended to use a separate virtual environment for each project, so let’s create one: python3 -m venv venv and use it: source venv/bin/activate

Afterwards you can install FastIoT: python3 -m pip install https+git://github.com/FraunhoferIVV/fastiot.git

To setup a new project with the name my_first_project you can now run: fiot create new-project my_first_project

Within this repository you can find some sample services to use as template. Or you can simply ask the CLI to create a new services: fiot create new-service my_first_service. You should now find a service stub in your project to be extended with your application logic. The service will be added to the deployment "full" automatically.

You can now also create deployment configurations (e.g. a docker-compose.yaml) using fiot config and build containers for your project using fiot build.

As the service has been added to a deployment automatically you now start the service (with broker) with the command fiot start full. You should see the log messages from sending and receiving data. To cancel just press [Ctrl]+[C].

For a more comprehensive list of features, a guide to the project structure please refer to the complete documentation.

To run services locally, in your IDE or within a container you may also refer to the complete documentation.

Developing FastIoT

Simply check out this project and install the dependencies listed in requirements.txt. To run all tests and sample services you may also install additional packages listed in requirements-complete.txt.

Project structure

A detailed structure for all projects based on FastIoT is listed in the documentation. Here just the few most important parts are listed:

  • src/fastiot: The core library and base with CLI, message handling, …
  • src/fastiot_core_services: Core Services to use directly in any project
  • src/fastiot_sample_services: Some examples about how to write services. Maybe used as copy and paste template for own services.

Release process

Currently, and subject to change, new commits in the main-branch will rise the version number automatically and count from the last tag set.

Once the interfaces are proven to be stable, development will take place in specific dev branches and only be merged to main for a new release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fastiot-0.2.180.tar.gz (82.3 kB view details)

Uploaded Source

Built Distribution

fastiot-0.2.180-py3-none-any.whl (104.2 kB view details)

Uploaded Python 3

File details

Details for the file fastiot-0.2.180.tar.gz.

File metadata

  • Download URL: fastiot-0.2.180.tar.gz
  • Upload date:
  • Size: 82.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for fastiot-0.2.180.tar.gz
Algorithm Hash digest
SHA256 a361864e7f105f640f6c4c84fa07f85b65503540a812b38c2dc22f10fa1d6e80
MD5 4d78b1cfcd24e0c573acbf3e9399be67
BLAKE2b-256 ee35bbd0000eb610db02e5ea76edc9448e6e55bc85239f255e1103bcd73e3416

See more details on using hashes here.

File details

Details for the file fastiot-0.2.180-py3-none-any.whl.

File metadata

  • Download URL: fastiot-0.2.180-py3-none-any.whl
  • Upload date:
  • Size: 104.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for fastiot-0.2.180-py3-none-any.whl
Algorithm Hash digest
SHA256 e15956ef1832ea95d2b943bb185a75615681e7c18e650220dc8ae644fe2eb907
MD5 eca487f934258b56a12cd3bcd7bb2c8b
BLAKE2b-256 ca4de1575c6d851e8dae5fa1a6589536757c10b5a046809d8b8301dab052eace

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page