Standard library and deployment tools for using Python with Storm
Project description
Pyleus is a Python 2.6+ framework for developing and launching Apache Storm topologies.
Please visit our wiki.
master |
develop |
---|---|
About
Pyleus is a framework for building Apache Storm topologies in idiomatic Python.
With Pyleus you can:
define a topology with a simple YAML file
have dependency management with a requirements.txt file
run faster thanks to Pyleus’ MessagePack based serializer
pass options to your components directly from the YAML file
use the Kafka spout built into Storm with only a YAML change
Install
From PyPI:
$ pip install pyleus
Note:
You do NOT need to install pyleus on your Storm cluster. That’s cool, isn’t it?
Try it out!
$ git clone https://github.com/Yelp/pyleus.git
$ pyleus build pyleus/examples/exclamation_topology/pyleus_topology.yaml
$ pyleus local exclamation_topology.jar
Or, submit to a Storm cluster with:
$ pyleus submit -n NIMBUS_IP exclamation_topology.jar
The examples directory contains several annotated Pyleus topologies that try to cover as many Pyleus features as possible.
Pyleus command line interface
Build a topology:
$ pyleus build /path/to/pyleus_topology.yaml
Run a topology locally:
$ pyleus local /path/to/topology.jar
Submit a topology to a Storm cluster:
$ pyleus submit [-n NIMBUS_IP] /path/to/pyleus_topology.yaml
List all topologies running on a Storm cluster:
$ pyleus list [-n NIMBUS_IP]
Kill a topology running on a Storm cluster:
$ pyleus kill [-n NIMBUS_IP] TOPOLOGY_NAME
Try pyleus -h for a list of all the available commands or pyleus CMD -h for any command-specific help.
Write your first topology
Please refer to the wiki for a more detailed tutorial.
Organize your files
This is an example of the directory tree of a simple topology:
my_first_topology/
|-- my_first_topology/
| |-- __init__.py
| |-- dummy_bolt.py
| |-- dummy_spout.py
|-- pyleus_topology.yaml
|-- requirements.txt
Define the topology layout
A simple pyleus_topology.yaml should look like the following:
name: my_first_topology
topology:
- spout:
name: my-first-spout
module: my_first_topology.dummy_spout
- bolt:
name: my-first-bolt
module: my_first_topology.dummy_bolt
groupings:
- shuffle_grouping: my-first-spout
This defines a topology where a single bolt subscribes to the output stream of a single spout. As simple as it is.
Write your first spout
This is the code implementing dummy_spout.py:
from pyleus.storm import Spout
class DummySpout(Spout):
OUTPUT_FIELDS = ['sentence', 'name']
def next_tuple(self):
self.emit(("This is a sentence.", "spout",))
if __name__ == '__main__':
DummySpout().run()
Write your first bolt
Let’s now look at dummy_bolt.py:
from pyleus.storm import SimpleBolt
class DummyBolt(SimpleBolt):
OUTPUT_FIELDS = ['sentence']
def process_tuple(self, tup):
sentence, name = tup.values
new_sentence = "{0} says, \"{1}\"".format(name, sentence)
self.emit((new_sentence,), anchors=[tup])
if __name__ == '__main__':
DummyBolt().run()
Run your topology
Run the topology on your local machine for debugging:
pyleus build my_first_topology/pyleus_topology.yaml
pyleus local --debug my_first_topology.jar
When you are done, hit C-C.
Configuration File
You can set default values for many configuration options by placing a .pyleus.conf file in your home directory:
[storm]
nimbus_ip: 10.11.12.13
jvm_opts: -Djava.io.tmpdir=/home/myuser/tmp
[build]
pypi_index_url: http://pypi.ninjacorp.com/simple/
Reference
License
Pyleus is licensed under the Apache License, Version 2.0: http://www.apache.org/licenses/LICENSE-2.0
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
File details
Details for the file pyleus-0.2.1.tar.gz
.
File metadata
- Download URL: pyleus-0.2.1.tar.gz
- Upload date:
- Size: 17.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ac5cec99a7d42fd9060dc4f2f41bb2eaa03e0ecd01429ee4eff46bceb97b1de6 |
|
MD5 | 575e83b0808485f7fcc84cd19b7eced5 |
|
BLAKE2b-256 | 7febe818dea7407ab8418442e6d5409ee3faa605b57d6e62239513ee6a792826 |