This is a diagram that I have used for this lab.
data:image/s3,"s3://crabby-images/0dec8/0dec86cc2aef111ccf89f8b35de67da61b735391" alt=""
I have used the following link to deploy the PHP Guestbook application with Redis (https://kubernetes.io/docs/tutorials/stateless-application/guestbook/)
Set up an Ubuntu Linux with 2GB RAM and 30GB storage for the Kubernetes host. Allow SSH and HTTP from anywhere to the Linux instance on Security Group.
data:image/s3,"s3://crabby-images/3092e/3092e6c642638a6b92e70a37e97c4613018f2cc1" alt=""
+ Deployment Redis Database.
Creating the Redis Deployment
#nano redis-leader-deployment.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis-leader
labels:
app: redis
role: leader
tier: backend
spec:
replicas: 1
selector:
matchLabels:
app: redis
template:
metadata:
labels:
app: redis
role: leader
tier: backend
spec:
containers:
- name: leader
image: "docker.io/redis:6.0.5"
resources:
requests:
cpu: 100m
memory: 100Mi
ports:
- containerPort: 6379
#Apply the Redis deployment.
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/redis-leader-deployment.yaml
# Check Redis Pod is running
microk8s kubectl get pods
# View logs from the Redis leader Pod
microk8s kubectl logs -f deployment/redis-leader
data:image/s3,"s3://crabby-images/6684d/6684dc05fbc9063390747178a4852bc399187b32" alt=""
+ Creating the Redis leader Service
#Apply a service to proxy the traffic to the Redis Pod.
#nano redis-leader-service.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: v1
kind: Service
metadata:
name: redis-leader
labels:
app: redis
role: leader
tier: backend
spec:
ports:
- port: 6379
targetPort: 6379
selector:
app: redis
role: leader
tier: backend
#Apply the Redis Service with the deployment file.
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/redis-leader-service.yaml
#verify that the Redis service is running
microk8s kubectl get service
data:image/s3,"s3://crabby-images/b0015/b0015d26ab097351a607c63e08a49b359a7016de" alt=""
+ Set up Redis followers to make it highly available on a few Redis followers.
#nano redis-follower-deployment.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis-follower
labels:
app: redis
role: follower
tier: backend
spec:
replicas: 2
selector:
matchLabels:
app: redis
template:
metadata:
labels:
app: redis
role: follower
tier: backend
spec:
containers:
- name: follower
image: gcr.io/google_samples/gb-redis-follower:v2
resources:
requests:
cpu: 100m
memory: 100Mi
ports:
- containerPort: 6379
#Apply the Redis Deployment for the redis-follower-deployment.yaml file.
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/redis-follower-deployment.yaml
# Verify two Redis follower replicas are running.
microk8s kubectl get pods
data:image/s3,"s3://crabby-images/9d0d1/9d0d1d0d01da81ee60c88a66483f705efe6601b7" alt=""
+ Creating the Redis follower service.
#nano redis-follower-service.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: v1
kind: Service
metadata:
name: redis-follower
labels:
app: redis
role: follower
tier: backend
spec:
ports:
# the port that this service should serve on
- port: 6379
selector:
app: redis
role: follower
tier: backend
#Apply the Redis Service with the deployment file.
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/redis-follower-service.yaml
# verify that the Redis service is running.
microk8s kubectl get service
data:image/s3,"s3://crabby-images/dc9b6/dc9b67ad173f69db11ed172792bb7eeec12b574b" alt=""
+ Set up and Expose the Guestbook Frontend.
#Creating Guestbook Frontend Deployment.
#nano frontend-deployment.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: apps/v1
kind: Deployment
metadata:
name: frontend
spec:
replicas: 3
selector:
matchLabels:
app: guestbook
tier: frontend
template:
metadata:
labels:
app: guestbook
tier: frontend
spec:
containers:
- name: php-redis
image: gcr.io/google_samples/gb-frontend:v5
env:
- name: GET_HOSTS_FROM
value: "dns"
resources:
requests:
cpu: 100m
memory: 100Mi
ports:
- containerPort: 80
#Apply the frontend Deployment file
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/frontend-deployment.yaml
#Verify three frontend replicas are running.
microk8s kubectl get pods -l app=guestbook -l tier=frontend
data:image/s3,"s3://crabby-images/d906a/d906adb76f705cad9323779fd9e81a16bdafd9d6" alt=""
+ Creating the Frontend Service.
#nano frontend-service.yaml
# SOURCE: https://cloud.google.com/kubernetes-engine/docs/tutorials/guestbook
apiVersion: v1
kind: Service
metadata:
name: frontend
labels:
app: guestbook
tier: frontend
spec:
# if your cluster supports it, uncomment the following to automatically create
# an external load-balanced IP for the frontend service.
# type: LoadBalancer
#type: LoadBalancer
ports:
# the port that this service should serve on
- port: 80
selector:
app: guestbook
tier: frontend
#Apply the frontend Service with the deployment file.
microk8s kubectl apply -f https://k8s.io/examples/application/guestbook/frontend-service.yaml
#Verify three frontend replicas are running.
microk8s kubectl get services
data:image/s3,"s3://crabby-images/9c5ad/9c5ad3a89e11ad5bfa629aa502bc2a6d5e62d9c2" alt=""
#Check the Frontend Service via LoadBalancer
microk8s kubectl get service frontend
data:image/s3,"s3://crabby-images/c13d1/c13d15c76fcbca391751611dcf19b18fb110fc46" alt=""
+ Scale the Web Frontend.
microk8s kubectl scale deployment frontend --replicas=5
microk8s kubectl get pods
microk8s kubectl scale deployment frontend --replicas=2
microk8s kubectl get pods
data:image/s3,"s3://crabby-images/0f64f/0f64fcf491c436ab44d3b950ad6434b2ffc7a48e" alt=""
#check frontend service.
data:image/s3,"s3://crabby-images/431de/431de728331748ae99fea16e659c9e1268661044" alt=""
data:image/s3,"s3://crabby-images/7f38b/7f38be91667263322c669e12a52cdbeaae928b9c" alt=""
+ Expose port 80 via public IP address on Kubernetes host (10.0.0.10). This allows accessing PHP Guestbook from outside.
microk8s kubectl patch svc frontend -n default -p '{"spec": {"type": "LoadBalancer", "externalIPs":["10.0.0.10"]}}'
data:image/s3,"s3://crabby-images/66862/66862045e96c0019c4d6247c60d3f93ae708cb1d" alt=""
data:image/s3,"s3://crabby-images/478a6/478a67a2b2ff6efd5b1022a9bd1ed2b8442cb1a6" alt=""
data:image/s3,"s3://crabby-images/eb70b/eb70b2a3666299a7d3005b3b47163c533d14b6ae" alt=""
Access PHP Guestbook from the Internet (http://54.165.173.81).
data:image/s3,"s3://crabby-images/4b3f5/4b3f5e594758cd84c50947bbe4ef0f860c8fae56" alt=""