hosein-yousefii / kubernetes-vault-cluster

vault cluster in kubernetes integrated with consul cluster.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

kubernetes-vault-cluster

GitHub license LinkedIn

vault cluster in kubernetes integrated with consul cluster, and using auto-unseal to unseal vault.

Use this repository To implement a simple Vault cluster which is integrated to Consul cluster as back storage, and a Vault as a transit server to automatically unseal vault cluster, of course for test purpose.

What is Vault?

Secure, store and tightly control access to tokens, passwords, certificates, encryption keys for protecting secrets and other sensitive data using a UI, CLI, or HTTP API.

What is Consul?

Consul uses service identities and traditional networking practices to help organizations securely connect applications running in any environment.

What is Transit server?

Vault supports opt-in automatic unsealing via transit secrets engine. This feature enables operators to delegate the unsealing process to a trusted Vault environment to ease operations. The Transit seal configures Vault to use Vault's Transit Secret Engine as the autoseal mechanism.

Why this repository?

It's simple to use and understand with simple configuration.

Get started:

Clone the repository where you have access to kubectl.

!!ATTENTION!!

It removes "vault-cluster" namespace first so, make sure you are in test environment.

Then run the script:

./vault-cluster.sh

This script will deploy consul cluster first, then vault. Also, init and unseal vault and store keys to the current directory in "vault-cluster-keys.txt".

In case of facing sealed "vault-auto-unseal" pod, you are able to run the script again, and it prompts you to ask if you want to unseal it.

!!Attention!!

I've used GlusterFS as storage class in kubernetes, you should change it to what you are using. The configuration is in "vault/deploy.yaml" and "consul/deploy.yaml" last section which is "volumeClaimTemplates:" so, change "storageClassName: "glusterfs"" to your cluster storage class.

How to contribute:

Several things need to be implemented like: TLS and etc. You are more than welcome to contribute to this project.

Copyright 2021 Hosein Yousefi yousefi.hosein.o@gmail.com

About

vault cluster in kubernetes integrated with consul cluster.

License:Apache License 2.0


Languages

Language:Shell 100.0%