/pricealert

Demonstrate Batch Processing and Wallaroo with the Coinbase Pro API (Mirror of WallarooLabs/blog_post_examples)

Primary LanguagePython

pricealert

This is a companion application designed to show the difference between batch processing and stream processing. If you aren't familiar with either Batch or Stream processing there are good articles online. Many of the use-cases where you'd normally use batch processing are perfect use-cases for streaming.

In this application we use Celery to run our periodic tasks. We're going to use Wallaroo 0.5.2 do demonstrate taking our celery logic and converting it to Wallaroo.

There are quite a lot of opportunities to improve this application. Which we may explore in a future blog post.

Installation and getting it running

If you don't have python 2.7.x, Redis or Wallaroo on your machine. Please find the correct installation instructions for Python and Redis for your operating system. You can find installation instructions for Wallaroo here and all the different installations should work (docker, wallaroo-up, etc..)

Once those three dependencies are installed and this repo cloned, you'll need to install the needed python dependencies. Locally or with an already created virtualenv environment, inside the newly cloned repo run pip install -r requirements.txt.

The best way to get Wallaroo setup is to follow our "Run a Wallaroo Application in..." for whichever way you decided to install Wallaroo.

The easiest way to make sure everything works correctly, is to first set up Django.

python manage.py migrate

Once Django is setup and you've done the necessary prerequisites for Wallaroo, you can run one of the following sets of commands.

For Celery in separate terminals:

# assuming you have all the dependencies installed
make run-on-celery

For Wallaroo in separate terminals:

# assuming you have all the dependencies installed
make run-on-wallaroo

Contributing

Please create an issue/PR if you come across any issues.