CKA, former CKAD Flashcards
Ingress vs egress ?
Ingress enables external traffic to reach containers, while egress enables containers to reach external resources. Ingress is typically used for exposing web applications and APIs to the outside world, while egress is used for accessing databases and other services outside of the cluster.
why do i do need livenessprobe?
Caution: Liveness probes can be a powerful way to recover from application failures, but they should be used with caution. Liveness probes must be configured carefully to ensure that they truly indicate unrecoverable application failure, for example a deadlock.
ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
whats special when configured using goproxy?
it need to come with readinessProbe of its own cause its a 2-step rocket
Difference in CKA vs CKAD exam allowed doc. sources?
CKA or CKAD: use the browser within the VM to access the following documentation:
https://kubernetes.io/docs/, https://kubernetes.io/blog/ and their subdomains. This includes all available language translations of these pages (e.g. https://kubernetes.io/zh/docs/)
CKAD only: https://helm.sh/docs
See here for all details: https://docs.linuxfoundation.org/tc-docs/certification/certification-resources-allowed#certified-kubernetes-administrator-cka-and-certified-kubernetes-application-developer-ckad
a tip how to search for multiple container pod yaml in the allowed documentation?
search two containers maybe? i found nginx and debian container in one pod yaml!
Which of the following commands will run a command inside an active container?
A. kubectl exec
B. kubectl run
C. kubectl create
D. kubectl describe
kubectl exec -i -t my-pod –container main-app – /bin/bash.
what does nodeSelector can be good for?
The nodeSelector: entry in the podspec could use this label to cause a pod to be deployed on a particular node with an entry such as:
P.s. Poor mans affinity option from what i understood later.
Can you name some built-in object labels?
There are several built-in object labels. For example nodes have labels such as the arch, hostname, and os, which could be used for assigning pods to a particular node, or type of node.
whats an ambassador in kubernetes?
It is “an open source, Kubernetes-native API gateway for microservices built on Envoy”.
It allows for access to the outside world without having to implement a service or another entry in an ingress controller: proxy local connection, reverse proxy, limits HTTP requests, re-route from the main container to the outside world.
Whats an initContainer?
The use of an initContainer allows one or more containers to run only if one or more previous containers run and exit successfully. For example, you could have a checksum verification scan container and a security scan container check the intended containers. Only if both containers pass the checks would the following group of containers be attempted. You can see a simple example below:
spec:
containers:
- name: intended
image: workload
initContainers:
- name: scanner
image: scanapp
Can k8s deployments be described in other terms?
This controller, or operator, is an agent to create and manage one or more instances of a specific stateful application. We have worked with built-in controllers such for Deployments and other resources.
The addition of a Custom Resource Definition can be handled through exactly what?
The addition of a Custom Resource Definition will be added to the cluster API path, currently under apiextensions.k8s.io/v1.
What does An option spec field is .spec.concurrencyPolicy used for?
An option spec field is .spec.concurrencyPolicy which determines how to handle existing jobs, should the time segment expire. If set to Allow, the default, another concurrent job will be run, and twice as many pods would be running. If set to Forbid, the current job continues and the new job is skipped. A value of Replace cancels the current job and the controlled pods, and starts a new job in its place.
Q. lab 4.1????: Verify your nodes are using a CNI plugin. Read through the startup process of CNI. Each message begins with a type ofmessage and a time stamp, followed by the details of the message. UseTABto complete for your node name. Examineboth the controller and one of your proxy pods
Those are the messages, dont see any type of message in the begining: I1212 11:23:19.028798 1 replica_set.go:205] Starting replicationcontroller controller
I1212 11:23:19.028813 1 shared_informer.go:252] Waiting for caches to sync for ReplicationC
ontroller
how many layers are there in the context of k8s CNI and what are their names?
1) physical is not talked about according to chatgpt
2) Layer 2 - Data Link Layer: This layer is responsible for node-to-node data transfer and handles things like MAC addressing, Ethernet framing, VLAN tagging, and error detection. CNI plugins operating at this layer manage how data is transferred within the same network segment or VLAN.
Layer 3 - Network Layer: This layer deals with IP addressing and routing. It is responsible for moving packets across network boundaries. CNI plugins operating at this layer are involved in routing and IP address assignment for pods.
Layer 4 - Transport Layer: While not directly managed by CNI plugins, this layer, which handles protocols like TCP and UDP, is relevant in the overall Kubernetes networking picture, particularly in services, ingress, and egress operations.
how is OSI organised?
Layer 1 - Physical Layer: This is the most fundamental layer, dealing with the transmission of raw bits over a physical medium. It includes things like cable types, electrical signals, and data rates. It’s the foundation upon which all higher layers are built.
Layer 2 - Data Link Layer: This layer is responsible for node-to-node data transfer and operates on frames. It handles things like physical addressing (MAC addresses), error detection and correction, and defines the protocol to establish and terminate a connection between two physically connected devices.
Layer 3 - Network Layer: The Network Layer is concerned with the routing of packets across different networks. It deals with logical addressing (IP addresses) and determines how data is sent to its destination through routing.
Layer 4 - Transport Layer: This layer provides end-to-end communication services for applications. It ensures complete data transfer and is responsible for error recovery and flow control. Protocols like TCP and UDP operate at this layer.
Layer 5 - Session Layer: This layer manages sessions between applications. It establishes, manages, and terminates connections between applications.
Layer 6 - Presentation Layer: It translates data between the application layer and the network. It’s responsible for data encryption, decryption, compression, and conversion.
Layer 7 - Application Layer: The highest layer of the OSI model, it provides services directly to user applications. It deals with network services that support applications.
Come up with questions about support of these features in k8s CNI projects: about support for vxlands, which layer is supported, network policies support, support for encryption of tcp and udp trafic and more? Here is what chatgpt 4 said:
Enhanced Kubernetes CNI Providers Comparison
Calico
Network Layer Support: Layer 3.
VXLAN Support: Yes, offers both VXLAN and IP-in-IP encapsulation.
Network Policies: Advanced network policy enforcement.
Encryption Support: Supports WireGuard for encrypting traffic.
Use Cases: High-performance, security-focused environments; advanced policy management.
Calico with Canal
Network Layer Support: Combines Layer 2 (Flannel) and Layer 3 (Calico).
VXLAN Support: Inherits VXLAN support from both Calico and Flannel.
Network Policies: Advanced, from Calico.
Encryption Support: Supports encryption via Calico (WireGuard).
Use Cases: Environments needing both simple setup (Flannel) and advanced policy control (Calico).
Flannel
Network Layer Support: Primarily Layer 2.
VXLAN Support: Yes, focuses on simplicity in VXLAN implementation.
Network Policies: Basic support, not as advanced as Calico.
Encryption Support: Does not natively support encryption of traffic.
Use Cases: Smaller, simpler Kubernetes setups; focus on ease of deployment.
Cilium
Network Layer Support: Layer 3, with eBPF-based networking.
VXLAN Support: Yes, along with other encapsulation formats.
Network Policies: Highly advanced, with eBPF-powered security features.
Encryption Support: Strong support for encryption, including transparent encryption of traffic.
Use Cases: Security-centric deployments; environments requiring detailed network visibility and control.
Kube-router
Network Layer Support: Layer 3 focused.
VXLAN Support: Limited or no native support for VXLAN.
Network Policies: Basic to moderate policy support.
Encryption Support: No native support for traffic encryption.
Use Cases: Balances performance and simplicity; suitable for medium-scale environments
What are some ways containers can communicate within the same pod?
IPC, loopback or shared filesystem access
Tips for the exam!
second: k should already be an alias, otherwise; alias k=kubectl
third: dont ever click on links not allowed or u will get disqualified. for that exit maximum window and see what are the links before clicking
fourth: Use :set paste or even better vim ~./.vimrc and put these there:
syntax on
autocmd FileType yaml setlocal ts=2 sts=2 sw=2 expandtab
What does those options stand for? autocmd FileType yaml setlocal ts=2 sts=2 sw=2 expandtab
autocmd FileType yaml: This part tells Vim to automatically execute the following commands whenever a file of the ‘yaml’ file type is opened. Vim detects the file type based on the file extension or sometimes the file content.
setlocal: This command sets options locally for the current buffer. It ensures that the changes made apply only to the YAML file you’re working on, not globally across all open files in Vim.
ts=2: This sets the ‘tabstop’ (ts) option to 2. The ‘tabstop’ option specifies the number of spaces that a tab in the file counts for. In this case, each tab character will be displayed as two spaces.
sts=2: This sets the ‘softtabstop’ (sts) option to 2. When you’re entering text, the ‘softtabstop’ setting makes Vim behave as though the tab character is 2 spaces wide. It affects how text is inserted and how the Tab and Backspace keys work.
sw=2: This sets the ‘shiftwidth’ (sw) option to 2. The ‘shiftwidth’ setting determines the number of spaces to use for each step of (auto)indent. It controls how many spaces are inserted for indentation.
expandtab: This option, when enabled, makes Vim insert spaces instead of tabs when the Tab key is pressed. Combined with the settings above, it means that each time you press Tab, it will insert two spaces.
Name possible memory settings in the pod yaml
Requests is what Kubernetes guarantees as available for the container.
Limits is the maximum amount of memory the container is allowed to use.
Args (“–vm-bytes”, “250M”) is specific to the stress tool used inside the container for testing and is not a Kubernetes resource allocation setting.
How do you aproach this on the exam? you need to know cron, its the linux 5 places cron thats used and which place is which:
Create a new cronjob which runs busybox and the sleep 30 command. Have the cronjob run every three minutes. View the job status to check your work. Change the settings so the pod runs 10 minutes from the current time, every week. For example, if the current time was 2:14PM, I would configure the job to run at 2:24PM, every Monday.
Obs! remember its 5parts cron and they are MHDMDofweek
What is the ambassador in Kubernetes?
Ambassador is a Kubernetes-native API Gateway built on Envoy Proxy. Managed entirely via Kubernetes Custom Resource Definitions, Ambassador provides powerful capabilities for traffic management, authentication, and observability.
Which of the following are helper container types? Choose all answers that apply: Ambassador, Adapter,ProbeHelper,Sidecar
All except Probehelper. can u give example of those?
If a Pod uses more CPU than allowed, it will be evicted. True or False?
False! But its true for memory and disk!
howdo you find port of your local registry?
You just need to list your k8s services: kubectl get svc
Write the list of all DbBackup objects into /root/db-backups .
kubectl get db-backups -A
k get crd to get a list of all, and then take the part before the first dot.
What does this 3 term mean? Helm Chart, Helm Release, Helm Values ?
Helm Chart: Kubernetes YAML template-files combined into a single package, Values allow customisation
Helm Release: Installed instance of a Chart
Helm Values: Allow to customise the YAML template-files in a Chart when creating a Release
Write the list of all Helm releases in the cluster into /root/releases .
helm ls -A > /root/releases
Obs. helm list -h helps!
How to get to know Api Group of k8s Deployments ?
The answer is “Apps”. Two ways to find out:
1) kubectl api-resources| grep -i deploy
deployments deploy apps/v1 true Deployment
2) k explain deploy
GROUP: apps
KIND: Deployment
VERSION: v1
P.s. Remember, group is like groupid in maven: [groupId]:[artifactId]:[type]:[version]
your best way to know the actual version of some api thing?
kubectl api-resources| grep -i
1) What is the official doc reference link for all the special annotations? 2) what is it for namespaces?
- https://kubernetes.io/docs/reference/labels-annotations-taints/. 2. kubernetes.io/metadata.name
Whats inside a basic Dockerfile that just ping a website?
FROM node:lts-alpine
WORKDIR /app
COPY . .
RUN yarn install –production
CMD [“node”, “src/index.js”]
EXPOSE 3000
Obs! remember command parts separated with comma. Also lower/uppercase in FROM matters.
Howto build and list a simple docker/podman image?
podman build -t pinger .
podman image ls
howto run a simple docker/podman image?
podman run –name my-ping pinger
This is the 4 ingredients of Dockerfile. What 2 would i use to create an image that pings a webside:
FROM ubuntu:22.04
COPY . /app
RUN make /app
CMD python /app/app.py
FROM bash
CMD [“ping”, “killercoda.com”]
What was the biggest surprise when i did killerkoda ingress task?
ingressClass! P.s. seems i can see it here kubectl get ingress test-ingress
- What is a command to create a container just by a command? 2. Where in official doc do i find that info
- kubectl run nginx –image=nginx 2. reference > kubectl > generated > kubectl_run
Howto get kubectl events sorted by time?
kubectl get events –sort-by=’.lastTimestamp’
What are 4 servicetypes?
Service type
For some parts of your application (for example, frontends) you may want to expose a Service onto an external IP address, one that’s accessible from outside of your cluster.
Kubernetes Service types allow you to specify what kind of Service you want.
The available type values and their behaviors are:
ClusterIP
Exposes the Service on a cluster-internal IP. Choosing this value makes the Service only reachable from within the cluster. This is the default that is used if you don’t explicitly specify a type for a Service. You can expose the Service to the public internet using an Ingress or a Gateway.
NodePort
Exposes the Service on each Node’s IP at a static port (the NodePort). To make the node port available, Kubernetes sets up a cluster IP address, the same as if you had requested a Service of type: ClusterIP.
LoadBalancer
Exposes the Service externally using an external load balancer. Kubernetes does not directly offer a load balancing component; you must provide one, or you can integrate your Kubernetes cluster with a cloud provider.
ExternalName
Maps the Service to the contents of the externalName field (for example, to the hostname api.foo.bar.example). The mapping configures your cluster’s DNS server to return a CNAME record with that external hostname value. No proxying of any kind is set up.
How do you expose deployment using service?
kubectl expose deployment/kubernetes-bootcamp –type=”NodePort” –port 8080
How am i supposed to find info about exposing a deployment?
Searching for “service expose deployment” gave 2 main type of results that are useful: 1) tutorial pages that are still under kubernetes.io 2) under tasks/access-application-cluster/service-access-application-cluster/
howto create secret from command with 3 data strings?
- either base64 each parameter and put in in yaml or 2. kubectl create secret generic db-secret-xxdf –from-literal=DB_Host=sql01 –from-literal=DB_User=root –from-literal=DB_Password=password123
howto label deployment?
kubectl label deployment my-deployment unhealthy=true
what do u do if u need to configure pod to run as root user?
root is the default user, no action needed!
how do u restart a pod?
A pod is the smallest unit in Kubernetes (K8S). They should run until they are replaced by a new deployment. Because of this, there is no way to restart a pod, instead, it should be replaced.
There is no kubectl restart [podname] command for use with K8S (with Docker you can use docker restart [container_id] ), so there are a few different ways to achieve a pod ‘restart’ with kubectl
Are you familiar with all of these shortcuts?
rs,deploy,svc,ns,netpol,pvc,sa
netpol = network policy, sa = service account
- how do u replace multiple lines in VIM? how do u indent multiple lines?
- kom ihåg procent tecken :%s/foo/bar/g
- 5jj (5 för antal rader , j och sen j igen tror jag)
difference readinessprobe and livenessProbe? example how it look like?
livenessProbe:
exec:
command:
- cat
- /tmp/healthy
Read all the k8s doc pages i opened fully
so i get my mental model over all the parts i can type!
TODO Kilkoda exam 2 q9
TODO: maybe do CKA test exam in addition to CKAD exam just to have a variation of tasks with quick answers!
q9: PV custom-volume has the correct host path?
q9 desc: Create a PersistentVolume called custom-volume with size: 50MiB reclaim policy:retain, Access Modes: ReadWriteMany and hostPath: /opt/data
how do you permanently save the namespace for all subsequent kubectl commands in that context?
kubectl config set-context –current –namespace=ggckad-s2
How do you quickly see if a pod have some volumemounts?
k exec pod1 – ls /etc/birke
When the exam say to create container from dockerfile, do they mean k8s or docker/podman container?
apparently they mean a docker container!
Howto Tag the Docker/Podman image, which is currently tagged as pinger , also as local-registry:5000/pinger?
Howto also then push the image into the local registry?
podman tag pinger local-registry:5000/pinger
podman image ls
podman push local-registry:5000/pinger
What does maxSurge mean in the context of deployments? and how can it be measured?
maxSurge: The number of pods that can be created above the desired amount of pods during an update. This can be an absolute number or percentage of the replicas count. The default is 25%.
What did i forget when trying to use your own CRD?
1) You create yaml by yourself, not template generator!
2) The mandatory first 5 lines start according to abbreviation “AKMnS”
3) !!! Most important cause i made it wrong!! The first A which is apiversion comes from CRD groupid/version, that is “apiVersion: beta.killercoda.com/v1” with or without citation!!!
Whats interesting about this?
controlplane $ k get shopping-items
NAME AGE
bananas 8m26s
shopping-items.beta.killercoda.com 10m
controlplane $ k delete bananas
error: the server doesn’t have a resource type “bananas”
controlplane $ k delete crd bananas
Error from server (NotFound): customresourcedefinitions.apiextensions.k8s.io “bananas” not found
controlplane $ k delete crd shopping-items.beta.killercoda.com
customresourcedefinition.apiextensions.k8s.io “shopping-items.beta.killercoda.com” deleted
Strange that i could not remove banas here!? Also it seems when i remove CRD, i remove the instance of it too!
if i need to search for helm chart “nginx-stable/nginx-ingress”, where can i search and where did i actually find it?
helm search hub - search for charts in the Artifact Hub or your own hub instance
helm search repo - search repositories for a keyword in charts
i found it in the repo! P.s. luckily i did not have to care about that when i just tried to install it by: helm install devserver nginx-stable/nginx-ingress -n team-yellow