Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Dataman-Cloud/swan

A Distributed, Highly Available Mesos Scheduler, Inspired by the design of Google Borg
https://github.com/Dataman-Cloud/swan

marathon mesos mesos-scheduler swan

Last synced: 1 day ago
JSON representation

A Distributed, Highly Available Mesos Scheduler, Inspired by the design of Google Borg

Awesome Lists containing this project

README

        

![](https://raw.githubusercontent.com/Dataman-Cloud/swan/master/docs/assets/img/swan.png)

------------

[![Build Status](https://travis-ci.org/Dataman-Cloud/swan.svg?branch=master)](https://travis-ci.org/Dataman-Cloud/swan)
[![codecov](https://codecov.io/gh/Dataman-Cloud/swan/branch/master/graph/badge.svg)](https://codecov.io/gh/Dataman-Cloud/swan)
[![Go Report Card](https://goreportcard.com/badge/github.com/Dataman-Cloud/swan)](https://goreportcard.com/report/github.com/Dataman-Cloud/swan)
[![Join the chat at https://gitter.im/Dataman-Cloud/swan](https://badges.gitter.im/Dataman-Cloud/swan.svg)](https://gitter.im/Dataman-Cloud/swan?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[![Docker Pulls](https://img.shields.io/docker/pulls/datamanos/swan.svg)](https://store.docker.com/community/images/datamanos/swan)

## What is `Swan`?

`Swan` is a `Mesos` framework forcus on long running tasks, which inspired by `Marathon`, written with `Golang` and base on latest `Mesos` HTTP API.

## What does `Swan` do?

With `Swan` you can deploy long running `application` on mesos cluster, control lifecycle of the application, scale up or scale down any `instances` size you want, can also do rolling-update with new versions base on flexible `health checks` defined by you. `Swan` also designed for high avaliability which means any server crash wouldn't affect running applications. with `service discovery` and `API gateway` build-in, service discovery made easy.

#### `Swan` is created and maintained by [Dataman-Cloud](https://github.com/Dataman-Cloud), and licensed under the Apache License, Version 2.0.

## Features

+ Application Management
+ ScaleUp/ScaleDown
+ Rolling update
+ Rollback
+ Mesos-based health checks
+ HA
+ Event Subscription
+ Compose
+ Calico-based IP-Per-Task
+ Schedule stategy

## Installation
[INSTALLATION](https://github.com/Dataman-Cloud/swan/tree/master/docs/installation.md)

### API
[API](https://github.com/Dataman-Cloud/swan/tree/master/docs/api.md)

## Contributing
If you want to contribute to swan, make a PR or report a issue.
The goal of swan is to become the default and best scheduler for mesos, so let's do it!

## TroubleShooting
[TroubleShooting](https://github.com/Dataman-Cloud/swan/tree/master/docs/trouble-shooting.md)

## Contact
- [pwzgorilla](mailto:[email protected])
- [bbklab](mailto:[email protected])

WeChat: xiaoshu062

## Licensing
Swan is licensed under the Apache License, Version 2.0. See
[LICENSE](https://github.com/Dataman-Cloud/swan/blob/master/LICENSE) for the full
license text.