In this article, we will set up a serverless platform with OpenFaaS, an open-source framework, to explore this paradigm—the first step in a deep dive into the serverless journey.
Prerequisites
- One or 2+ servers (recommended), using Ubuntu 18.04.3 (Desktop or Server version, local or remote). Note: These servers should have a fixed IP address.
- Internet connection
Setup Kubernetes Cluster with Rancher 2.0
There are manifold options for deploying a local or remote Kubernetes cluster. You can find out them here. One of the easiest ways to build one is Rancher.
Rancher is known as a platform to deliver Kubernetes-as-a-Service across any infrastructure and it could be used in both production and development environment.
In this experiment, I used 3 virtual machines running Ubuntu 18.04. All of them used sharing networking, so they could connect to each other and have internet access. At least one plays a master role (Master node), and others are Worker nodes.
Step 1: Install the latest version of Docker
Docker is a mandatory ingredient and must be installed in all nodes (both Master and Worker)
Option 1: Using the following script
curl -fsSL https://get.docker.com -o get-docker.sh
sh get-docker.sh
Option 2: Do it step-by-step
Install docker:
sudo apt install -y docker.io
After the installation is complete, start the docker service and enable it to run it every time at system boot.
systemctl start docker
systemctl enable docker
Grant privileges to manage Docker to non-root user (don’t have to use “sudo docker”)
sudo groupadd docker
sudo usermod -aG docker $USER
You can check it using the commands below:
systemctl status docker
docker —version
Step 2: Deploy the Rancher Server on the Master node
Login to the Master node and install Rancher. It is nothing more than running a container. Following the official docs, from your shell, enter the following command:
sudo docker run -d --restart=unless-stopped -p 80:80 -p 443:443 rancher/rancher
It will take some minutes to complete. Once it’s done, log in to Rancher by the IP https://<server_ip>
(replace <serverip> with your Master node IP)
Then, you will be asked to set a password for the admin account and confirm the Rancher Server URL
Step 3: Setup the Kubernetes (K8s) Cluster
After login into the Rancher dashboard, click “Add Cluster” on the upper right corner. Then, select From existing nodes (Custom) to continue.
Type Cluster name, keep other fields as default or customize them if needed
You will see the command to deploy Master and Worker nodes afterward:
There are two cases: single-node cluster and multi nodes cluster
Single Node Cluster:
If you only have one server play the role of both Master and Worker:
- Check all boxes in part 1 – Node Options (etcd, Control Plan, Worker)
- Then, copy the command in part 2 and run it on your shell on your server. The command will be looked like:
sudo docker run -d --privileged --restart=unless-stopped --net=host -v /etc/kubernetes:/etc/kubernetes -v /var/run:/var/run rancher/rancher-agent:v2.3.2 --server https://<server_ip> --token wxhkwshb69zjk76jfrgmw8z8raabbccf98xjkv4fh92gmcrcm6d26r --ca-checksum cc2ccdb2e5a2620a4daec8de9fb100daabbccad85d8c169a1b1ddaa6fe6895d5 --etcd --controlplane --worker
Multi Nodes Cluster:
If you have 2 nodes or more than, then one is Master and others are Worker. You should set up follow the following rules:
- Master node: check etcd and Control Plan and use the command in part 2 to run on Master node
- Worker node: check the only Worker and use the command in part 2 to run on all Worker nodes.
Note that Rancher uses the hostname of each server as the Node name by default. If you have 2 or more nodes with the same hostname, you should define the different Node names for each other. Otherwise, the latter nodes couldn’t be added to the Cluster.
After that, wait for the provisioning process (it could take some minutes). When it’s done, you can see all nodes are activated in the Nodes page
Step 4: Setup OpenFaaS – Serverless platform on Rancher K8s Cluster
OpenFaaS is a prevalent open-source platform for Serverless (besides OpenWhisk, Kubeless, Fission,…). OpenFaaS is Kubernetes-native and uses Deployments, Services, and Secrets. For more detail check out the “faas-netes” repository. Presently, OpenFaaS is not available in the library of Rancher so we will need to install it by hand. Once you have a cluster, you can follow these steps. I will deploy by kubectl, you can try other options (like using Helm or k3sup by find out on this page)
Install kubectl
Login to the Master node and run the following command on your shell
sudo snap install kubectl --classic
Put the Rancher Kubeconfig file into the Master node
Login to Kubernetes dashboard, on Cluster page, click Kubeconfig File on the upper right corner. You will see the kubeconfig
file in the new popup.
Then copy all and put this into the file in /home/<user-name>/kube/config
(create a new file if it does not exist).
Note that, you should change the permission of this file to ensure it could be accessible by the following command: sudo chmod 755 /home//.kube/config
Install OpenFaaS CLI
You can install the OpenFaaS CLI (to interact with CLI) using brew or a curl script.
Via curl:
curl -sL https://cli.openfaas.com | sudo sh
Via brew:
brew install faas-cli
Deploy OpenFaaS from faas-netes YAML and kubectl
Clone the repository:
git clone https://github.com/openfaas/faas-netes
Deploy the whole stack: This command is split into two parts so that the OpenFaaS namespaces are always created first:
openfaas
– for OpenFaaS servicesopenfaas-fn
– for functions
Enter to faas-netes folder and deploy openfass and openfaas-fn namespace
cd faas-netes
kubectl apply -f namespaces.yml --kubeconfig=/home/<user-name>/.kube/config
Create a password for the gateway:
# Generate a random password
PASSWORD=$(head -c 12 /dev/urandom | shasum| cut -d' ' -f1)
kubectl -n openfaas create secret generic basic-auth \
--from-literal=basic-auth-user=admin \
--from-literal=basic-auth-password="$PASSWORD"
Note: You can use your own password and remember it to login OpenFaaS UI. If using above command to generate a random password, then review and keep it (using echo $PASSWORD
)
Deploy OpenFaaS:
In faas-netes folder, run following command:
kubectl apply -f ./yaml --kubeconfig=/home/<user-name>/.kube/config
Add OpenFaaS Project to Rancher
Back to Rancher dashboard, navigate to Projects/Namespace, you will see 2 namespaces openfaas and openfaas-fn are created. Then, click Add Project on the upper right corner, enter Project Name (like openfaas or other up to you) and click Create. Next, select 2 openfaas namespaces and click Move button (on upper left corner) to move them to Project openfaas you have just created. Result:
When clicking on your project, you will see all your Workloads
Set up OpenFaaS gateway to access OpenFaaS UI
Select Load balancing section, then click Add Ingress on the upper right corner. Type Ingress name, select Target is gateway workload, port like 8080, keep others fields á default and click Save.
The result will be like the following:
Config Gateway Environment
export OPENFAAS_URL=gateway.openfaas.<your_gateway_IP>.xip.io
Now, you can access the OpenFaaS URL via the URL gateway.openfaas.<server-ip>.xip.io (in Targets) section and login with username admin and password in step 3
Congratulation! OpenFaaS deployment on Rancher is completed and you can play with Serverless now.