I had a little free time on hand and saw an e-mail by CSIT on a new mini-challenge. Since this topic is on Cloud Infrastructure, my domain, how could I miss it? 😄
The Challenge
data:image/s3,"s3://crabby-images/5ad3e/5ad3efbb3a81462be3202298db0273d0f00df147" alt=""
Background
data:image/s3,"s3://crabby-images/6cfc4/6cfc4e7922a3e3338ffc8fc73674e4040e4ba61d" alt=""
data:image/s3,"s3://crabby-images/00cc4/00cc4de491e1a534b97c3cec84480708ac2dedb1" alt=""
Tools for this challenge
This challenge is using killercoda for simulation where you get an environment for 1 hour to simulate the tasks. Cool!
data:image/s3,"s3://crabby-images/460a2/460a2affd19ac10f8872a3043c1ea0d5d9c920ad" alt=""
Task 1: The Murder Weapon
data:image/s3,"s3://crabby-images/9ef34/9ef3467974f803cacf08b054a085741d186f880d" alt=""
data:image/s3,"s3://crabby-images/c6fa0/c6fa0e6b7c4e05c13620289e130ace7a46bdb3fe" alt=""
The first task is pretty easy. Just use the command below to create a deployment. The -n default is kind of redundant as kubectl will default to the default namespace if -n is not specified.
kubectl create deployment investigation-unit --image=sachua/task-1:v0.0.1 -n default
Output:
data:image/s3,"s3://crabby-images/8b920/8b92030948ee4908c2f00f2bbc13014444709d95" alt=""
data:image/s3,"s3://crabby-images/1bda7/1bda7c27a626ebafa4de735129a0726e0a2102ab" alt=""
The command to retrieve flag is already given, just copy and paste 😄
kubectl logs -n default deployment/investigation-unit | sed 's/.*: //'
Output:
data:image/s3,"s3://crabby-images/6742f/6742f7e79a8fe8ec348c14c4ffae5edc1e26fee2" alt=""
Task 2: An Elusive Fingerprint
data:image/s3,"s3://crabby-images/94fd9/94fd99021666a79ab3ef876f8e4c88a97ae34273" alt=""
data:image/s3,"s3://crabby-images/65aff/65affa168674b79fb4aa22f519f8008b800f5194" alt=""
We will need to create 3 files for this Task:
- pv.yaml (Persistent Volume)
- pvc.yaml (Persistent Volume Claim)
- deployment.yaml (Deployment)
apiVersion: v1
kind: PersistentVolume
metadata:
name: analysis-unit-pv
spec:
storageClassName: manual
capacity:
storage: 1Gi
accessModes:
- ReadWriteOnce
hostPath:
path: /mnt/data
pv.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: analysis-unit-pvc
spec:
storageClassName: manual
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
pvc.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: analysis-unit
name: analysis-unit
namespace: default
spec:
replicas: 1
selector:
matchLabels:
app: analysis-unit
template:
metadata:
labels:
app: analysis-unit
spec:
containers:
- image: sachua/task-2:v0.0.1
name: task-2
volumeMounts:
- mountPath: /mnt/data
name: analysis-vol
volumes:
- name: analysis-vol
persistentVolumeClaim:
claimName: analysis-unit-pvc
deployment.yaml
Then we need to create the resources:
kubectl apply -f pv.yaml
kubectl apply -f pvc.yaml
kubectl apply -f deployment.yaml
Output:
data:image/s3,"s3://crabby-images/add41/add41a6bb0d814a980791448f610ae0fa37c870d" alt=""
We will see the logs of this pod to see what's inside.
data:image/s3,"s3://crabby-images/7dbed/7dbed462ad74f2d7a76d207f73db3efdf1f02ec7" alt=""
data:image/s3,"s3://crabby-images/5a227/5a22782523df928983981207491e57577b7c2027" alt=""
Output:
data:image/s3,"s3://crabby-images/9e4b2/9e4b27357e08410c20ce1a2bed36ecc51778b142" alt=""
Task 3: Identify The Culprit
data:image/s3,"s3://crabby-images/1392d/1392d979d71e286fe14012a59682ee931cdd19e2" alt=""
data:image/s3,"s3://crabby-images/5747e/5747e1b784ad6229232263918e2b690f26e709ab" alt=""
First, we will create a deployment named "command-center":
kubectl create deployment command-center --image=sachua/task-3:v0.0.1 -n default
Output:
data:image/s3,"s3://crabby-images/7a457/7a457230245b0d211824ecf345bf3493956d2190" alt=""
Then, we need to create the service yaml files:
- investigation-unit-svc.yaml
- analysis-unit-svc.yaml
kubectl create svc clusterip investigation-unit --tcp=80:80 --dry-run=client -o yaml > investigation-unit-svc.yaml
kubectl create svc clusterip analysis-unit --tcp=80:80 --dry-run=client -o yaml > analysis-unit-svc.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app: analysis-unit
name: analysis-unit
namespace: default
spec:
ports:
- name: http
port: 80
protocol: TCP
targetPort: 80
selector:
app: analysis-unit
type: ClusterIP
analysis-unit-svc.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app: investigation-unit
name: investigation-unit
namespace: default
spec:
ports:
- name: http
port: 80
protocol: TCP
targetPort: 80
selector:
app: investigation-unit
type: ClusterIP
investigation-unit-svc.yaml
Then create the 2 services:
kubectl apply -f analysis-unit-svc.yaml
kubectl apply -f investigation-unit-svc.yaml
Output:
data:image/s3,"s3://crabby-images/6bca9/6bca96132b5233188a262a69b2aca9378fd4f284" alt=""
data:image/s3,"s3://crabby-images/afa36/afa362caf3c93a7a989f8c1d6f5e5ae3e8a259f1" alt=""
Retrieve the flag by running the command!
kubectl logs -n default deployment/command-center | grep -im 1 culprit | sed 's/.*: //'
Output:
data:image/s3,"s3://crabby-images/73a22/73a22effebb954350f34ad15dc256f92603b6510" alt=""
Completion!
data:image/s3,"s3://crabby-images/674bb/674bb032ee5859c3944a7949bae4fda4fcecf1ec" alt=""
Submission of Flags
data:image/s3,"s3://crabby-images/2b211/2b2112b5d13df2280f157b302ff98dbae1d504e8" alt=""
data:image/s3,"s3://crabby-images/5b165/5b165484d1a6304bf7c253001b8d43ea7879e10c" alt=""
Badge
data:image/s3,"s3://crabby-images/261c9/261c967e8031e2b806e2a189c7b8dd1f40f98388" alt=""