Follow this step-by-step guide to set up Nuclio on Minikube, which is a tool that lets you run Kubernetes locally.
- Prerequisites
- Prepare Minikube
- Install Nuclio
- Deploy a function with the Nuclio CLI (nuctl)
- What's next
Before starting the set-up procedure, ensure that the following prerequisites are met:
-
The following components are installed on your installation machine:
-
The Nuclio CLI (
nuctl
) is installed — if you wish to use the CLI to deploy Nuclio functions. To install the CLI, simply download the appropriate CLI version to your installation machine. -
It's recommended that you use these drivers:
Start Minikube as you normally would. Note that the following command also enables role-based access control (RBAC) so that you can get more comfortable working with an RBAC-enabled Kubernetes cluster:
minikube start --kubernetes-version v1.20.11 --driver docker --extra-config=apiserver.authorization-mode=RBAC
Note: You may want to
- Change the Kubernetes version. Currently, the recommended version is 1.20.11.
- Change the minikube driver according to your environment and needs
- Add
--addons ingress
to yourminikube start
command to support creating function ingresses to flexibly expose your function. Ensure that your function ingress appears on your hosts file (/etc/hosts). You can do this by running this command:echo "$(minikube ip) my-function.info" | sudo tee -a /etc/hosts
Bring up a Docker registry inside Minikube. You'll later push your functions to this registry.
Note: We are bringing up a local, simple, insecure docker registry. Instead, you can skip this step, and use any other docker registry, such as Docker Hub, Azure Container Registry (ACR), or Google Container Registry (GCR). See Getting started with Kubernetes for instructions.
SSH into the minikube machine, and run the registry using docker
:
minikube ssh -- docker run -d -p 5000:5000 registry:2
Before Docker container images can be pushed to your newly created, insecure registry, you need to add its
address ($(minikube ip):5000
) to the list of insecure registries to instruct Docker to accept working against it:
- Docker for macOS - you can add it under Preferences | Daemon.
- Linux - follow the instructions in the Docker documentation.
At this stage you should have a functioning Kubernetes cluster, a Docker registry, and a working Kubernetes CLI (kubectl
), and you can proceed to install the Nuclio services on the cluster (i.e., deploy Nuclio).
Create a Nuclio namespace by running the following command:
Note: All Nuclio resources go into the "nuclio" namespace, and role-based access control (RBAC) is configured accordingly.
minikube kubectl -- create namespace nuclio
Add nuclio to helm repo charts: the following commands add Nuclio repo charts to your helm repos:
helm repo add nuclio https://nuclio.github.io/nuclio/charts
Deploy Nuclio to the cluster: the following command deploys Nuclio and its minimum required Kubernetes resources (including RBAC roles):
helm --namespace nuclio install nuclio nuclio/nuclio
Use the command minikube kubectl -- get pods --namespace nuclio
to verify both the controller and dashboard are running.
Run the following Nuclio CLI (nuctl
) command from a command-line shell to deploy the example helloworld
Go function.
You can add the --verbose
flag if you want to peek under the hood.
nuctl deploy helloworld \
--namespace nuclio \
--http-trigger-service-type nodePort \
--path https://raw.githubusercontent.com/nuclio/nuclio/master/hack/examples/golang/helloworld/helloworld.go \
--registry $(minikube ip):5000 \
--run-registry localhost:5000
Note: The command above exposes the function externally using a
nodePort
. This is done for demonstration purposes only. Please read more about exposing your function for more information.
Note: The difference between the two registries specified in this command, and the reason for their addresses being different is as follows:
- The
--registry
option defines the Docker registry onto which the function images that you build will be pushed. This is the registry that you previously brought up on your Minikube VM.- The
--registry-run
option defines the registry from which thekubelet
Kubernetes "node agent" will pull the function images. Because this operation occurs in the Minikube VM, the command specifieslocalhost
instead of the VM's IP address.
When the function deployment completes, you can get the function information by running the following CLI command:
nuctl get function helloworld
Sample output -
NAMESPACE | NAME | PROJECT | STATE | NODE PORT | REPLICAS
nuclio | helloworld | default | ready | 42089 | 1/1
You can see from the sample output that the deployed function helloworld
is running and using port 42089
.
Since the function is exposed using a nodePort
, you can run the following CLI command to invoke it:
nuctl invoke helloworld --method POST --body '{"hello":"world"}' --content-type "application/json"
Sample output -
> Response headers:
Server = nuclio
Date = Thu, 18 Jun 2020 06:56:27 GMT
Content-Type = application/text
Content-Length = 21
> Response body:
Hello, from Nuclio :]
See the following resources to make the best of your new Nuclio environment: