
Slipstream provides a data-flow model to simplify development of stateful streaming applications.
Simplicity: parallelizing processing, mapping sources to sinks
Freedom: allowing arbitrary code free of limiting abstractions
Speed: optimized and configurable defaults to get started quickly
Consume any source that can be turned into an Async Iterable
; Kafka, streaming API’s, et cetera.
Sink or cache data to any Callable
; Kafka, RocksDB, API’s.
Perform any arbitrary stateful operation – joining, aggregating, filtering – using regular Python code.
Detect dependency stream downtimes, pause dependent streams, or send out corrections.
Because everything is built with basic python building blocks, framework-like features can be crafted with ease. For instance, while timers aren’t included, you can whip one up effortlessly:
from asyncio import run, sleep
async def timer(interval=1.0):
while True:
await sleep(interval)
yield
We’ll use print
as our sink:
Let’s send our mascot 🐟 – blub downstream on a regular 1 second interval:
from slipstream import handle, stream
@handle(timer(), sink=[print])
def handler():
yield '🐟 - blub'
run(stream())
# 🐟 - blub
# 🐟 - blub
# 🐟 - blub
# ...
Some things that stand out:
We’ve created an
Async Iterable
sourcetimer()
(not generating data, just triggering the handler)We used
slipstream.handle
to bind the sources and sinks to thehandler
functionWe yielded
🐟 - blub
, which is sent to all theCallable
sinks (justprint
in this case)Running
slipstream.stream
starts the flow from sources via handlers into the sinks
The data-flow model that simplifies development of stateful streaming applications!
Contents¶
Proceed by interacting with Kafka and caching application state in: getting started.