Java Clean Architecture Masterclass

Java Clean Architecture Masterclass28-29 May

Join

Github Actions Docker pulls Maven central License Last commit Apache StreamPipes Contributors GitHub commit activity GitHub issues by-label Documentation
LinkedIn X D

Apache StreamPipes Logo

Open Source Industrial IoT Data Platform

Apache StreamPipes helps teams connect industrial data sources, build real-time streaming pipelines, explore time-series data, and deliver live operational insights without requiring many different systems or custom code for every use case.

Overview

Apache StreamPipes is an end-to-end industrial IoT data platform that combines a graphical user interface for domain experts with an extensible framework for developers. It enables teams to connect industrial data sources, process real-time data streams, store historical data, and build data-driven applications on top of industrial equipment.

StreamPipes provides an opinionated architecture for managing industrial IoT data. Most users rely on StreamPipes to make data from machines, production systems, and other industrial assets available to analytics, monitoring, and application layers.

A standard StreamPipes installation includes everything needed to get started: a messaging system for real-time data exchange, with NATS as the default and support for additional protocols, as well as a time-series database for storing historical data. StreamPipes also includes a wide range of connectors tailored to industrial IoT requirements. For example, it provides extensive OPC UA support, including a web-based node browser and support for OPC UA events.

StreamPipes is fully open source, governed by the Apache Software Foundation, and includes enterprise-grade capabilities such as user and role management, OAuth 2.0 integration, and support for geographically distributed deployments that simplify communication between OT and IT networks.

As a ready-to-use platform, StreamPipes enables users to implement industrial IoT use cases on top of a reliable data foundation. Developers can extend the platform through REST APIs, client libraries for various programming languages, and an SDK for building custom connectors, processors, sinks, and application logic.

Product Tour

Feature Preview
Connect data sources with a guided setup flow StreamPipes Connect
Build stream analytics pipelines visually StreamPipes Pipeline Editor
Create beautiful charts and dashboards Charts and Dashboards
Asset-centric organization and navigation Asset Management
Administration, users, and platform operations Security and User Managemnet

Built for users

Built for developers

Quick Start

Run StreamPipes as a user

The fastest way to get a full installation with extensions is to use one of the Docker-based installers:

For most first-time users, installer/compose is the right starting point.

cd installer/compose
docker-compose up -d

After the services are up, open http://localhost to complete the setup in the browser.

Build StreamPipes as a developer

Prerequisites:

Backend build:

mvn clean package

UI build:

cd ui
npm install
npm run build

From the repository root, you can start the full stack with:

docker-compose up --build -d

This will start a development stack with no volumes! Choose the installation options from the installer page for production setups.

For backend changes, prefer targeted module validation first, for example:

mvn -pl <module> -am test

Documentation

The main documentation lives at streampipes.apache.org/docs.

Repository Structure

This repository contains the StreamPipes platform, SDKs, extensions, installers, and UI in a single monorepo. A few important entry points:

Extending StreamPipes

StreamPipes is designed to be extended. Custom processors, sinks, and data sources can be packaged as pipeline elements and deployed independently of the core platform.

The bundled extension code lives in streampipes-extensions.

Community

Get help

Or simply use Github Discussions.

To subscribe directly to a mailing list:

Contribute

Contributions are welcome across core services, UI, extensions, installers, and documentation.

Report bugs or request features

License

Apache License 2.0

Join libs.tech

...and unlock some superpowers

GitHub

We won't share your data with anyone else.