2018-12-13 13:39:08 +05:30
# Serverless
> Introduced in GitLab 11.5.
2019-03-02 22:35:43 +05:30
CAUTION: **Caution:**
Serverless is currently in [alpha ](https://about.gitlab.com/handbook/product/#alpha ).
2018-12-13 13:39:08 +05:30
Run serverless workloads on Kubernetes using [Knative ](https://cloud.google.com/knative/ ).
## Overview
Knative extends Kubernetes to provide a set of middleware components that are useful to build modern, source-centric, container-based applications. Knative brings some significant benefits out of the box through its main components:
2019-05-30 16:15:17 +05:30
- [Serving ](https://github.com/knative/serving ): Request-driven compute that can scale to zero.
2019-07-07 11:18:12 +05:30
- [Eventing ](https://github.com/knative/eventing ): Management and delivery of events.
2018-12-13 13:39:08 +05:30
For more information on Knative, visit the [Knative docs repo ](https://github.com/knative/docs ).
2019-07-07 11:18:12 +05:30
With GitLab Serverless, you can deploy both functions-as-a-service (FaaS) and serverless applications.
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
## Prerequisites
2018-12-13 13:39:08 +05:30
To run Knative on Gitlab, you will need:
2019-07-07 11:18:12 +05:30
1. **Existing GitLab project:** You will need a GitLab project to associate all resources. The simplest way to get started:
- If you are planning on deploying functions, clone the [functions example project ](https://gitlab.com/knative-examples/functions ) to get started.
- If you are planning on deploying a serverless application, clone the sample [Knative Ruby App ](https://gitlab.com/knative-examples/knative-ruby-app ) to get started.
2019-02-15 15:39:39 +05:30
1. **Kubernetes Cluster:** An RBAC-enabled Kubernetes cluster is required to deploy Knative.
The simplest way to get started is to add a cluster using [GitLab's GKE integration ](../index.md#adding-and-creating-a-new-gke-cluster-via-gitlab ).
2019-07-07 11:18:12 +05:30
The set of minimum recommended cluster specifications to run Knative is 3 nodes, 6 vCPUs, and 22.50 GB memory.
2019-02-15 15:39:39 +05:30
1. **Helm Tiller:** Helm is a package manager for Kubernetes and is required to install
Knative.
2019-07-07 11:18:12 +05:30
1. **GitLab Runner:** A runner is required to run the CI jobs that will deploy serverless
applications or functions onto your cluster. You can install the GitLab Runner
onto the existing Kubernetes cluster. See [Installing Applications ](../index.md#installing-applications ) for more information.
2019-02-15 15:39:39 +05:30
1. **Domain Name:** Knative will provide its own load balancer using Istio. It will provide an
2019-07-07 11:18:12 +05:30
external IP address or hostname for all the applications served by Knative. You will be prompted to enter a
2019-02-15 15:39:39 +05:30
wildcard domain where your applications will be served. Configure your DNS server to use the
2019-07-07 11:18:12 +05:30
external IP address or hostname for that domain.
2019-02-15 15:39:39 +05:30
1. ** `.gitlab-ci.yml` :** GitLab uses [Kaniko ](https://github.com/GoogleContainerTools/kaniko )
2019-07-07 11:18:12 +05:30
to build the application. We also use [gitlabktl ](https://gitlab.com/gitlab-org/gitlabktl )
and [TriggerMesh CLI ](https://github.com/triggermesh/tm ) CLIs to simplify the
deployment of services and functions to Knative.
2019-02-15 15:39:39 +05:30
1. ** `serverless.yml` ** (for [functions only ](#deploying-functions )): When using serverless to deploy functions, the `serverless.yml` file
will contain the information for all the functions being hosted in the repository as well as a reference to the
runtime being used.
2019-07-07 11:18:12 +05:30
1. ** `Dockerfile` ** (for [applications only ](#deploying-serverless-applications ): Knative requires a
`Dockerfile` in order to build your applications. It should be included at the root of your
project's repo and expose port `8080` . `Dockerfile` is not require if you plan to build serverless functions
using our [runtimes ](https://gitlab.com/gitlab-org/serverless/runtimes ).
1. **Prometheus** (optional): Installing Prometheus allows you to monitor the scale and traffic of your serverless function/application.
See [Installing Applications ](../index.md#installing-applications ) for more information.
2018-12-13 13:39:08 +05:30
## Installing Knative via GitLab's Kubernetes integration
NOTE: **Note:**
2019-02-15 15:39:39 +05:30
The minimum recommended cluster size to run Knative is 3-nodes, 6 vCPUs, and 22.50 GB memory. **RBAC must be enabled.**
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
1. [Add a Kubernetes cluster ](../index.md ) and [install Helm ](../index.md#installing-applications ).
1. Once Helm has been successfully installed, scroll down to the Knative app section. Enter the domain to be used with
your application/functions (e.g. `example.com` ) and click **Install** .
2018-12-13 13:39:08 +05:30
![install-knative ](img/install-knative.png )
2019-07-07 11:18:12 +05:30
1. After the Knative installation has finished, you can wait for the IP address or hostname to be displayed in the
**Knative Endpoint** field or [retrieve the Istio Ingress Endpoint manually ](../#manually-determining-the-external-endpoint ).
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
NOTE: **Note:**
Running `kubectl` commands on your cluster requires setting up access to the cluster first.
For clusters created on GKE, see [GKE Cluster Access ](https://cloud.google.com/kubernetes-engine/docs/how-to/cluster-access-for-kubectl ),
for other platforms [Install kubectl ](https://kubernetes.io/docs/tasks/tools/install-kubectl/ ).
2018-12-13 13:39:08 +05:30
2019-02-15 15:39:39 +05:30
1. The ingress is now available at this address and will route incoming requests to the proper service based on the DNS
name in the request. To support this, a wildcard DNS A record should be created for the desired domain name. For example,
2019-07-07 11:18:12 +05:30
if your Knative base domain is `knative.info` then you need to create an A record or CNAME record with domain `*.knative.info`
pointing the ip address or hostname of the ingress.
2018-12-13 13:39:08 +05:30
![dns entry ](img/dns-entry.png )
2019-07-07 11:18:12 +05:30
NOTE: **Note:**
You can deploy either [functions ](#deploying-functions ) or [serverless applications ](#deploying-serverless-applications )
on a given project but not both. The current implementation makes use of a `serverless.yml` file to signal a FaaS project.
2019-09-04 21:01:54 +05:30
## Using an existing installation of Knative
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/issues/58941) in GitLab 12.0.
NOTE: **Note:**
The "invocations" monitoring feature of GitLab serverless will not work when
adding an existing installation of Knative.
It is also possible to use GitLab Serverless with an existing Kubernetes
cluster which already has Knative installed.
Simply:
1. Follow the steps to
[add an existing Kubernetes cluster ](../index.md#adding-an-existing-kubernetes-cluster ).
1. Follow the steps to deploy [functions ](#deploying-functions )
or [serverless applications ](#deploying-serverless-applications ) onto your
cluster.
2019-07-07 11:18:12 +05:30
## Deploying functions
2019-02-15 15:39:39 +05:30
> Introduced in GitLab 11.6.
Using functions is useful for dealing with independent
events without needing to maintain a complex unified infrastructure. This allows
you to focus on a single task that can be executed/scaled automatically and independently.
2019-07-07 11:18:12 +05:30
Currently the following [runtimes ](https://gitlab.com/gitlab-org/serverless/runtimes ) are offered:
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
- ruby
2019-02-15 15:39:39 +05:30
- node.js
2019-07-07 11:18:12 +05:30
- Dockerfile
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
You can find and import all the files referenced in this doc in the ** [functions example project ](https://gitlab.com/knative-examples/functions )**.
2019-03-02 22:35:43 +05:30
2019-07-07 11:18:12 +05:30
Follow these steps to deploy a function using the Node.js runtime to your Knative instance (you can skip these steps if you've cloned the example project):
2019-03-02 22:35:43 +05:30
1. Create a directory that will house the function. In this example we will create a directory called `echo` at the root of the project.
1. Create the file that will contain the function code. In this example, our file is called `echo.js` and is located inside the `echo` directory. If your project is:
- Public, continue to the next step.
- Private, you will need to [create a GitLab deploy token ](../../deploy_tokens/index.md#creating-a-deploy-token ) with `gitlab-deploy-token` as the name and the `read_registry` scope.
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
1. `.gitlab-ci.yml` : this defines a pipeline used to deploy your functions.
It must be included at the root of your repository:
2019-02-15 15:39:39 +05:30
```yaml
2019-07-07 11:18:12 +05:30
include:
template: Serverless.gitlab-ci.yml
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
functions:build:
extends: .serverless:build:functions
environment: production
2019-03-02 22:35:43 +05:30
2019-07-07 11:18:12 +05:30
functions:deploy:
extends: .serverless:deploy:functions
environment: production
2019-02-15 15:39:39 +05:30
```
2019-07-07 11:18:12 +05:30
This `.gitlab-ci.yml` creates jobs that invoke some predefined commands to
build and deploy your functions to your cluster.
`Serverless.gitlab-ci.yml` is a template that allows customization.
You can either import it with `include` parameter and use `extends` to
customize your jobs, or you can inline the entire template by choosing it
from **Apply a template** dropdown when editing the `.gitlab-ci.yml` file through
the user interface.
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
2. `serverless.yml` : this file contains the metadata for your functions,
such as name, runtime, and environment.
It must be included at the root of your repository.
The following is a sample `echo` function which shows the required structure
for the file.
You can find the relevant files for this project in the [functions example project ](https://gitlab.com/knative-examples/functions ).
2019-02-15 15:39:39 +05:30
```yaml
2019-07-07 11:18:12 +05:30
service: functions
description: "GitLab Serverless functions using Knative"
2019-02-15 15:39:39 +05:30
provider:
name: triggermesh
environment:
2019-07-07 11:18:12 +05:30
FOO: value
2019-02-15 15:39:39 +05:30
functions:
2019-07-07 11:18:12 +05:30
echo-js:
handler: echo-js
source: ./echo-js
runtime: https://gitlab.com/gitlab-org/serverless/runtimes/nodejs
description: "node.js runtime function"
2019-05-18 00:54:41 +05:30
environment:
2019-07-07 11:18:12 +05:30
MY_FUNCTION: echo-js
```
2019-05-30 16:15:17 +05:30
2019-07-07 11:18:12 +05:30
Explanation of the fields used above:
2019-02-15 15:39:39 +05:30
### `service`
| Parameter | Description |
|-----------|-------------|
| `service` | Name for the Knative service which will serve the function. |
| `description` | A short description of the `service` . |
### `provider`
| Parameter | Description |
|-----------|-------------|
| `name` | Indicates which provider is used to execute the `serverless.yml` file. In this case, the TriggerMesh `tm` CLI. |
| `environment` | Includes the environment variables to be passed as part of function execution for **all** functions in the file, where `FOO` is the variable name and `BAR` are he variable contents. You may replace this with you own variables. |
### `functions`
In the `serverless.yml` example above, the function name is `echo` and the subsequent lines contain the function attributes.
| Parameter | Description |
|-----------|-------------|
2019-07-07 11:18:12 +05:30
| `handler` | The function's name. |
| `source` | Directory with sources of a functions. |
2019-02-15 15:39:39 +05:30
| `runtime` | The runtime to be used to execute the function. |
| `description` | A short description of the function. |
| `environment` | Sets an environment variable for the specific function only. |
2019-03-02 22:35:43 +05:30
After the `gitlab-ci.yml` template has been added and the `serverless.yml` file has been
created, pushing a commit to your project will result in a
2019-02-15 15:39:39 +05:30
CI pipeline being executed which will deploy each function as a Knative service.
Once the deploy stage has finished, additional details for the function will
appear under **Operations > Serverless** .
![serverless page ](img/serverless-page.png )
2019-03-02 22:35:43 +05:30
This page contains all functions available for the project, the description for
accessing the function, and, if available, the function's runtime information.
2019-02-15 15:39:39 +05:30
The details are derived from the Knative installation inside each of the project's
2019-07-07 11:18:12 +05:30
Kubernetes cluster. Click on each function to obtain detailed scale and invocation data.
2019-02-15 15:39:39 +05:30
The function details can be retrieved directly from Knative on the cluster:
```bash
kubectl -n "$KUBE_NAMESPACE" get services.serving.knative.dev
```
2019-07-07 11:18:12 +05:30
The sample function can now be triggered from any HTTP client using a simple `POST` call:
2019-02-15 15:39:39 +05:30
2019-07-07 11:18:12 +05:30
1. Using curl (replace the URL on the last line with the URL of your application):
```bash
curl \
--header "Content-Type: application/json" \
--request POST \
--data '{"GitLab":"FaaS"}' \
2019-09-04 21:01:54 +05:30
http://functions-echo.functions-1.functions.example.com/
2019-07-07 11:18:12 +05:30
```
2. Using a web-based tool (ie. postman, restlet, etc)
![function execution ](img/function-execution.png )
2019-02-15 15:39:39 +05:30
## Deploying Serverless applications
> Introduced in GitLab 11.5.
NOTE: **Note:**
2019-07-07 11:18:12 +05:30
You can reference and import the sample [Knative Ruby App ](https://gitlab.com/knative-examples/knative-ruby-app ) to get started.
2019-02-15 15:39:39 +05:30
Add the following `.gitlab-ci.yml` to the root of your repository
2019-07-07 11:18:12 +05:30
(you may skip this step if you've previously cloned the sample [Knative Ruby App ](https://gitlab.com/knative-examples/knative-ruby-app ) mentioned above):
2019-02-15 15:39:39 +05:30
```yaml
2019-07-07 11:18:12 +05:30
include:
template: Serverless.gitlab-ci.yml
2019-02-15 15:39:39 +05:30
build:
2019-07-07 11:18:12 +05:30
extends: .serverless:build:image
2019-02-15 15:39:39 +05:30
deploy:
2019-07-07 11:18:12 +05:30
extends: .serverless:deploy:image
2019-02-15 15:39:39 +05:30
```
2019-07-07 11:18:12 +05:30
`Serverless.gitlab-ci.yml` is a template that allows customization.
You can either import it with `include` parameter and use `extends` to
customize your jobs, or you can inline the entire template by choosing it
from **Apply a template** dropdown when editing the `.gitlab-ci.yml` file through
the user interface.
2019-03-02 22:35:43 +05:30
### Deploy the application with Knative
2018-12-13 13:39:08 +05:30
2019-02-15 15:39:39 +05:30
With all the pieces in place, the next time a CI pipeline runs, the Knative application will be deployed. Navigate to
**CI/CD > Pipelines** and click the most recent pipeline.
2018-12-13 13:39:08 +05:30
2019-03-02 22:35:43 +05:30
### Obtain the URL for the Knative deployment
2019-07-07 11:18:12 +05:30
Go to the **CI/CD > Pipelines** and click on the pipeline that deployed your app. Once all the stages of the pipeline finish, click the **deploy** stage.
2018-12-13 13:39:08 +05:30
![deploy stage ](img/deploy-stage.png )
The output will look like this:
```bash
Running with gitlab-runner 11.5.0~beta.844.g96d88322 (96d88322)
on docker-auto-scale 72989761
Using Docker executor with image gcr.io/triggermesh/tm@sha256:e3ee74db94d215bd297738d93577481f3e4db38013326c90d57f873df7ab41d5 ...
Pulling docker image gcr.io/triggermesh/tm@sha256:e3ee74db94d215bd297738d93577481f3e4db38013326c90d57f873df7ab41d5 ...
Using docker image sha256:6b3f6590a9b30bd7aafb9573f047d930c70066e43955b4beb18a1eee175f6de1 for gcr.io/triggermesh/tm@sha256:e3ee74db94d215bd297738d93577481f3e4db38013326c90d57f873df7ab41d5 ...
Running on runner-72989761-project-4342902-concurrent-0 via runner-72989761-stg-srm-1541795796-27929c96...
Cloning repository...
Cloning into '/builds/danielgruesso/knative'...
Checking out 8671ad20 as master...
Skipping Git submodules setup
$ echo "$CI_REGISTRY_IMAGE"
registry.staging.gitlab.com/danielgruesso/knative
$ tm -n "$KUBE_NAMESPACE" --config "$KUBECONFIG" deploy service "$CI_PROJECT_NAME" --from-image "$CI_REGISTRY_IMAGE" --wait
Deployment started. Run "tm -n knative-4342902 describe service knative" to see the details
Waiting for ready state.......
2019-07-07 11:18:12 +05:30
Service domain: knative.knative-4342902.example.com
2018-12-13 13:39:08 +05:30
Job succeeded
```
2019-02-15 15:39:39 +05:30
The second to last line, labeled **Service domain** contains the URL for the deployment. Copy and paste the domain into your
2018-12-13 13:39:08 +05:30
browser to see the app live.
2019-02-15 15:39:39 +05:30
![knative app ](img/knative-app.png )
2019-07-07 11:18:12 +05:30
## Function details
Go to the **Operations > Serverless** page and click on one of the function
rows to bring up the function details page.
![function_details ](img/function-details-loaded.png )
The pod count will give you the number of pods running the serverless function instances on a given cluster.
### Prometheus support
For the Knative function invocations to appear,
[Prometheus must be installed ](../index.md#installing-applications ).
Once Prometheus is installed, a message may appear indicating that the metrics data _is
loading or is not available at this time._ It will appear upon the first access of the
page, but should go away after a few seconds. If the message does not disappear, then it
is possible that GitLab is unable to connect to the Prometheus instance running on the
cluster.