simple system process manager
Project description
**NOTICE**: Since the 2013/05/25, a deep rewrite on the gaffer code is
in progress.
**2013-10-29 - 0.5.0 released.**
> slow progress on the new version. Have been distracted by some due
> work. The new design is in place now and the new branch will be
> created soon,
# Gaffer
Control, Watch and Launch your applications and jobs over HTTP.
Gaffer is a set of Python modules and tools to easily maintain and
interact with your applications or jobs launched on different machines over
HTTP and websockets.
It promotes distributed and decentralized topologies without single points of
failure, enabling fault tolerance and high availability.
## Features
- RESTful HTTP Api
- Websockets and [SOCKJS](http://sockjs.org) support to interact with a gaffer node from any browser or SOCKJS client.
- Framework to manage and interact your applications and jobs on
- differerent machines
- Server and command-line tools to manage and interract with your processes
- manages topology information. Clients query gaffer_lookupd to discover gaffer nodes for a specific job or application.
- Possibility to interact with STDIO and PIPES to interact with your
applications and processes
- Subscribe to process statistics per process or process templates and get them in quasi RT.
- Procfile applications support but also JSON config support.
- Supervisor-like features.
- Fully evented. Use the libuv event loop using the [pyuv library](http://pyuv.readthedocs.org)
- Flapping: handle cases where your processes crash too much
- Easily extensible: add your own endpoint, create your client, embed gaffer in your application, ...
- Compatible with python 2.7x, 3.x
## Documentation
http://gaffer.readthedocs.org
## Getting Started
http://gaffer.readthedocs.org/en/latest/getting-started.html
## Installation
Gaffer requires Python superior to 2.6 (yes Python 3 is supported)
To install gaffer using pip you must make sure you have a
recent version of distribute installed:
$ curl -O http://python-distribute.org/distribute_setup.py
$ sudo python distribute_setup.py
$ easy_install pip
To install from source, run the following command:
$ pip install git+https://github.com/benoitc/gaffer.git
From pypi:
$ pip install gaffer
## Build status
**Master branch**: <a href="https://travis-ci.org/benoitc/gaffer"><img src="https://secure.travis-ci.org/benoitc/gaffer.png?branch=master" alt="Build Status" /></a>
**Develop branch**: <a href="https://travis-ci.org/benoitc/gaffer"><img src="https://secure.travis-ci.org/benoitc/gaffer.png?branch=develop" alt="Build Status" /></a>
## License
gaffer is available in the public domain (see UNLICENSE). gaffer is also
optionally available under the MIT License (see LICENSE), meant
especially for jurisdictions that do not recognize public domain
works.
in progress.
**2013-10-29 - 0.5.0 released.**
> slow progress on the new version. Have been distracted by some due
> work. The new design is in place now and the new branch will be
> created soon,
# Gaffer
Control, Watch and Launch your applications and jobs over HTTP.
Gaffer is a set of Python modules and tools to easily maintain and
interact with your applications or jobs launched on different machines over
HTTP and websockets.
It promotes distributed and decentralized topologies without single points of
failure, enabling fault tolerance and high availability.
## Features
- RESTful HTTP Api
- Websockets and [SOCKJS](http://sockjs.org) support to interact with a gaffer node from any browser or SOCKJS client.
- Framework to manage and interact your applications and jobs on
- differerent machines
- Server and command-line tools to manage and interract with your processes
- manages topology information. Clients query gaffer_lookupd to discover gaffer nodes for a specific job or application.
- Possibility to interact with STDIO and PIPES to interact with your
applications and processes
- Subscribe to process statistics per process or process templates and get them in quasi RT.
- Procfile applications support but also JSON config support.
- Supervisor-like features.
- Fully evented. Use the libuv event loop using the [pyuv library](http://pyuv.readthedocs.org)
- Flapping: handle cases where your processes crash too much
- Easily extensible: add your own endpoint, create your client, embed gaffer in your application, ...
- Compatible with python 2.7x, 3.x
## Documentation
http://gaffer.readthedocs.org
## Getting Started
http://gaffer.readthedocs.org/en/latest/getting-started.html
## Installation
Gaffer requires Python superior to 2.6 (yes Python 3 is supported)
To install gaffer using pip you must make sure you have a
recent version of distribute installed:
$ curl -O http://python-distribute.org/distribute_setup.py
$ sudo python distribute_setup.py
$ easy_install pip
To install from source, run the following command:
$ pip install git+https://github.com/benoitc/gaffer.git
From pypi:
$ pip install gaffer
## Build status
**Master branch**: <a href="https://travis-ci.org/benoitc/gaffer"><img src="https://secure.travis-ci.org/benoitc/gaffer.png?branch=master" alt="Build Status" /></a>
**Develop branch**: <a href="https://travis-ci.org/benoitc/gaffer"><img src="https://secure.travis-ci.org/benoitc/gaffer.png?branch=develop" alt="Build Status" /></a>
## License
gaffer is available in the public domain (see UNLICENSE). gaffer is also
optionally available under the MIT License (see LICENSE), meant
especially for jurisdictions that do not recognize public domain
works.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
gaffer-0.5.0.tar.gz
(371.2 kB
view details)
File details
Details for the file gaffer-0.5.0.tar.gz
.
File metadata
- Download URL: gaffer-0.5.0.tar.gz
- Upload date:
- Size: 371.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8672f3e3c01aa070eb856c4f6f32fd3b47b6ee676201fa21adc54d611a5f96d2 |
|
MD5 | d1d766b05bf713519c0072585e163d10 |
|
BLAKE2b-256 | 3ca3192a9f7a2b4e3f6927ba4c9c253ceba61af45232fa32fffcfa2d49dd2f33 |