Skip to content

Latest commit

 

History

History
31 lines (25 loc) · 1.33 KB

README.md

File metadata and controls

31 lines (25 loc) · 1.33 KB

Cloud Lab

The source of truth for my Kubernetes clusters. I use this to manage both my on-prem and cloud deployments. Manifests are configured in a modular fashion using flux, kustomize, and helm to allow for simple cross-cluster orchestration.

I often use this repo in junction with my k3s-ansible repository. Once the ansible script has created the cluster it can be bootstrapped with this one.

If the cluster was created without a CNI, install cillum with its cli by running cilium install.

Bootstrapping

# environment
export SOPS_AGE_KEY=path_to_agekey_file
export CLUSTER=flux_cluster_config_to_use
export BRANCH=branch
export SSH_KEY=path_to_ssh_key
# optional
export SSH_KEY_PASS=password_to_ssh_key_file

# manually create flux namespace
kubectl create ns flux-system
# create SOPS secret so flux can decrypt secrets
kubectl create secret generic sops-age --namespace=flux-system --from-file=$SOPS_AGE_KEY_FILE
# Now we can bootstrap the cluster with a single command
flux bootstrap git \
    --url=ssh://[email protected]/clanktron/homelab \
    --branch=$BRANCH \
    --private-key-file="$SSH_KEY" \
    --password="$SSH_KEY_PASS" \
    --path=clusters/"$CLUSTER"