Commit a67566c5 authored by Alishan Ladhani's avatar Alishan Ladhani Committed by Thong Kuah

Document how to use OpenFaaS runtimes with GitLab Serverless

parent f78c8e7d
...@@ -166,13 +166,14 @@ You must do the following: ...@@ -166,13 +166,14 @@ You must do the following:
or [serverless applications](#deploying-serverless-applications) onto your or [serverless applications](#deploying-serverless-applications) onto your
cluster. cluster.
## Deploying functions ## Supported runtimes
> Introduced in GitLab 11.6. Serverless functions for GitLab can be written in 6 supported languages:
Using functions is useful for dealing with independent events without needing - NodeJS and Ruby, with GitLab-managed and OpenFaas runtimes.
to maintain a complex unified infrastructure. This allows you to focus on a - C#, Go, PHP, and Python with OpenFaaS runtimes only.
single task that can be executed/scaled automatically and independently.
### GitLab managed runtimes
Currently the following [runtimes](https://gitlab.com/gitlab-org/serverless/runtimes) are offered: Currently the following [runtimes](https://gitlab.com/gitlab-org/serverless/runtimes) are offered:
...@@ -182,6 +183,31 @@ Currently the following [runtimes](https://gitlab.com/gitlab-org/serverless/runt ...@@ -182,6 +183,31 @@ Currently the following [runtimes](https://gitlab.com/gitlab-org/serverless/runt
`Dockerfile` presence is assumed when a runtime is not specified. `Dockerfile` presence is assumed when a runtime is not specified.
### OpenFaaS runtimes
> [Introduced](https://gitlab.com/gitlab-org/gitlab/issues/29253) in GitLab 12.5.
[OpenFaaS classic runtimes](https://github.com/openfaas/templates#templates-in-store) can be used with GitLab serverless.
Runtimes are specified using the pattern: `openfaas/classic/<template_name>`. The following
example shows how to define a function in `serverless.yml` using an OpenFaaS runtime:
```yaml
hello:
source: ./hello
runtime: openfaas/classic/ruby
description: "Ruby function using OpenFaaS classic runtime"
```
`handler` is not needed for OpenFaaS functions. The location of the handler is defined
by the conventions of the runtime.
See the [`ruby-openfaas-function`](https://gitlab.com/knative-examples/ruby-openfaas-function)
project for an example of a function using an OpenFaaS runtime.
## Deploying functions
> Introduced in GitLab 11.6.
You can find and import all the files referenced in this doc in the You can find and import all the files referenced in this doc in the
**[functions example project](https://gitlab.com/knative-examples/functions)**. **[functions example project](https://gitlab.com/knative-examples/functions)**.
...@@ -352,6 +378,10 @@ To run a function locally: ...@@ -352,6 +378,10 @@ To run a function locally:
> Introduced in GitLab 11.5. > Introduced in GitLab 11.5.
Serverless applications are the building block of serverless functions. They are useful in scenarios where an existing
runtime does not meet the needs of an application, such as one written in a language that has no runtime available. Note
though that serverless applications should be stateless!
NOTE: **Note:** NOTE: **Note:**
You can reference and import the sample [Knative Ruby App](https://gitlab.com/knative-examples/knative-ruby-app) to get started. You can reference and import the sample [Knative Ruby App](https://gitlab.com/knative-examples/knative-ruby-app) to get started.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment