All Projects → spring-cloud → Spring Cloud Dataflow

spring-cloud / Spring Cloud Dataflow

Licence: apache-2.0
A microservices-based Streaming and Batch data processing in Cloud Foundry and Kubernetes

Programming Languages

java
68154 projects - #9 most used programming language

Projects that are alternatives of or similar to Spring Cloud Dataflow

Netcorekit
💗 A crafted toolkit for building cloud-native apps on the .NET platform
Stars: ✭ 248 (-67.07%)
Mutual labels:  cloud-native, microservices-architecture
kubecloud
Kubecloud is a multi-cloud container cloud management platform
Stars: ✭ 48 (-93.63%)
Mutual labels:  orchestration, cloud-native
go-zero
A cloud-native Go microservices framework with cli tool for productivity.
Stars: ✭ 23,294 (+2993.49%)
Mutual labels:  cloud-native, microservices-architecture
Spring Cloud Stream
Framework for building Event-Driven Microservices
Stars: ✭ 662 (-12.08%)
Mutual labels:  cloud-native, stream-processing
Service Fabric
Service Fabric is a distributed systems platform for packaging, deploying, and managing stateless and stateful distributed applications and containers at large scale.
Stars: ✭ 2,874 (+281.67%)
Mutual labels:  cloud-native, orchestration
Awesome Microservices
A curated list of Microservice Architecture related principles and technologies.
Stars: ✭ 10,642 (+1313.28%)
Mutual labels:  cloud-native, microservices-architecture
if1007
Desenvolvimento de Aplicações com Arquitetura Baseada em Microservices
Stars: ✭ 78 (-89.64%)
Mutual labels:  cloud-native, microservices-architecture
Bats
面向 OLTP、OLAP、批处理、流处理场景的大一统 SQL 引擎
Stars: ✭ 152 (-79.81%)
Mutual labels:  stream-processing, batch-processing
theodolite
Theodolite is a framework for benchmarking the horizontal and vertical scalability of cloud-native applications.
Stars: ✭ 20 (-97.34%)
Mutual labels:  stream-processing, cloud-native
godsend
A simple and eloquent workflow for streaming messages to micro-services.
Stars: ✭ 15 (-98.01%)
Mutual labels:  stream-processing, microservices-architecture
Grpcjsontranscoder
A filter which allows a RESTful JSON API client to send requests to .NET web server over HTTP and get proxied to a gRPC service
Stars: ✭ 97 (-87.12%)
Mutual labels:  cloud-native, microservices-architecture
Microservices Recipes A Free Gitbook
“If you are working in an organization that places lots of restrictions on how developers can do their work, then microservices may not be for you.” ― Sam Newman
Stars: ✭ 393 (-47.81%)
Mutual labels:  cloud-native, microservices-architecture
Nats Server
High-Performance server for NATS.io, the cloud and edge native messaging system.
Stars: ✭ 10,223 (+1257.64%)
Mutual labels:  cloud-native, microservices-architecture
Coolstore Microservices
A full-stack .NET microservices build on Dapr and Tye
Stars: ✭ 1,903 (+152.72%)
Mutual labels:  cloud-native, microservices-architecture
Siddhi
Stream Processing and Complex Event Processing Engine
Stars: ✭ 1,185 (+57.37%)
Mutual labels:  cloud-native, stream-processing
football-events
Event-Driven microservices with Kafka Streams
Stars: ✭ 57 (-92.43%)
Mutual labels:  stream-processing, microservices-architecture
Pulsar Spark
When Apache Pulsar meets Apache Spark
Stars: ✭ 55 (-92.7%)
Mutual labels:  stream-processing, batch-processing
Pulsar Flink
Elastic data processing with Apache Pulsar and Apache Flink
Stars: ✭ 126 (-83.27%)
Mutual labels:  stream-processing, batch-processing
zeebe-helm
Public Zeebe K8s HELM Charts
Stars: ✭ 13 (-98.27%)
Mutual labels:  orchestration, cloud-native
Nats.go
Golang client for NATS, the cloud native messaging system.
Stars: ✭ 3,690 (+390.04%)
Mutual labels:  cloud-native, microservices-architecture

Spring Data Flow Dashboard

Latest Release Version Latest Snapshot Version
Build Status

Spring Cloud Data Flow is a microservices-based toolkit for building streaming and batch data processing pipelines in Cloud Foundry and Kubernetes.

Data processing pipelines consist of Spring Boot apps, built using the Spring Cloud Stream or Spring Cloud Task microservice frameworks.

This makes Spring Cloud Data Flow ideal for a range of data processing use cases, from import/export to event streaming and predictive analytics.


Components

Architecture: The Spring Cloud Data Flow Server is a Spring Boot application that provides RESTful API and REST clients (Shell, Dashboard, Java DSL). A single Spring Cloud Data Flow installation can support orchestrating the deployment of streams and tasks to Local, Cloud Foundry, and Kubernetes.

Familiarize yourself with the Spring Cloud Data Flow architecture and feature capabilities.

Deployer SPI: A Service Provider Interface (SPI) is defined in the Spring Cloud Deployer project. The Deployer SPI provides an abstraction layer for deploying the apps for a given streaming or batch data pipeline, and managing the application lifecycle.

Spring Cloud Deployer Implementations:

Domain Model: The Spring Cloud Data Flow domain module includes the concept of a stream that is a composition of Spring Cloud Stream applications in a linear data pipeline from a source to a sink, optionally including processor application(s) in between. The domain also includes the concept of a task, which may be any process that does not run indefinitely, including Spring Batch jobs.

Application Registry: The App Registry maintains the metadata of the catalog of reusable applications. For example, if relying on Maven coordinates, an application URI would be of the format: maven://<groupId>:<artifactId>:<version>.

Shell/CLI: The Shell connects to the Spring Cloud Data Flow Server's REST API and supports a DSL that simplifies the process of defining a stream or task and managing its lifecycle.

Community Implementations: There are also community maintained Spring Cloud Data Flow implementations that are currently based on the 1.7.x series of Spring Cloud Data Flow.

The Apache YARN implementation has reached end-of-line status. Let us know at Gitter if you are interested in forking the project to continue developing and maintaining it.


Building

Clone the repo and type

$ ./mvnw clean install 

Looking for more information? Follow this link.

Building on Windows

When using Git on Windows to check out the project, it is important to handle line-endings correctly during checkouts. By default Git will change the line-endings during checkout to CRLF. This is, however, not desired for Spring Cloud Data Flow as this may lead to test failures under Windows.

Therefore, please ensure that you set Git property core.autocrlf to false, e.g. using: $ git config core.autocrlf false. Fore more information please refer to the Git documentation, Formatting and Whitespace.


Contributing

We welcome contributions! Follow this link for more information on how to contribute.


Code formatting guidelines

  • The directory ./src/eclipse has two files for use with code formatting, eclipse-code-formatter.xml for the majority of the code formatting rules and eclipse.importorder to order the import statements.

  • In eclipse you import these files by navigating Windows -> Preferences and then the menu items Preferences > Java > Code Style > Formatter and Preferences > Java > Code Style > Organize Imports respectfully.

  • In IntelliJ, install the plugin Eclipse Code Formatter. You can find it by searching the "Browse Repositories" under the plugin option within IntelliJ (Once installed you will need to reboot Intellij for it to take effect). Then navigate to Intellij IDEA > Preferences and select the Eclipse Code Formatter. Select the eclipse-code-formatter.xml file for the field Eclipse Java Formatter config file and the file eclipse.importorder for the field Import order. Enable the Eclipse code formatter by clicking Use the Eclipse code formatter then click the OK button. ** NOTE: If you configure the Eclipse Code Formatter from File > Other Settings > Default Settings it will set this policy across all of your Intellij projects.

License

Spring Cloud Data Flow is Open Source software released under the Apache 2.0 license.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].