Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thefactory/marathon-python
Python client library for Mesos Marathon's REST API
https://github.com/thefactory/marathon-python
Last synced: 11 days ago
JSON representation
Python client library for Mesos Marathon's REST API
- Host: GitHub
- URL: https://github.com/thefactory/marathon-python
- Owner: thefactory
- License: mit
- Created: 2014-04-23T17:43:22.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2020-10-26T17:09:22.000Z (about 4 years ago)
- Last Synced: 2024-09-30T16:41:52.219Z (about 2 months ago)
- Language: Python
- Homepage:
- Size: 2.33 MB
- Stars: 197
- Watchers: 28
- Forks: 193
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# marathon-python
[![Build Status](https://travis-ci.org/thefactory/marathon-python.svg?branch=master)](https://travis-ci.org/thefactory/marathon-python)
This is a Python library for interfacing with [Marathon](https://github.com/mesosphere/marathon) servers via Marathon's [REST API](https://mesosphere.github.io/marathon/docs/rest-api.html).
#### Compatibility
* For Marathon 1.9.x and 1.10.x, use at least 0.13.0
* For Marathon 1.6.x, use at least 0.10.0
* For Marathon 1.4.1, use at least 0.8.13
* For Marathon 1.1.1, use at least 0.8.1
* For all version changes, please see `CHANGELOG.md`If you find a feature that is broken, please submit a PR that adds a test for
it so it will be fixed and will continue to stay fixed as Marathon changes over
time.Just because this library is tested against a specific version of Marathon,
doesn't necessarily mean that it supports every feature and API Marathon
provides.## Installation
#### From PyPi (recommended)
```bash
pip install marathon
```#### From GitHub
```bash
pip install -e [email protected]:thefactory/marathon-python.git#egg=marathon
```#### From source
```bash
git clone [email protected]:thefactory/marathon-python
python marathon-python/setup.py install
```## Testing
`marathon-python` uses Travis to test the code against different versions of Marathon.
You can run the tests locally on a Linux machine that has docker on it:### Running The Tests
```bash
make itests
```### Running The Tests Against a Specific Version of Marathon
```bash
MARATHONVERSION=v1.6.322 make itests
```## Documentation
API documentation is [here](http://thefactory.github.io/marathon-python).
Or you can build the documentation yourself:
```bash
pip install sphinx
pip install sphinx_rtd_theme
cd docs/
make html
```The documentation will be in `/gh-pages/html`:
```bash
open gh-pages/html/index.html
```## Basic Usage
Create a `MarathonClient()` instance pointing at your Marathon server(s):
```python
>>> from marathon import MarathonClient
>>> c = MarathonClient('http://localhost:8080')>>> # or multiple servers:
>>> c = MarathonClient(['http://host1:8080', 'http://host2:8080'])
```Then try calling some methods:
```python
>>> c.list_apps()
[MarathonApp::myapp1, MarathonApp::myapp2]
``````python
>>> from marathon.models import MarathonApp
>>> c.create_app('myapp3', MarathonApp(cmd='sleep 100', mem=16, cpus=1))
MarathonApp::myapp3
``````python
>>> app = c.get_app('myapp3')
>>> app.ports
[19671]
>>> app.mem = 32
>>> c.update_app('myapp3', app)
{'deploymentId': '83b215a6-4e26-4e44-9333-5c385eda6438', 'version': '2014-08-26T07:37:50.462Z'}
>>> c.get_app('myapp3').mem
32.0
``````python
>>> c.get_app('myapp3').instances
1
>>> c.scale_app('myapp3', instances=3)
{'deploymentId': '611b89e3-99f2-4d8a-afe1-ec0b83fdbb88', 'version': '2014-08-26T07:40:20.121Z'}
>>> c.get_app('myapp3').instances
3
>>> c.scale_app('myapp3', delta=-1)
{'deploymentId': '1081a99c-55e8-4404-907b-4a3697059848', 'version': '2014-08-26T07:43:30.232Z'}
>>> c.get_app('myapp3').instances
2
``````python
>>> c.list_tasks('myapp1')
[MarathonTask:myapp1-1398201790254]
>>> c.kill_tasks('myapp1', scale=True)
[MarathonTask:myapp1-1398201790254]
>>> c.list_tasks('myapp1')
[]
```## License
Open source under the MIT License. See [LICENSE](LICENSE).