SAP-archive / karydia

Kubernetes Security Walnut
Other
76 stars 10 forks source link

Karydia - A Kubernetes Security Walnut

Karydia Logo

Status: Beta | Kubernetes Version >=1.15.x

Karydia is a security add-on for Kubernetes, which helps you follow good security practices by inverting insecure default settings in Kubernetes. Kubernetes default settings are not optimized for security, but rather on running out-of-the-box without complicated configuration upfront. It's easy to get a pod up and running; in the simplest case it's just one command. Unfortunately, the simple setup does not have a highly secure application in mind. Default settings are not enough!

Karydia inverts the following insecure default settings:

A description of each feature can be found here and an overview of the application of these features is described in the demo section.

If you have any problems while using Karydia, have a look at our troubleshooting guide. If this does not solve your problem, please open a GitHub Issue.

Installing Karydia

To install Karydia using Helm run the following commands:

kubectl create namespace karydia
helm install karydia ./install/charts --namespace karydia

A detailed description of the installation process can be found in the corresponding readme.

Testing

Integration Tests

Install Karydia Dev
kubectl create namespace karydia
helm install karydia ./install/charts --namespace karydia --set dev.active=true
Build, Swap and Test
make build deploy-dev
make e2e-test

Unit Tests

make test

Debug Karydia

To debug (for example Visual Studio Code), change the following line in the debug configuration:

"args": ["--kubeconfig","<PATH>/.kube/config"]