GithubHelp home page GithubHelp logo

isabella232 / industrial-iot Goto Github PK

View Code? Open in Web Editor NEW

This project forked from azure/industrial-iot

0.0 0.0 0.0 67.41 MB

Azure Industrial IoT Platform

License: MIT License

Batchfile 0.12% Shell 0.12% C# 98.70% JavaScript 0.05% ANTLR 0.05% PowerShell 0.92% HTML 0.05%

industrial-iot's Introduction

Azure Industrial IoT Platform

License: MIT Build Status

Welcome!

The Azure Industrial IoT Platform is a Microsoft product that has fully embraced openness. We use Azure's managed Platform as a Service (PaaS) services, open-source software leveraging the MIT license throughout, open international standards for communication (OPC UA, MQTT) and interfaces (Open API) and open industrial data models (OPC UA) on the edge and in the cloud.

Discover, register and manage your industrial assets with Azure

The Azure Industrial IoT Platform allows you to discover industrial assets on-site and automatically registers them in the cloud for easy access there. It leverages managed Azure PaaS services. On top of the Azure PaaS services, we have built a number of edge and cloud micro-services that must be used together, leveraging OPC UA as the data model. This is also the first cloud platform to leverage the OPC UA PubSub telemetry format (both JSON and binary, on top of MQTT). If your assets don't support OPC UA as an interface, we have worked with our large partner network to support all types of industrial interfaces through the use of adapters, fully integrated with our platform. Please check out the Azure IoT Edge Marketplace. So far, we support modules from Softing and CopaData.

An overview architecture is depicted below:

diagram

The edge services are implemented as Azure IoT Edge modules and run on on-premises. The cloud services are implemented as ASP.NET micro-services with a REST interface and run on managed Azure Kubernetes Services (currently in preview) or stand-alone on Azure App Service. For both edge and cloud services, we have provided pre-built Docker containers in the Microsoft Container Registry (MCR), so you don't have to build them yourself. The edge and cloud services are leveraging each other and must be used together. We have also provided easy-to-use deployment scripts that allow you to deploy the entire platform in a step-by-step fashion.

We have also built an application running on Azure that lets you access the services through a simple UI.

Getting started

Clone the repository:

git clone https://github.com/Azure/Industrial-IoT
cd Industrial-IoT

Start the deployment

On Windows:

.\deploy -version <version>

On Linux:

./deploy.sh -version <version>

For more information, see the detailed instructions and additional deployment options.

Learn more

What you get when you deploy the platform

The minimal deployment script deploys the following managed Azure services into your Azure subscription:

  • 1 IoT Hub with 4 partitions, S1 SKU (to communicate with the edge and ingress raw OPC UA telemetry data)
  • 1 Key Vault, Premium SKU (to manage secrets and certificates)
  • 1 Service Bus, Standard SKU (as integration event bus)
  • 1 Event Hubs with 4 partitions and 2 day retention, Standard SKU (contains processed and contextualized OPC UA telemetry data)
  • 1 Cosmos DB with Session consistency level (to persist state that is not persisted in IoT Hub)
  • 1 Blob Storage V2, Standard LRS SKU (for event hub checkpointing)

Azure Kubernetes Services should be used to host the cloud micro-services (this is currently in preview, please see our documentation).

Alternatively, the full deployment script deploys the following additional managed Azure services into your Azure subscription and deploys the cloud micro-services into an App Service instance:

  • 1 Data Lake Storage V2, Standard LRS SKU (used to connect Power BI to the platform, see tutorial)
  • 1 Time Series Insights, Pay As You Go SKU, 1 Scale Unit
  • 1 Blob Storage V2, Standard LRS SKU (used for long-term storage for Time Series Insights)
  • 2 App Service, B1 SKU (for hosting the Industrial IoT Engineering Tool cloud application and for hosting the cloud micro-services all-in-one)
  • 1 SignalR, Standard SKU (used to scale out asynchronous API notifications)
  • 4 Virtual Machines, 2 B2 SKU (1 Linux IoT Edge gateway and 1 Windows IoT Edge gateway) and 2 B1 SKU (used for a factory simulation to show the capabilities of the platform and to generate sample telemetry)
  • 1 Device Provisioning Service, S1 SKU (used for deploying and provisioning the simulation gateways)
  • 1 Application Insights and 1 Log Analytics Workspace for Operations Monitoring

Give feedback and report bugs

Please report any security related issues by following our security process.

Please enter all other bugs, feature requests, documentation issues, or suggestions as GitHub issues.

Contribute

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.

If you want/plan to contribute, we ask you to sign a CLA (Contribution License Agreement) and follow the project 's code submission guidelines. A friendly bot will remind you about it when you submit a pull-request.

License

Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT License.

industrial-iot's People

Contributors

bamajeed avatar banchio avatar barnstee avatar cindyxing avatar coconut147 avatar cristipogacean avatar dacolgit avatar dependabot[bot] avatar dovjar avatar faister avatar hansgschossmann avatar jmayrbaeurl avatar karok2m avatar katriendg avatar khilscher avatar koepalex avatar luiscantero avatar maidab avatar marcschier avatar markusstuhler avatar microsoftopensource avatar monikavar avatar mregen avatar msftgits avatar oliverchristen avatar rangedsp avatar sebader avatar sjai013 avatar tamaskleizer avatar ytechie avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.