Skip to content

A simpler class interface and launch utils for processing kinesis streams with the Amazon Kinesis Client Library MultiLangDaemon

License

Notifications You must be signed in to change notification settings

empiricalresults/easy-kclpy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

easy_kclpy

A simpler class interface and launch utils for processing kinesis streams with the Amazon Kinesis Client Library MultiLangDaemon. It includes a launcher that is fully configured from environment variables.

Installing the package

The package can be installed with pip like any other package. Here is a summary for installing it with python3.

> python3 -m venv venv
> . venv/bin/activate
> pip3 install --upgrade pip
> pip3 install -r requirements.txt
> python setup.py develop

How to make a Release

  1. Update the version in setup.py, commit to master.

  2. Locally, build a source distribution:

    python setup.py sdist

Running the example

Here's an example of launching an example kinesis worker that dumps the stream to local files.

First configure the environment variables.

export APPLICATION_NAME="LocalFileWriter"
export EXECUTABLE_NAME="python3 easy_kclpy/utils/kinesis_to_file_processor.py"
export STREAM_NAME=[your-kinesis-stream]

Then launch the daemon that will run a worker per shard.

python -m easy_kclpy.utils.launch_multilangdaemon -j /usr/bin/java --generate-properties -p kinesis.properties

This requires you to have AWS credentials with permission to create a dynamo table and read from the kinesis stream. The name of the dynamo table will be the same as the name of the app defined in the environment variables above (ie LocalFileWriter).

About

A simpler class interface and launch utils for processing kinesis streams with the Amazon Kinesis Client Library MultiLangDaemon

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages