enforce-policy-as-code
关于
This skill implements Policy-as-Code enforcement using OPA Gatekeeper or Kyverno to validate and mutate Kubernetes resources against organizational policies. It covers admission control, audit mode, violation reporting, and CI/CD integration for shift-left validation. Use it to enforce configuration standards, prevent security misconfigurations, ensure pre-deployment compliance, and audit existing clusters.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/enforce-policy-as-code在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
name: enforce-policy-as-code description: > Policy-as-Code-Durchsetzung mit OPA Gatekeeper oder Kyverno implementieren, um Kubernetes-Ressourcen gemaess organisatorischen Richtlinien zu validieren und zu mutieren. Behandelt Constraint-Templates, Admission-Control, Audit- Modus, Verletzungs-Reporting und Integration mit CI/CD-Pipelines fuer Shift-Left-Richtlinienvalidierung. Einsatz beim Durchsetzen von Ressourcenkonfigurationsstandards, Verhindern von Sicherheits- Fehlkonfigurationen wie privilegierten Containern, Sicherstellen von Compliance vor dem Deployment, Standardisieren von Benennungskonventionen oder Auditieren bestehender Cluster-Ressourcen gegen Richtlinien. locale: de source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: devops complexity: intermediate language: multi tags: opa, gatekeeper, kyverno, policy, admission-control, compliance, kubernetes
Policy-as-Code durchsetzen
Deklarative Richtliniendurchsetzung mit OPA Gatekeeper oder Kyverno fuer Kubernetes-Ressourcenvalidierung und -Mutation implementieren.
Wann verwenden
- Organisationsstandards fuer Ressourcenkonfiguration durchsetzen (Labels, Annotationen, Limits)
- Sicherheits-Fehlkonfigurationen verhindern (privilegierte Container, Host-Namespaces, unsichere Images)
- Compliance-Anforderungen vor dem Ressourcen-Deployment sicherstellen
- Ressourcen-Benennungskonventionen und Metadaten standardisieren
- Automatisierte Korrektur durch Mutations-Richtlinien implementieren
- Bestehende Cluster-Ressourcen gegen Richtlinien auditieren ohne zu blockieren
- Richtlinienvalidierung in CI/CD-Pipelines fuer Shift-Left-Ansatz integrieren
Eingaben
- Erforderlich: Kubernetes-Cluster mit Admin-Zugriff
- Erforderlich: Auswahl der Policy-Engine (OPA Gatekeeper oder Kyverno)
- Erforderlich: Liste der durchzusetzenden Richtlinien (Sicherheit, Compliance, Betrieb)
- Optional: Vorhandene Ressourcen zum Auditieren
- Optional: Ausnahme-/Ausschluss-Muster fuer spezifische Namespaces oder Ressourcen
- Optional: CI/CD-Pipeline-Konfiguration fuer Pre-Deployment-Validierung
Vorgehensweise
Siehe Erweiterte Beispiele fuer vollstaendige Konfigurationsdateien und Vorlagen.
Schritt 1: Policy-Engine installieren
OPA Gatekeeper oder Kyverno als Admission-Controller deployen.
Fuer OPA Gatekeeper:
# Install Gatekeeper using Helm
helm repo add gatekeeper https://open-policy-agent.github.io/gatekeeper/charts
helm repo update
# Install with audit enabled
helm install gatekeeper gatekeeper/gatekeeper \
--namespace gatekeeper-system \
--create-namespace \
--set audit.replicas=2 \
--set replicas=3 \
--set validatingWebhookFailurePolicy=Fail \
--set auditInterval=60
# Verify installation
kubectl get pods -n gatekeeper-system
kubectl get crd | grep gatekeeper
# Check webhook configuration
kubectl get validatingwebhookconfigurations gatekeeper-validating-webhook-configuration -o yaml
Fuer Kyverno:
# Install Kyverno using Helm
helm repo add kyverno https://kyverno.github.io/kyverno/
helm repo update
# Install with HA setup
helm install kyverno kyverno/kyverno \
--namespace kyverno \
--create-namespace \
--set replicaCount=3 \
--set admissionController.replicas=3 \
--set backgroundController.replicas=2 \
--set cleanupController.replicas=2
# Verify installation
kubectl get pods -n kyverno
kubectl get crd | grep kyverno
# Check webhook configurations
kubectl get validatingwebhookconfigurations kyverno-resource-validating-webhook-cfg
kubectl get mutatingwebhookconfigurations kyverno-resource-mutating-webhook-cfg
Namespace-Ausschluesse erstellen:
# gatekeeper-config.yaml
apiVersion: config.gatekeeper.sh/v1alpha1
kind: Config
metadata:
name: config
namespace: gatekeeper-system
spec:
match:
- excludedNamespaces:
- kube-system
- kube-public
- kube-node-lease
- gatekeeper-system
processes:
- audit
- webhook
validation:
traces:
- user: system:serviceaccount:gatekeeper-system:gatekeeper-admin
kind:
group: ""
version: v1
kind: Namespace
Erwartet: Policy-Engine-Pods laufen mit mehreren Replikas. CRDs installiert (ConstraintTemplate, Constraint fuer Gatekeeper; ClusterPolicy, Policy fuer Kyverno). Validierungs-/Mutations-Webhooks aktiv. Audit-Controller laeuft.
Bei Fehler:
- Pod-Logs pruefen:
kubectl logs -n gatekeeper-system -l app=gatekeeper --tail=50 - Webhook-Endpunkte erreichbar pruefen:
kubectl get endpoints -n gatekeeper-system - Auf Port-Konflikte oder Zertifikatsprobleme in Webhook-Logs pruefen
- Sicherstellen, dass Cluster ausreichende Ressourcen hat (Policy-Engines benoetigen ~500 MB pro Replik)
- RBAC-Berechtigungen pruefen:
kubectl auth can-i create constrainttemplates --as=system:serviceaccount:gatekeeper-system:gatekeeper-admin
Schritt 2: Constraint-Templates und Richtlinien definieren
Wiederverwendbare Richtlinien-Templates und spezifische Constraints erstellen.
OPA-Gatekeeper-Constraint-Template:
# required-labels-template.yaml
apiVersion: templates.gatekeeper.sh/v1
kind: ConstraintTemplate
metadata:
name: k8srequiredlabels
annotations:
# ... (see EXAMPLES.md for complete configuration)
Kyverno-ClusterPolicy:
# kyverno-policies.yaml
apiVersion: kyverno.io/v1
kind: ClusterPolicy
metadata:
name: require-labels
annotations:
# ... (see EXAMPLES.md for complete configuration)
Richtlinien anwenden:
# Apply Gatekeeper templates and constraints
kubectl apply -f required-labels-template.yaml
# Apply Kyverno policies
kubectl apply -f kyverno-policies.yaml
# Verify constraint/policy status
kubectl get constraints
kubectl get clusterpolicies
# Check for any policy errors
kubectl describe k8srequiredlabels require-app-labels
kubectl describe clusterpolicy require-labels
Erwartet: ConstraintTemplates/ClusterPolicies erfolgreich erstellt. Constraints zeigen Status "True" fuer Durchsetzung. Keine Fehler in Richtliniendefinitionen. Webhook beginnt neue Ressourcen gegen Richtlinien auszuwerten.
Bei Fehler:
- Rego-Syntax validieren (Gatekeeper):
opa testlokal verwenden oder Constraint-Status pruefen - YAML-Syntax pruefen:
kubectl apply --dry-run=client -f policy.yaml - Constraint-Status pruefen:
kubectl get constraint -o yaml | grep -A 10 status - Mit einfacher Richtlinie beginnen, dann Komplexitaet erhoehen
- Pruefen, ob Match-Kriterien (Arten, Namespaces) korrekt sind
Schritt 3: Richtliniendurchsetzung testen
Validieren, dass Richtlinien nicht-konforme Ressourcen blockieren und konforme erlauben.
Test-Manifeste erstellen:
# test-non-compliant.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: test-no-labels
namespace: production
# ... (see EXAMPLES.md for complete configuration)
Richtlinien testen:
# Attempt to create non-compliant resource (should fail)
kubectl apply -f test-non-compliant.yaml
# Expected: Error with policy violation message
# Create compliant resource (should succeed)
kubectl apply -f test-compliant.yaml
# Expected: deployment.apps/test-compliant created
# Test with dry-run for validation
kubectl apply -f test-non-compliant.yaml --dry-run=server
# Shows policy violations without actually creating resource
# Clean up
kubectl delete -f test-compliant.yaml
Mit Policy-Reporting testen (Kyverno):
# Check policy reports
kubectl get policyreports -A
kubectl get clusterpolicyreports
# View detailed report
kubectl get policyreport -n production -o yaml
# Check policy rule results
kubectl get policyreport -n production -o jsonpath='{.items[0].results}' | jq .
Erwartet: Nicht-konforme Ressourcen werden mit klaren Verletzungsmeldungen abgelehnt. Konforme Ressourcen werden erfolgreich erstellt. Richtlinienberichte zeigen Bestehen/Fehlschlagen-Ergebnisse. Dry-Run-Validierung funktioniert ohne Ressourcenerstellung.
Bei Fehler:
- Pruefen ob Richtlinie im Audit-Modus statt Durchsetzungs-Modus:
validationFailureAction: audit - Pruefen ob Webhook Anfragen verarbeitet:
kubectl logs -n gatekeeper-system -l app=gatekeeper - Auf Namespace-Ausschluesse pruefen, die Test-Namespace ausnehmen koennten
- Webhook-Konnektivitaet testen:
kubectl run test --rm -it --image=busybox --restart=Never - Webhook-Failure-Policy pruefen (Ignore vs Fail)
Schritt 4: Mutations-Richtlinien implementieren
Automatische Korrektur durch Mutation konfigurieren.
Gatekeeper-Mutation:
# gatekeeper-mutations.yaml
apiVersion: mutations.gatekeeper.sh/v1beta1
kind: Assign
metadata:
name: add-default-labels
spec:
# ... (see EXAMPLES.md for complete configuration)
Kyverno-Mutations-Richtlinien:
# kyverno-mutations.yaml
apiVersion: kyverno.io/v1
kind: ClusterPolicy
metadata:
name: add-default-labels
spec:
# ... (see EXAMPLES.md for complete configuration)
Mutationen anwenden und testen:
# Apply mutation policies
kubectl apply -f gatekeeper-mutations.yaml
# OR
kubectl apply -f kyverno-mutations.yaml
# Test mutation with a deployment
# ... (see EXAMPLES.md for complete configuration)
Erwartet: Mutationen fuegen automatisch Labels, Ressourcen hinzu oder aendern Images. Deployete Ressourcen zeigen mutierte Werte. Mutationen werden in Policy-Engine-Logs protokolliert. Keine Fehler bei Mutations-Anwendung.
Bei Fehler:
- Pruefen, ob Mutations-Webhook aktiviert:
kubectl get mutatingwebhookconfiguration - Mutations-Richtlinien-Syntax pruefen: insbesondere JSON-Pfade und Bedingungen
- Logs pruefen:
kubectl logs -n kyverno deploy/kyverno-admission-controller - Sicherstellen, dass Mutationen nicht konfliktieren (mehrere Mutationen auf demselben Feld)
- Sicherstellen, dass Mutation vor Validierung angewendet wird (Reihenfolge wichtig)
Schritt 5: Audit-Modus und Reporting aktivieren
Audit konfigurieren, um Verletzungen in bestehenden Ressourcen ohne Blockierung zu identifizieren.
Gatekeeper-Audit:
# Audit runs automatically based on auditInterval setting
# Check audit results
kubectl get constraints -o json | \
jq '.items[] | {name: .metadata.name, violations: .status.totalViolations}'
# Get detailed violation information
# ... (see EXAMPLES.md for complete configuration)
Kyverno-Audit und Reporting:
# Generate policy reports for existing resources
kubectl create job --from=cronjob/kyverno-cleanup-controller -n kyverno manual-report-gen
# View policy reports
kubectl get policyreport -A
kubectl get clusterpolicyreport
# ... (see EXAMPLES.md for complete configuration)
Dashboard fuer Richtlinien-Compliance erstellen:
# prometheus-rules.yaml
apiVersion: monitoring.coreos.com/v1
kind: PrometheusRule
metadata:
name: policy-alerts
namespace: monitoring
# ... (see EXAMPLES.md for complete configuration)
Erwartet: Audit identifiziert Verletzungen in bestehenden Ressourcen ohne Deployments zu blockieren. Richtlinienberichte mit Bestehen/Fehlschlagen-Zaehlen generiert. Verletzungen exportierbar zur Pruefung. Metriken fuer Monitoring exponiert. Alerts loesen bei zunehmenden Verletzungen aus.
Bei Fehler:
- Audit-Controller laufend pruefen:
kubectl get pods -n gatekeeper-system -l gatekeeper.sh/operation=audit - Audit-Intervall-Einstellung in Installation pruefen
- Audit-Logs auf Fehler pruefen:
kubectl logs -n gatekeeper-system -l gatekeeper.sh/operation=audit - RBAC-Berechtigungen pruefen, die Lesen aller Ressourcentypen fuer Audit ermoeglichen
- Pruefen ob CRD-Status-Feld befuellt wird:
kubectl get constraint -o yaml | grep -A 20 status
Schritt 6: Mit CI/CD-Pipeline integrieren
Pre-Deployment-Richtlinienvalidierung fuer Shift-Left-Richtliniendurchsetzung hinzufuegen.
CI/CD-Integrations-Skript:
#!/bin/bash
# validate-policies.sh
set -e
echo "=== Policy Validation for CI/CD ==="
# ... (see EXAMPLES.md for complete configuration)
GitHub-Actions-Workflow:
# .github/workflows/policy-validation.yaml
name: Policy Validation
on:
pull_request:
paths:
# ... (see EXAMPLES.md for complete configuration)
Pre-Commit-Hook:
#!/bin/bash
# .git/hooks/pre-commit
# Validate Kubernetes manifests against policies
if git diff --cached --name-only | grep -E 'manifests/.*\.yaml$'; then
echo "Validating Kubernetes manifests against policies..."
# ... (see EXAMPLES.md for complete configuration)
Erwartet: CI/CD-Pipeline validiert Manifeste vor dem Deployment. Richtlinienverletzungen schlagen Pipeline mit klaren Meldungen fehl. Richtlinienberichte werden an PR angehaengt. Pre-Commit-Hooks erkennen Verletzungen frueh. Entwickler werden ueber Richtlinienprobleme informiert, bevor sie den Cluster erreichen.
Bei Fehler:
- CLI-Tools installiert und im PATH pruefen
- Kubeconfig-Credentials fuer Richtlinien-Abruf pruefen
- Richtlinienvalidierung lokal zuerst testen:
kyverno apply policy.yaml --resource manifest.yaml - Sicherstellen, dass aus Cluster synchronisierte Richtlinien vollstaendig sind
- Policy-CLI-Logs auf spezifische Validierungsfehler pruefen
Validierung
- Policy-Engine-Pods mit HA-Konfiguration laufend
- Validierungs- und Mutations-Webhooks aktiv und erreichbar
- Constraint-Templates und Richtlinien ohne Fehler erstellt
- Nicht-konforme Ressourcen mit klaren Verletzungsmeldungen abgelehnt
- Konforme Ressourcen erfolgreich deploybar
- Mutations-Richtlinien korrigieren Ressourcen automatisch
- Audit-Modus identifiziert Verletzungen in bestehenden Ressourcen
- Richtlinienberichte generiert und zugaenglich
- Metriken fuer Richtlinien-Compliance-Monitoring exponiert
- CI/CD-Pipeline validiert Manifeste vor dem Deployment
- Pre-Commit-Hooks verhindern Richtlinienverletzungen
- Namespace-Ausschluesse angemessen konfiguriert
Haeufige Stolperfallen
-
Webhook-Failure-Policy:
failurePolicy: Failblockiert alle Ressourcen wenn Webhook nicht verfuegbar.Ignorefuer nicht-kritische Richtlinien verwenden, aber Sicherheitsimplikationen verstehen. Webhook-Verfuegbarkeit vor Durchsetzung testen. -
Zu restriktive Anfangsrichtlinien: Mit Durchsetzungsmodus bei strengen Richtlinien bestehende Workloads brechen. Mit Audit-Modus beginnen, Verletzungen pruefen, Teams informieren, dann schrittweise durchsetzen.
-
Fehlende Ressourcenspezifikationen: Richtlinien muessen API-Gruppen, Versionen und Arten korrekt angeben.
kubectl api-resourcesverwenden, um genaue Werte zu finden. Wildcards (*) praktisch, koennen aber Leistungsprobleme verursachen. -
Mutations-Reihenfolge: Mutationen werden vor Validierungen angewendet. Sicherstellen, dass Mutationen nicht konfliktieren und Validierungen mutierte Werte beruecksichtigen. Mutation+Validierung zusammen testen.
-
Namespace-Ausschluesse: System-Namespaces auszuschliessen ist notwendig, aber vorsichtig sein, nicht zu viel auszuschliessen. Ausschluesse regelmaessig ueberpruefen, wenn Richtlinien reifen.
-
Rego-Komplexitaet (Gatekeeper): Komplexe Rego-Richtlinien schwer zu debuggen. Einfach beginnen, lokal mit
opa testtesten, Logging mittrace()hinzufuegen, Gator fuer Offline-Tests verwenden. -
Leistungseinfluss: Richtlinienbewertung fuegt Latenz zum Admission-Prozess hinzu. Richtlinien effizient halten, geeignete Match-Kriterien verwenden, Webhook-Latenz-Metriken ueberwachen.
-
Richtlinienkonflikte: Mehrere Richtlinien, die dasselbe Feld aendern, verursachen Probleme. Richtlinien teamuebergreifend koordinieren, Richtlinien-Bibliotheken fuer gaengige Muster verwenden, Kombinationen testen.
-
Hintergrund-Scanning: Hintergrund-Audit scannt gesamten Cluster. Kann ressourcenintensiv in grossen Clustern sein. Audit-Intervall basierend auf Cluster-Groesse und Richtlinienanzahl anpassen.
-
Versionskompatibilitaet: Policy-CRD-Versionen aendern sich. Gatekeeper v3 verwendet
v1beta1-Constraints, Kyverno v1.11 verwendetkyverno.io/v1. Docs fuer die jeweilige Version pruefen.
Verwandte Skills
manage-kubernetes-secrets- Secret-Validierungs-Richtliniensecurity-audit-codebase- Komplementaeres Sicherheits-Scanningdeploy-to-kubernetes- Anwendungs-Deployment mit Richtlinienvalidierungsetup-service-mesh- Service-Mesh-Autorisierungs-Richtlinien ergaenzen Admission-Richtlinienconfigure-api-gateway- Gateway-Richtlinien arbeiten neben Admission-Richtlinienimplement-gitops-workflow- GitOps mit Richtlinienvalidierung in der Pipeline
GitHub 仓库
相关推荐技能
content-collections
元Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。
polymarket
元这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。
creating-opencode-plugins
元该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。
sglang
元SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。
