High Availability Kubernetes Using RKE in ServerStadium Part 3
After Kubernetes and Rancher is ready, we can continue to create simple application run on our Kubernetes Cluster
Please login to Rancher WEB UI using your Rancher URL
Create a Project in Rancher
Click Cluster Name; for this application, we choose local, then click Add Project button
data:image/s3,"s3://crabby-images/4a371/4a3710d1c86de2dfd30a4b306310ac694cc698fc" alt=""
data:image/s3,"s3://crabby-images/0ab5b/0ab5b31e1e81d07d7f498ebc3a0d670684f17a8e" alt=""
Insert the project name with the name Website, then click Create
data:image/s3,"s3://crabby-images/6d8ac/6d8ac9b5616cf46ec4fcfb86f0022f13a6dedb80" alt=""
Add Namespace
Select Website project, then we create a namespace in which the application will be deployed.
Click Add Namespace button, then Insert Name with nginx-ns
data:image/s3,"s3://crabby-images/db33e/db33e60fb317713c2419fad4568574c339682226" alt=""
data:image/s3,"s3://crabby-images/93294/932942f7b8a41bc315a78de698d141a8d797f587" alt=""
Click the dashboard, then Choose Project Website
data:image/s3,"s3://crabby-images/10acf/10acffc22b19c50d3d755eb7cb38697a3d39d3f6" alt=""
Click the Deploy button on the right side to deploy a simple application.
data:image/s3,"s3://crabby-images/2c0de/2c0dec7aaa33b1a127fdee89c3087a5d47a8e03d" alt=""
Fill in the value as the following screenshot
Name: nginx
Docker Image: nginx
Namespace: nginx-ns
Port Mapping:
Port Name: nginx
Public the container port: 80
Protocol: TCP
“As a” : NodePort
Then click Launch
data:image/s3,"s3://crabby-images/5b6e2/5b6e2dbac53bc5df499ece5ad7533c7982596f7a" alt=""
Let’s monitor until the deployment status is Active
data:image/s3,"s3://crabby-images/806fc/806fc4289a061be655f3904e37204bb129aa8ca8" alt=""
After deployment is successful, the Nginx application uses port 30350. In the next step, we will add this port to the Load Balancer in ServerStadium Cloud
data:image/s3,"s3://crabby-images/3b587/3b587c545eadce5a9b378cd002eff0665e9c9da0" alt=""
Add Port to Load Balancer
Create a Load balancer with Name nginx with Public Port 80 and the Private Port 30350
data:image/s3,"s3://crabby-images/33320/33320406429d8d6a0cdbcbf327159ed2eea5d804" alt=""
Edit nginx Load Balancer to assign All nodes
data:image/s3,"s3://crabby-images/3f5e0/3f5e0736c75694f223dd052791621fcba932280a" alt=""
Edit nginx Load balancer, then assign all nodes to the LB
data:image/s3,"s3://crabby-images/d4398/d4398011c9c09b690d5054363332ec52706ff542" alt=""
Add all nodes to the Load Balancer; we can access the Nginx using the IP Address of the Load Balancer
data:image/s3,"s3://crabby-images/5c408/5c4087b1fd1bf31adc093018e6f8229185fd1ca1" alt=""
Scaling a pod using Rancher is very simple. We only need to click the plus button on the right side.
data:image/s3,"s3://crabby-images/c53b1/c53b1bb07ee4546a4935aaf4ff2b1bc8c0b683ac" alt=""
After a while, we will see two dots under Active which means the nginx already has 2 pods
data:image/s3,"s3://crabby-images/14e04/14e04a5c7e99fe01cacf3c34f95703d122b17ecf" alt=""
Also, we can verify it using kubectl command. Please run the command below to verify the pods
# kubectl get pods
data:image/s3,"s3://crabby-images/6b66c/6b66cca8224b368f19d0616233a88c539097f694" alt=""
We can see the Rancher and kubectl command has the same result.
Add Helm Repository through Rancher
Helm is Package Manager of Kubernetes like apt and yum. We can add the repository and then choose the application that you would like to be installed. Click Apps, then choose Manage Catalogs.
data:image/s3,"s3://crabby-images/e0c5e/e0c5e04d391aca1474c00d967059e2307070500d" alt=""
After that, we will see the default three repositories of rancher
data:image/s3,"s3://crabby-images/faa09/faa09277a5d2b111de9be8ebc9d6e851a99d5259" alt=""
Click Add Catalog button to add the repository. In this tutorial, we will add the Bitnami Helm repository
Name: Bitnami
Catalog URL: https://charts.bitnami.com/bitnami
Helm Version: Helm v3
Then click Create
data:image/s3,"s3://crabby-images/3028a/3028a5ce2cffd7444c79c330d781f19c1108168d" alt=""
After Bitnami Repository has been added, we can continue to deploy the application.
Deploy / Launch Apache from Helm Repository
We will deploy Apache in the Kubernetes cluster. Click the Launch Button the search Apache
data:image/s3,"s3://crabby-images/13b6b/13b6bf0caca8971a6d5bf81cab5de4cf1033ce5f" alt=""
On the new screen, we will see many applications on Kubernetes. Just type Apache the click the Apache to continue the deployment
data:image/s3,"s3://crabby-images/c55b5/c55b51b944d3f89ac9c88160d738ed2f53b55753" alt=""
Fill the field as follow :
Name: apache
Namespace: apache
Then Click the Launch button
data:image/s3,"s3://crabby-images/90b8f/90b8f03b4c0fe228bd77b020fb36a60e9ab7ae70" alt=""
Click Apps to see the status of Apache deployment
data:image/s3,"s3://crabby-images/c2163/c21637f8355bf4582de2e43b8ce61b885ecdb603" alt=""
Let’s find the service port of the Apache using kubectl in the Apache namespace
# kubectl get svc -n apache
data:image/s3,"s3://crabby-images/b251c/b251c439af2f86fb1f376056609c85405744a756" alt=""
In here, we get port 30560, which we can set on the Load Balancer of ServerStadium Cloud. Add new Load Balancer configuration as follow.
data:image/s3,"s3://crabby-images/8991a/8991ae5dbf4047cc701f35ef4df17ca368404bf1" alt=""
Then assign all nodes to this Load Balancer IP Address. Verify the Apache deployment by accessing the website using the URL
data:image/s3,"s3://crabby-images/e4dd2/e4dd26b4487e75dfba73a09454f5cf71a482a0e7" alt=""
Finally, we successfully installed Kubernetes and deployed a simple application, Nginx and Apache, in ServerStadium Cloud.
Please feel free to submit your question to our Support if you need more assistance.
Missed something? You can always re-read the article part 1 and part 2. Ready to have your High Availability in Kubernetes Using RKE? Try it in ServerStadium Cloud now; sign up here.