Bird
Raised Fist0
Kubernetesdevops~20 mins

Why advanced patterns matter in Kubernetes - Challenge Your Understanding

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Challenge - 5 Problems
🎖️
Kubernetes Advanced Patterns Master
Get all challenges correct to earn this badge!
Test your skills under time pressure!
🧠 Conceptual
intermediate
2:00remaining
Why use advanced Kubernetes deployment patterns?

Which reason best explains why advanced deployment patterns like Blue-Green or Canary are important in Kubernetes?

AThey allow updating applications without downtime and reduce risk by gradual rollout.
BThey make the cluster use less memory by deleting old pods immediately.
CThey automatically fix all bugs in the application code during deployment.
DThey increase the number of replicas to maximum for faster scaling.
Attempts:
2 left
💡 Hint

Think about how users experience updates and how errors can be caught early.

💻 Command Output
intermediate
1:30remaining
Output of a rolling update command

What is the expected output when running this command in Kubernetes?

kubectl rollout status deployment/myapp
ANo resources found in default namespace
Bdeployment "myapp" successfully rolled out
Cerror: deployment "myapp" not found
Ddeployment "myapp" paused
Attempts:
2 left
💡 Hint

This command checks if the deployment finished updating.

🔀 Workflow
advanced
2:30remaining
Order of steps in a Canary deployment

Arrange these steps in the correct order for performing a Canary deployment in Kubernetes.

A1,2,3,4
B2,1,3,4
C1,3,2,4
D3,1,2,4
Attempts:
2 left
💡 Hint

Think about deploying first, then watching, then increasing traffic.

Troubleshoot
advanced
2:00remaining
Troubleshooting failed rolling update

You ran kubectl rollout restart deployment/myapp but the new pods keep crashing. What is the most likely cause?

AThe cluster ran out of CPU resources.
BThe service selector labels do not match pods.
CThe deployment was paused before restart.
DThe new container image has a bug causing crashes.
Attempts:
2 left
💡 Hint

New pods crashing usually means something wrong inside the container.

Best Practice
expert
3:00remaining
Best practice for managing secrets in Kubernetes

Which option is the best practice for securely managing sensitive data like passwords in Kubernetes?

AUse ConfigMaps to store all sensitive data for simplicity.
BInclude passwords directly in container environment variables in the Deployment YAML.
CStore secrets in Kubernetes Secrets objects and enable encryption at rest.
DCommit secrets in plain text to the Git repository for easy access.
Attempts:
2 left
💡 Hint

Think about security and encryption when storing secrets.

Practice

(1/5)
1. Why is it important to use advanced patterns in Kubernetes deployments?
easy
A. They reduce the need for monitoring and logging.
B. They make the YAML files shorter but less readable.
C. They improve scalability and reliability of applications.
D. They allow running Kubernetes without any configuration.

Solution

  1. Step 1: Understand the role of advanced patterns

    Advanced patterns help manage complex deployments by improving how applications scale and recover from failures.
  2. Step 2: Evaluate the options

    Only They improve scalability and reliability of applications. correctly states that advanced patterns improve scalability and reliability, which are key goals in Kubernetes.
  3. Final Answer:

    They improve scalability and reliability of applications. -> Option C
  4. Quick Check:

    Advanced patterns = better scalability and reliability [OK]
Hint: Think about what helps apps run well at scale [OK]
Common Mistakes:
  • Confusing shorter YAML with better patterns
  • Assuming no need for monitoring with advanced patterns
  • Believing Kubernetes runs without configuration
2. Which of the following is the correct syntax to define a Kubernetes Deployment with a rolling update strategy?
easy
A. apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n type: RollingUpdate\n replicas: 3
B. apiVersion: v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n type: Recreate\n replicas: 3
C. apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n rollingUpdate:\n maxSurge: 1\n maxUnavailable: 0\n replicas: 3
D. apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n replicas: 3

Solution

  1. Step 1: Identify correct apiVersion and kind

    Deployments use apiVersion 'apps/v1' and kind 'Deployment'. Options A, C, and D use this correctly.
  2. Step 2: Check strategy type for rolling update

    RollingUpdate strategy requires 'strategy.type: RollingUpdate' as in apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n type: RollingUpdate\n replicas: 3. apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n rollingUpdate:\n maxSurge: 1\n maxUnavailable: 0\n replicas: 3 misses 'type' field, so it's incomplete.
  3. Final Answer:

    apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n type: RollingUpdate\n replicas: 3 -> Option A
  4. Quick Check:

    RollingUpdate strategy syntax = apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: myapp\nspec:\n strategy:\n type: RollingUpdate\n replicas: 3 [OK]
Hint: Look for 'strategy.type: RollingUpdate' in spec [OK]
Common Mistakes:
  • Using wrong apiVersion for Deployment
  • Missing 'type' under strategy for rolling update
  • Confusing Recreate with RollingUpdate strategy
3. Given the following Kubernetes YAML snippet, what will be the result of applying it?
apiVersion: apps/v1
kind: Deployment
metadata:
  name: test-deploy
spec:
  replicas: 2
  selector:
    matchLabels:
      app: test
  template:
    metadata:
      labels:
        app: test
    spec:
      containers:
      - name: test-container
        image: nginx:1.19
        ports:
        - containerPort: 80
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
medium
A. Deployment will create 3 pods permanently due to maxSurge setting.
B. Deployment will create 2 pods with rolling update allowing 1 extra pod during updates.
C. Deployment will fail because maxUnavailable cannot be zero.
D. Deployment will create only 1 pod because maxUnavailable is zero.

Solution

  1. Step 1: Understand replicas and rolling update settings

    The deployment requests 2 replicas. maxSurge: 1 allows 1 extra pod temporarily during updates, maxUnavailable: 0 means no pods go down during update.
  2. Step 2: Analyze the effect on pod count

    During rolling update, Kubernetes can create up to 3 pods (2 + 1 surge) temporarily, but final stable state is 2 pods running.
  3. Final Answer:

    Deployment will create 2 pods with rolling update allowing 1 extra pod during updates. -> Option B
  4. Quick Check:

    maxSurge=1 means 1 extra pod allowed temporarily [OK]
Hint: maxSurge adds temporary pods, doesn't increase final replicas [OK]
Common Mistakes:
  • Thinking maxSurge adds permanent pods
  • Believing maxUnavailable cannot be zero
  • Confusing maxUnavailable with pod count
4. You applied a Deployment with this strategy:
strategy:
  type: RollingUpdate
  rollingUpdate:
    maxSurge: 2
    maxUnavailable: 2
But during updates, you notice downtime. What is the likely cause?
medium
A. maxUnavailable is too high, allowing pods to be down simultaneously.
B. maxSurge is too low, preventing new pods from starting.
C. RollingUpdate strategy requires maxUnavailable to be zero.
D. Deployment replicas must be at least 5 for this strategy.

Solution

  1. Step 1: Understand maxUnavailable impact

    maxUnavailable: 2 means up to 2 pods can be unavailable during update, which can cause downtime if replicas are low.
  2. Step 2: Connect downtime to maxUnavailable setting

    If too many pods are down at once, service becomes unavailable, causing downtime.
  3. Final Answer:

    maxUnavailable is too high, allowing pods to be down simultaneously. -> Option A
  4. Quick Check:

    High maxUnavailable = possible downtime [OK]
Hint: Keep maxUnavailable low to avoid downtime during updates [OK]
Common Mistakes:
  • Assuming maxSurge controls downtime
  • Believing maxUnavailable must be zero always
  • Thinking replicas count must be 5 for rolling updates
5. You want to deploy a microservices app on Kubernetes with zero downtime and automatic rollback on failure. Which advanced pattern combination should you use?
hard
A. Use BlueGreen deployment without readiness or liveness probes.
B. Use Recreate strategy with liveness probes and no rollback settings.
C. Use RollingUpdate strategy without probes and manual rollback.
D. Use RollingUpdate strategy with readiness probes and set 'progressDeadlineSeconds' for rollback.

Solution

  1. Step 1: Identify zero downtime and rollback requirements

    RollingUpdate strategy allows gradual pod replacement for zero downtime. Readiness probes ensure traffic only goes to healthy pods. 'progressDeadlineSeconds' triggers rollback if update stalls.
  2. Step 2: Evaluate options for best fit

    Use RollingUpdate strategy with readiness probes and set 'progressDeadlineSeconds' for rollback. combines RollingUpdate, readiness probes, and rollback settings, meeting all requirements. Others miss probes or rollback automation.
  3. Final Answer:

    Use RollingUpdate strategy with readiness probes and set 'progressDeadlineSeconds' for rollback. -> Option D
  4. Quick Check:

    RollingUpdate + readiness probes + rollback = zero downtime + auto rollback [OK]
Hint: Combine RollingUpdate, readiness probes, and rollback for smooth deploys [OK]
Common Mistakes:
  • Ignoring readiness probes causing downtime
  • Using Recreate strategy which causes downtime
  • Skipping rollback configuration