In this section, you'll learn how to install Rancher using Google Kubernetes Engine.
- You will need a Google account.
- You will need a Google Cloud billing account. You can manage your Cloud Billing accounts using the Google Cloud Console. For more information about the Cloud Console, visit General guide to the console.
- You will need a cloud quota for at least one in-use IP address and at least 2 CPUs. For more details about hardware requirements for the Rancher server, refer to this section.
1. Enable the Kubernetes Engine API
Take the following steps to enable the Kubernetes Engine API:
- Visit the Kubernetes Engine page in the Google Cloud Console.
- Create or select a project.
- Open the project and enable the Kubernetes Engine API for the project. Wait for the API and related services to be enabled. This can take several minutes.
- Make sure that billing is enabled for your Cloud project. For information on how to enable billing for your project, refer to the Google Cloud documentation.
2. Open the Cloud Shell
Cloud Shell is a shell environment for managing resources hosted on Google Cloud. Cloud Shell comes preinstalled with the
gcloud command-line tool and kubectl command-line tool. The
gcloud tool provides the primary command-line interface for Google Cloud, and
kubectl provides the primary command-line interface for running commands against Kubernetes clusters.
The following sections describe how to launch the cloud shell from the Google Cloud Console or from your local workstation.
To launch the shell from the Google Cloud Console, go to the upper-right corner of the console and click the terminal button. When hovering over the button, it is labeled Activate Cloud Shell.
kubectl, perform the following steps:
Install the Cloud SDK by following these steps. The Cloud SDK includes the
gcloudcommand-line tool. The steps vary based on your OS.
After installing Cloud SDK, install the
kubectlcommand-line tool by running the following command:
gcloud components install kubectl
In a later step,
kubectlwill be configured to use the new GKE cluster.
Install Helm 3 if it is not already installed.
Enable Helm experimental support for OCI images with the
HELM_EXPERIMENTAL_OCIvariable. Add the following line to
~/.bash_profilein macOS, or wherever your shell stores environment variables):
Run the following command to load your updated
If you are running macOS, use this command:
3. Configure the gcloud CLI
Set up default gcloud settings using one of the following methods:
- Using gcloud init, if you want to be walked through setting defaults.
- Using gcloud config, to individually set your project ID, zone, and region.
- Using gcloud init
- Using gcloud config
Run gcloud init and follow the directions:
If you are using SSH on a remote server, use the --console-only flag to prevent the command from launching a browser:
gcloud init --console-only
Follow the instructions to authorize gcloud to use your Google Cloud account and select the new project that you created.
4. Confirm that gcloud is configured correctly
gcloud config list
The output should resemble the following:
region = us-west1 # Your chosen region
zone = us-west1-b # Your chosen zone
account = <Your email>
disable_usage_reporting = True
project = <Your project ID>
Your active configuration is: [default]
5. Create a GKE Cluster
The following command creates a three-node cluster.
cluster-name with the name of your new cluster.
When choosing a Kubernetes version, be sure to first consult the support matrix to find the highest version of Kubernetes that has been validated for your Rancher version.
Note: If the version of Kubernetes is updated to v1.22 or later, the version of ingress-nginx would also need to be updated.
gcloud container clusters create cluster-name --num-nodes=3 --cluster-version=<VERSION>
6. Get Authentication Credentials
After creating your cluster, you need to get authentication credentials to interact with the cluster:
gcloud container clusters get-credentials cluster-name
This command configures
kubectl to use the cluster you created.
7. Install an Ingress
The cluster needs an Ingress so that Rancher can be accessed from outside the cluster.
The following command installs an
nginx-ingress-controller with a LoadBalancer service:
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
helm repo update
helm upgrade --install \
ingress-nginx ingress-nginx/ingress-nginx \
--namespace ingress-nginx \
--set controller.service.type=LoadBalancer \
--version 4.0.18 \
8. Get the Load Balancer IP
To get the address of the load balancer, run:
kubectl get service ingress-nginx-controller --namespace=ingress-nginx
The result should look similar to the following:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-controller LoadBalancer 10.3.244.156 22.214.171.124 80:31876/TCP,443:32497/TCP 81s
9. Set up DNS
External traffic to the Rancher server will need to be directed at the load balancer you created.
Set up a DNS to point at the external IP that you saved. This DNS will be used as the Rancher server URL.
There are many valid ways to set up the DNS. For help, refer to the Google Cloud documentation about managing DNS records.
10. Install the Rancher Helm chart
Next, install the Rancher Helm chart by following the instructions on this page. The Helm instructions are the same for installing Rancher on any Kubernetes distribution.
Use the DNS name from the previous step as the Rancher server URL when you install Rancher. It can be passed in as a Helm option. For example, if the DNS name is
rancher.my.org, you could run the Helm installation command with the option
New in v2.6.7
When installing Rancher on top of this setup, you will also need to pass the value below into the Rancher Helm install command in order to set the name of the ingress controller to be used with Rancher's ingress resource:
Refer here for the Helm install command for your chosen certificate option.