faas/guide/backends.md
rgee0 bc75e3f476 changing image as per #475
Signed-off-by: rgee0 <richard@technologee.co.uk>
2018-01-13 17:55:09 +00:00

108 lines
3.7 KiB
Markdown

## OpenFaaS backends guide
OpenFaaS is a framework for building serverless functions with containers and running them at scale.
> Bring Serverless OpenFaaS functions to your favourite container platform.
We support two orchestration platforms or "backends" within the OpenFaaS project.
* Docker Swarm
* Kubernetes
There are several other backends available with community-support as documented in the [community guide](https://github.com/openfaas/faas/blob/master/community.md#openfaas-providers).
The Docker Swarm support is built-into the faas repo, but the Kubernetes support is provided by a microservice in the [faas-netes](https://github.com/openfaas/faas-netes) repo.
If you're thinking of writing a new back-end we'd love to hear about it and help you, so please get in touch with alex@openfaas.com. Existing implementations (like OpenFaaS) are written in Golang and this provides a level of consistency across the projects.
### I need a backend for X
This project is focusing on Docker Swarm and Kubernetes, but we're open to support from third parties and vendors for other backends:
Here are some ideas:
* Nomad
* Marathon Mesos
* AWS ECS
* Hyper.sh
If you would like to write your own back-end for `X` then you can write your own microservice that conforms to the [Swagger API](https://github.com/openfaas/faas/tree/master/api-docs) here.
### How does my back-end work?
In order to support a new back end you will write a new "external_provider" and configure this on the API Gateway. The API Gateway will then proxy any requests to your new microservice. The first "external_provider" was the Kubernetes implementation [faas-netes](https://github.com/openfaas/faas-netes):
![](https://camo.githubusercontent.com/888f9106de92978615b16231e6a0801e0a5b6f77/68747470733a2f2f696d6775722e636f6d2f646f776e6c6f61642f525847344e3162)
Deploy a function - through the built-in Swarm support or through faas-netes
![](https://pbs.twimg.com/media/DIyFFnsXkAAa5Gj.jpg)
Invoke your function - through the built-in Swarm or via faas-netes
![](https://pbs.twimg.com/media/DIyFFnqXgAAMyCh.jpg)
Find out more about the [watchdog here](https://github.com/openfaas/faas/tree/master/watchdog).
### Automatically compatible OpenFaaS
The following are fully compatible with any additional back-ends:
* API Gateway
* Promethes metrics (tracked through API Gateway)
* The built-in UI portal (hosted on the API Gateway)
* The Function Watchdog and any existing OpenFaaS functions
* The [CLI](https://github.com/openfaas/faas-cli)
* Asynchronous function invocation
Dependent on back-end:
* Secrets or environmental variable support
* Windows Containers function runtimes (i.e. via W2016 and Docker)
* Scaling - dependent on underlying API (available in Docker & Kubernetes)
#### Backend endpoints:
* List / Create / Delete a function
`/system/functions`
Method(s): GET / POST / DELETE
* Get a specific function
`/system/function/{name:[-a-zA-Z_0-9]+}`
Method(s): GET
* Scale a specific function:
`/system/scale-function/{name:[-a-zA-Z_0-9]+}`
Method(s): POST
* Invoke a specific function
`/function/{name:[-a-zA-Z_0-9]+}`
Method(s): POST
### Examples / documentation
* See the [Swagger API](https://github.com/openfaas/faas/tree/master/api-docs) as a starting point.
#### faas-netes (Kubernetes)
The Kubernetes integration was written by Alex Ellis and is officially supported by the project.
* See the [FaaS-netes handlers](https://github.com/openfaas/faas-netes/tree/master/handlers) for examples of how to implement each endpoint.
#### Rancher / Cattle (community)
This work is by Ken Fukuyama from Japan.
* [Blog post](https://medium.com/@kenfdev/openfaas-on-rancher-684650cc078e)
* [faas-rancher](https://github.com/kenfdev/faas-rancher) implementation in Golang