Online curated resources that will help you prepare for taking the Kubernetes Certified Kubernetes Security Specialist CKS Certification exam.
- Please raise an issue, or make a pull request for fixes, new additions, or updates.
Resources are primarly cross referenced back to the allowed CKS sites during the exam as per CNCF/Linux Foundation exam allowed search rules. Videos and other third party resources e.g. blogs will be provided as an optional complimentary material and any 3rd party material not allowed in the exam will be designated with π© in the curriculum sections below.
Ensure you have the right version of Kubernetes documentation selected (e.g. v1.20 as of 22 January 2021) especially for API objects and annotations, however for third party tools, you might find that you can still find references for them in old releases and blogs e.g. Falco install.
- Icons/emoji legend
- π Expand to see more content
- π Verify, not best resource yet
- π΅ Good overall refence, can be used in the exam
- π© External third-party resource, can not be used during exam
- π To-do, item that needs further checking(todo list for future research/commits)
Offical exam objectives you review and understand in order to pass the test.
-
Duration : two (2) hours
-
Number of questions: 15-20 hands-on performance based tasks
-
Passing score: 67%
-
Certification validity: two (2) years
-
Prerequisite: valid CKA
-
Cost: $300 USD, One (1) year exam eligibility, with a free retake within the year.
Linux Foundation offer several discounts around the year e.g. CyberMonday, Kubecon attendees among other special holidays/events
- From Chrome or Chromium browser to open one additional tab in order to access
Kubernetes Documentation:
- https://kubernetes.io/docs and their subdomains
- https://github.com/kubernetes and their subdomains
- https://kubernetes.io/blog and their subdomains
This includes all available language translations of these pages (e.g. https://kubernetes.io/zh/docs)
- Cluster Setup - 10%
- Cluster Hardening - 15%
- System Hardening - 15%
- Minimize Microservice Vulnerabilities - 20%
- Supply Chain Security - 20%
- Monitoring, Logging and Runtime Security - 20%
- Slack
- Books
- Youtube Videos
- Webinars
- Containers and Kubernetes Security Training
- Extra Kubernetes security resources
π΅ Securing a Cluster
-
Use Network security policies to restrict cluster level access
-
π© Use CIS benchmark to review the security configuration of Kubernetes components (etcd, kubelet, kubedns, kubeapi)
- π© Kube-bench - Checks whether Kubernetes is deployed securely by running the checks documented ain the CIS Kubernetes Benchmark.
-
Properly set up Ingress objects with security control
-
Protect node metadata and endpoints
Using Kubernetes network policy to restrict pods access to cloud metadata
- This example assumes AWS cloud, and metadata IP address is 169.254.169.254 should be blocked while all other external addresses are not.
apiVersion: networking.k8s.io/v1 kind: NetworkPolicy metadata: name: deny-only-cloud-metadata-access spec: podSelector: {} policyTypes: - Egress egress: - to: - ipBlock: cidr: 0.0.0.0/0 except: - 169.254.169.254/32
-
Verify platform binaries before deploying
π Kubernetes binaries can be verified by their digest **sha512 hash**
- Checking the Kubernetes release page for the specific release
- Checking the change log for the images and their digests
-
Exercise caution in using service accounts e.g. disable defaults, minimize permissions on newly created ones
π Opt out of automounting API credentials for a service account
apiVersion: v1 kind: ServiceAccount metadata: name: build-robot automountServiceAccountToken: false
apiVersion: v1 kind: Pod metadata: name: cks-pod spec: serviceAccountName: default automountServiceAccountToken: false
-
Minimize host OS footprint (reduce attack surface)
π π Reduce host attack surface
- seccomp which stands for secure computing was originally intended as a means of safely running untrusted compute-bound programs
- AppArmor can be configured for any application to reduce its potential host attack surface and provide greater in-depth defense.
- PSP enforces
- Apply host updates
- Install minimal required OS fingerprint
- Protect access to data with permissions
-
Minimize IAM roles
-
Minimize external access to the network
π π if it means deny external traffic to outside the cluster?!!
- not tested, however, the thinking is that all pods can talk to all pods in all name spaces but not to the outside of the cluster!!!
apiVersion: networking.k8s.io/v1 kind: NetworkPolicy metadata: name: deny-external-egress spec: podSelector: {} policyTypes: - Egress egress: to: - namespaceSelector: {}
-
Appropriately use kernel hardening tools such as AppArmor, seccomp
- Setup appropriate OS-level security domains e.g. using PSP, OPA, security contexts
- Manage kubernetes secrets
- Use container runtime sandboxes in multi-tenant environments (e.g. gvisor, kata containers)
- Implement pod to pod encryption by use of mTLS
- π check if service mesh is part of the CKS exam
-
Minimize base image footprint
π Minimize base Image
- Use distroless, UBI minimal, Alpine, or relavent to your app nodejs, python but the minimal build.
- Do not include uncessary software not required for container during runtime e.g build tools and utilities, troubleshooting and debug binaries.
-
Secure your supply chain: whitelist allowed image registries, sign and validate images
-
Use static analysis of user workloads (e.g. kubernetes resources, docker files)
-
Perform behavioural analytics of syscall process and file activities at the host and container level to detect malicious activities
-
Detect threats within a physical infrastructure, apps, networks, data, users and workloads
-
Detect all phases of attack regardless where it occurs and how it spreads
-
Perform deep analytical investigation and identification of bad actors within the environment
- Aqua Security Liz Rice:Free Container Security Book
- Learn Kubernetes security: Securely orchestrate, scale, and manage your microservices in Kubernetes deployments
- Google/Ian Lewis: Kubernetes security best practices
- Code in Action for the book Learn Kubernetes Security playlist
- Kubernetes security concepts and demos
- Killer.sh CKS practice exam - use code walidshaari for 20% discount.
- UDEMY Kim WΓΌstkamp's Kubernetes CKS 2021 Complete Course with killer.sh Simulator (discounted price)
- Linux Foundation Kubernetes Security essentials LFS 260
- Linux Academy/ACloudGuru Kubernetes security
- Zeal Vora's Udemy Certified Kubernetes Security Specialist 2021 - Link includes a discount till 28th January 2021
- Cloud native security defending containers and kubernetes
- Tutorial: Getting Started With Cloud-Native Security - Liz Rice, Aqua Security & Michael Hausenblas
- K21 academy CKS step by step activity hands-on-lab activity guide
- Andrew Martin Control Plane Security training
- Stackrox CKS study guide - Brief and informative study guide from Stackrox @mfosterrox
- Kim's CKS Challenge series - also posted on medium @ https://wuestkamp.medium.com/
- Abdennour
- Ibrahim Jelliti
- Viktor Vedmich