Bird
Raised Fist0
Kubernetesdevops~10 mins

Event inspection for diagnostics in Kubernetes - Interactive Code Practice

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
Practice - 5 Tasks
Answer the questions below
1fill in blank
easy

Complete the command to list all events in the default namespace.

Kubernetes
kubectl get [1]
Drag options to blanks, or click blank then click option'
Apods
Bservices
Cnodes
Devents
Attempts:
3 left
💡 Hint
Common Mistakes
Using 'pods' instead of 'events' will list pods, not events.
Using 'nodes' or 'services' will show unrelated resources.
2fill in blank
medium

Complete the command to describe a specific event named 'my-event'.

Kubernetes
kubectl describe [1] my-event
Drag options to blanks, or click blank then click option'
Aevent
Bpod
Cservice
Dnode
Attempts:
3 left
💡 Hint
Common Mistakes
Using 'pod' or 'service' will try to describe the wrong resource type.
Using 'node' will describe a node, not an event.
3fill in blank
hard

Fix the error in the command to get events from the 'kube-system' namespace.

Kubernetes
kubectl get events -n [1]
Drag options to blanks, or click blank then click option'
Adefault
Bdev
Ckube-system
Dproduction
Attempts:
3 left
💡 Hint
Common Mistakes
Using 'default' will show events from the default namespace, not 'kube-system'.
Using 'production' or 'dev' may cause errors if those namespaces don't exist.
4fill in blank
hard

Fill both blanks to filter events by reason 'Failed' in the 'default' namespace.

Kubernetes
kubectl get events -n [1] --field-selector reason=[2]
Drag options to blanks, or click blank then click option'
Adefault
Bkube-system
CFailed
DStarted
Attempts:
3 left
💡 Hint
Common Mistakes
Using the wrong namespace will show no or unrelated events.
Using 'Started' instead of 'Failed' will filter different events.
5fill in blank
hard

Fill all three blanks to create a JSON output of events filtered by type 'Warning' in 'kube-system' namespace.

Kubernetes
kubectl get events -n [1] --field-selector type=[2] -o [3]
Drag options to blanks, or click blank then click option'
Adefault
Bkube-system
CWarning
Djson
Attempts:
3 left
💡 Hint
Common Mistakes
Using 'default' namespace will not show system events.
Using 'Started' instead of 'Warning' filters wrong event types.
Forgetting '-o json' outputs default table format.

Practice

(1/5)
1. What is the primary purpose of Kubernetes events when diagnosing cluster issues?
easy
A. To deploy new applications to the cluster
B. To permanently store all logs from containers
C. To configure network policies automatically
D. To show what is happening inside the cluster in real-time

Solution

  1. Step 1: Understand Kubernetes events role

    Kubernetes events provide information about actions and changes happening inside the cluster, like pod starts or errors.
  2. Step 2: Differentiate from other cluster functions

    Events are not for storing logs, configuring policies, or deploying apps; they are for showing cluster activity.
  3. Final Answer:

    To show what is happening inside the cluster in real-time -> Option D
  4. Quick Check:

    Events = cluster activity info [OK]
Hint: Events show cluster actions and changes live [OK]
Common Mistakes:
  • Confusing events with logs storage
  • Thinking events deploy apps
  • Assuming events configure network
2. Which of the following commands correctly lists recent Kubernetes events sorted by timestamp?
easy
A. kubectl get events --sort-by=.metadata.creationTimestamp
B. kubectl describe events --sort=timestamp
C. kubectl events list --order=asc
D. kubectl get pods --events

Solution

  1. Step 1: Identify correct kubectl syntax for events

    The command to list events is 'kubectl get events'. To sort by timestamp, use '--sort-by=.metadata.creationTimestamp'.
  2. Step 2: Check other options for syntax errors

    'kubectl describe events' does not support '--sort', 'kubectl events list' is invalid, and 'kubectl get pods --events' is not a valid flag.
  3. Final Answer:

    kubectl get events --sort-by=.metadata.creationTimestamp -> Option A
  4. Quick Check:

    Correct command = kubectl get events --sort-by=.metadata.creationTimestamp [OK]
Hint: Use --sort-by=.metadata.creationTimestamp with kubectl get events [OK]
Common Mistakes:
  • Using invalid flags like --sort or --order
  • Trying to list events with kubectl describe
  • Confusing pods command with events
3. Given the command kubectl get events --field-selector involvedObject.kind=Pod --sort-by=.lastTimestamp, what is the expected output?
medium
A. A list of all Pods sorted by creation time
B. A list of all events related to Pods sorted by the last event time
C. An error because --field-selector is invalid with events
D. A list of all nodes with their event counts

Solution

  1. Step 1: Understand the command filters and sorting

    The command filters events to only those involving Pods using '--field-selector involvedObject.kind=Pod' and sorts them by '.lastTimestamp'.
  2. Step 2: Interpret the output type

    The output will be events related to Pods, not Pods themselves or nodes, and no syntax error occurs.
  3. Final Answer:

    A list of all events related to Pods sorted by the last event time -> Option B
  4. Quick Check:

    Field selector filters events by Pod, sorted by lastTimestamp [OK]
Hint: Field selector filters events; sort-by orders by timestamp [OK]
Common Mistakes:
  • Thinking it lists Pods instead of events
  • Assuming syntax error with field-selector
  • Confusing nodes with Pods
4. You run kubectl get events --sort-by=.metadata.lastTimestamp but get an error: "error: unknown field selector: .metadata.lastTimestamp". What is the likely cause?
medium
A. Mixing --sort-by with an invalid field selector syntax
B. Trying to sort by a field not supported for sorting events
C. Using --sort-by with an incorrect field path for events
D. Using --sort-by with a field selector syntax instead of sorting

Solution

  1. Step 1: Analyze the error message

    The error says "unknown field selector" which suggests the field path used with --sort-by is incorrect for events.
  2. Step 2: Verify correct field path for sorting events

    The correct field path for sorting events by last occurrence time is '.lastTimestamp' (root level field). '.metadata.lastTimestamp' does not exist, causing the unknown field error.
  3. Step 3: Identify the most accurate cause

    Using --sort-by with an incorrect field path for events correctly states the issue is an incorrect field path for sorting events, causing the error.
  4. Final Answer:

    Using --sort-by with an incorrect field path for events -> Option C
  5. Quick Check:

    Incorrect field path in --sort-by causes error [OK]
Hint: Check field path spelling and validity for --sort-by [OK]
Common Mistakes:
  • Confusing --sort-by with --field-selector
  • Assuming syntax error in command structure
  • Ignoring field path case sensitivity
5. You want to monitor only warning events related to Pods in the default namespace and see the newest events first. Which command achieves this?
hard
A. kubectl get events -n default --field-selector type=Warning,involvedObject.kind=Pod --sort-by=.lastTimestamp
B. kubectl get events -n default --field-selector type=Warning,involvedObject.kind=Pod --sort-by=.metadata.creationTimestamp
C. kubectl get events --field-selector type=Warning,involvedObject.kind=Pod -n default --sort-by=.metadata.lastTimestamp
D. kubectl get pods -n default --filter type=Warning --sort-by=.lastTimestamp

Solution

  1. Step 1: Filter events by type and involved object

    Use '--field-selector type=Warning,involvedObject.kind=Pod' to get warning events related to Pods.
  2. Step 2: Specify namespace and sort order

    Use '-n default' for the default namespace and '--sort-by=.lastTimestamp' to sort newest events first.
  3. Step 3: Evaluate options

    kubectl get events -n default --field-selector type=Warning,involvedObject.kind=Pod --sort-by=.lastTimestamp correctly combines all requirements. kubectl get events --field-selector type=Warning,involvedObject.kind=Pod -n default --sort-by=.metadata.lastTimestamp has wrong sort field, B uses creationTimestamp which sorts oldest first, D is invalid as it targets pods, not events.
  4. Final Answer:

    kubectl get events -n default --field-selector type=Warning,involvedObject.kind=Pod --sort-by=.lastTimestamp -> Option A
  5. Quick Check:

    Filter warnings on Pods, default namespace, sort by lastTimestamp [OK]
Hint: Filter warnings on Pods, sort by lastTimestamp for newest first [OK]
Common Mistakes:
  • Using wrong sort field for newest events
  • Filtering pods instead of events
  • Omitting namespace or using wrong flags