CKS (Spécialiste en Sécurité Kubernetes) : prérequis et plan d'étude de 6 semaines
Le CKS est plus difficile que le CKA, plus restreint en portée, et nécessite un CKA actif pour s'inscrire. Voici comment l'étudier sans s'épuiser.
Le CKS â Certified Kubernetes Security Specialist â est, Ă mon avis, le plus difficile des trois examens Kubernetes de niveau professionnel, plus restreint que le CKA et plus exigeant sous la pression du temps. Deux heures, pratique, 445 $, avec une reprise gratuite incluse. PSI Bridge, uniquement en ligne, pas de centres d'examen. La note de passage est de 67 %. La CNCF ne publie pas les taux de rĂ©ussite officiels, mais le taux de rĂ©ussite au premier essai, selon les sondages communautaires, se situe autour de 40 Ă 50 %, ce qui est infĂ©rieur Ă celui du CKA, et cela correspond Ă mon expĂ©rience en observant mes collĂšgues le passer.
Ce que la plupart des gens oublient : vous ne pouvez pas simplement vous inscrire. La CNCF exige un CKA actif sur votre compte au moment de l'inscription. Pas « vous avez passé le CKA à un moment donné ». Actif. Si votre CKA a expiré (ce qui se produit désormais aprÚs 2 ans au lieu de 3 depuis le changement de politique du 1er avril 2024), vous devez le renouveler avant de pouvoir vous inscrire au CKS. Il s'agit d'une condition stricte, pas d'une simple recommandation, et elle surprend les gens chaque trimestre.
Les véritables prérequis
L'officiel : un CKA actif. C'est tout.
L'officieux :
- MaĂźtrise de
kubectlau point de ne plus rĂ©flĂ©chir Ă la syntaxe. Si vous cherchez encore « kubectl create deployment » sur Google, vous n'ĂȘtes pas prĂȘt. - Bases de Linux â vous vous connecterez en SSH aux nĆuds, lirez les journaux systemd, modifierez les drapeaux kubelet et dĂ©boguerez les Ă©checs de profils seccomp / AppArmor. Si
journalctl -u kubeletne vous est pas familier, commencez par y remédier. - Maßtrise de
vim. Pas de la sorcellerie Vim. Mais éditer du YAML dans vim en 2 heures sans perdre 30 secondes à « attendez, comment je sauvegarde déjà » est obligatoire. - Un modÚle mental fonctionnel de NetworkPolicy. C'est le plus grand obstacle de l'examen. Plus de détails ci-dessous.
- Un contact prĂ©alable avec Falco, Trivy, AppArmor, seccomp, mTLS via le service mesh et les Pod Security Standards. Vous n'avez pas besoin d'ĂȘtre un expert dans aucun d'entre eux ; vous devez les reconnaĂźtre.
Si vous manquez plus de deux de ces éléments, consacrez un mois supplémentaire aux exercices opérationnels de type CKA avant de vous attaquer au CKS. Tenter d'apprendre les opérations et la sécurité de Kubernetes simultanément sous la pression du temps est un chemin vers l'épuisement de la reprise gratuite.
Ce qui est réellement testé
Le programme de la CNCF le divise comme suit (les pourcentages changent à chaque révision du programme ; ceci est à jour début 2026) :
- Mise en place et durcissement du cluster (~15 %) : benchmarks CIS, kube-bench, restriction de l'accÚs externe, désactivation de l'authentification anonyme, drapeaux de durcissement kubelet.
- Durcissement du systÚme (~15 %) : durcissement du noyau (seccomp, AppArmor), réduction de la surface d'attaque, minimisation de l'IAM cÎté cloud.
- Minimiser les vulnérabilités des microservices (~20 %) : Pod Security Standards (qui ont remplacé les PSPs en 1.25), jetons ServiceAccount, OPA / Gatekeeper ou Kyverno, mTLS.
- Sécurité de la chaßne d'approvisionnement (~20 %) : analyse d'images avec Trivy, signature avec cosign, contrÎleurs d'admission qui bloquent les images non signées, bases du SBOM, minimisation des images de base.
- Surveillance, journalisation, sécurité d'exécution (~20 %) : rÚgles Falco, analyse comportementale, immuabilité, journalisation d'audit au niveau du serveur API.
- Politique réseau (Network Policy) (~10 %) :
default-deny, isolation des namespaces, rÚgles d'egress. Listé comme un faible pourcentage, mais en pratique, toutes les autres catégories touchent aussi à NetworkPolicy.
L'examen ne teste pas le fonctionnement interne de Falco. Il teste votre capacité à écrire une rÚgle Falco qui se déclenche lorsqu'un shell démarre dans un conteneur. L'examen ne teste pas la cryptographie de cosign. Il teste votre capacité à configurer un contrÎleur d'admission pour rejeter les images non signées. Le travail est opérationnel, pas académique.
Le plan de 6 semaines
Cela suppose environ 10 heures par semaine avec un CKA actif déjà en poche. Adaptez si vous avez plus ou moins de temps.
Semaine 1 : NetworkPolicy jusqu'à l'épuisement.
Mettez en place un cluster kind localement avec Calico ou Cilium (le kindnet par dĂ©faut n'applique pas les NetworkPolicy, ce qui dĂ©route les gens). Ăcrivez une politique default-deny pour un namespace. Ăcrivez une politique allow-from-namespace. Ăcrivez une politique d'egress qui autorise uniquement le DNS. Ăcrivez-en une qui autorise le trafic depuis un label de pod spĂ©cifique Ă travers les namespaces. Refaites tout cela de mĂ©moire jusqu'Ă ce que vous puissiez les Ă©crire dans vim sans consulter kubernetes.io. Le YAML de NetworkPolicy est le domaine de contenu le plus volumineux de l'examen et celui oĂč la plupart des gens Ă©chouent. Passez plus de temps ici que vous ne pensez en avoir besoin.
Semaine 2 : Pod Security Standards, ServiceAccounts, renforcement du RBAC.
Appliquez les profils restricted, baseline et privileged aux namespaces. Configurez les ServiceAccounts avec automountServiceAccountToken: false. Créez un RBAC qui suit le principe du moindre privilÚge pour un déploiement qui doit lire des ConfigMaps dans son propre namespace et rien d'autre. Entraßnez-vous à diagnostiquer « ce pod ne peut pas faire X à cause du RBAC » jusqu'à ce que le flux kubectl auth can-i devienne automatique.
Semaine 3 : ChaĂźne d'approvisionnement â Trivy, cosign, contrĂŽle d'admission.
Scannez une image avec Trivy et interprĂ©tez la sortie CVE. Signez une image avec cosign. Configurez un ImagePolicyWebhook ou une politique Kyverno qui rejette les images non signĂ©es par votre clĂ©. Mettez en place un registre OCI localement si vous voulez vous entraĂźner pleinement. L'examen vous fournira probablement Trivy installĂ© ; vous devriez connaĂźtre ses drapeaux clĂ©s par cĆur (--severity HIGH,CRITICAL, --ignore-unfixed).
Semaine 4 : ExĂ©cution â Falco, AppArmor, seccomp.
Installez Falco sur un cluster kind. Lisez les rĂšgles par dĂ©faut. Ăcrivez une rĂšgle personnalisĂ©e. Appliquez un profil AppArmor Ă un pod (l'examen vous donne gĂ©nĂ©ralement un profil dĂ©jĂ sur le nĆud et vous demande de le connecter via une annotation â ce qui signifie connaĂźtre la syntaxe container.apparmor.security.beta.kubernetes.io/<container>: localhost/<profile>). Appliquez un profil seccomp via securityContext.seccompProfile. Ces deux Ă©lĂ©ments ont une syntaxe hĂ©ritĂ©e basĂ©e sur les annotations et une syntaxe actuelle basĂ©e sur les champs ; l'examen a tendance Ă tester la syntaxe actuelle, mais vous devriez reconnaĂźtre les deux.
Semaine 5 : Durcissement du cluster et de l'hĂŽte.
ExĂ©cutez kube-bench, interprĂ©tez les Ă©checs, corrigez les plus faciles (authentification anonyme, journalisation d'audit, drapeaux kubelet). Configurez la politique d'audit sur le serveur API. Restreignez l'accĂšs Ă etcd. DĂ©sactivez les ports kubelet inutiles. Il s'agit principalement de travail Linux au niveau des nĆuds, et c'est lĂ que les ingĂ©nieurs sans solides bases d'administrateur systĂšme ralentissent.
Semaine 6 : Killer Shell, simulations complĂštes et repos.
Utilisez les deux sessions Killer Shell incluses cette semaine. Elles sont intentionnellement plus difficiles que l'examen rĂ©el ; attendez-vous Ă obtenir un score infĂ©rieur Ă ce que vous espĂ©rez. Utilisez les lacunes pour Ă©tudier. Passez l'examen rĂ©el dans les 2-3 derniers jours de la semaine 6 pendant que la mĂ©moire musculaire est fraĂźche. Ne le reportez pas â chaque semaine de dĂ©lai vous fait perdre vos rĂ©flexes.
Dormez la nuit précédant l'examen. Ne passez pas une nuit blanche à étudier. Ne modifiez pas vos alias kubectl le jour de l'examen.
Les piĂšges qui posent problĂšme
NetworkPolicy sous la pression du temps. DĂ©jĂ mentionnĂ© et il est bon de le rĂ©pĂ©ter. La structure YAML est impitoyable â une mauvaise indentation tue la politique silencieusement et le pod continue de router. EntraĂźnez-vous dans vim jusqu'Ă ce que vous puissiez Ă©crire un default-deny + selective allow par rĂ©flexe.
Oublier que NetworkPolicy nécessite un CNI qui l'applique. kindnet ne le fait pas. flannel (par défaut dans certaines configurations) ne le fait pas. Calico, Cilium, Weave le font. Assurez-vous que votre cluster de pratique exécute un CNI appliquant ces rÚgles, sinon vous apprendrez les mauvaises leçons.
Confondre PSP et Pod Security Standards. Les PSPs ont été supprimés en 1.25 (il y a des années maintenant, mais l'ancien matériel de formation y fait toujours référence). Le mécanisme actuel est le Pod Security Admission avec les profils restricted, baseline, privileged appliqués via des labels de namespace. N'étudiez pas les PSPs.
Configuration du chiffrement au repos d'etcd. Testé souvent. Spécifiquement : éditer EncryptionConfiguration, redémarrer le serveur API avec le bon drapeau, et vérifier avec etcdctl get que la valeur est chiffrée. Pratiquez cela.
Le piĂšge de l'onglet du navigateur. Vous ĂȘtes autorisĂ© Ă consulter kubernetes.io, falco.org, app-armor.net, et quelques autres. Vous ne pouvez pas compter sur la recherche rapide sous la pression du temps. MĂ©morisez la structure. Utilisez l'onglet pour copier-coller des extraits spĂ©cifiques, pas pour apprendre la syntaxe.
Devriez-vous le passer ?
Passez le CKS si votre travail est ou sera la sĂ©curitĂ© de plateforme, l'ingĂ©nierie de sĂ©curitĂ© dans un environnement Kubernetes, ou le travail de conformitĂ© dans des secteurs rĂ©glementĂ©s. Ne le passez pas si vous ĂȘtes un ingĂ©nieur de plateforme gĂ©nĂ©raliste â le CKA couvre ce dont la plupart des rĂŽles gĂ©nĂ©ralistes ont besoin, et le CKS est un excĂšs qui expire en 2 ans.
Si vous vous y lancez, parcourez la banque de questions CKS sur CertLabPro ou démarrez un examen chronométré. La couverture conceptuelle des banques de questions complÚte les répétitions opérationnelles que vous devez effectuer sur de vrais clusters. Les deux sont nécessaires ; ni l'un ni l'autre ne suffit seul.