Skip to content

Latest commit

 

History

History
83 lines (63 loc) · 2.99 KB

README.md

File metadata and controls

83 lines (63 loc) · 2.99 KB

tretboot

A small Kubernetes project to bootstrap your real GitOps in a cluster. I had the challenge to setup and configure a Rancher instance in a empty K3s, without wanting to manually install all the required helm charts in that repository.

I wanted to make the installation as simple as possible, deployed from a Git repository and the only dependency to apply this to a cluster initially should be kubectl. This is why I created this small project.

How to install?

To run tretboot you just need apply the tretboot.yaml to your cluster and create a config map containing the URL to the Git repository, that contains your Helm charts or fleet.yaml.

kubectl apply -f https://raw.githubusercontent.com/Deltachaos/tretboot/main/tretboot.yaml
kubectl create configmap tretboot-config \
  --namespace tretboot \
  --from-literal="repository=https://user:[email protected]/somerepo.git"

How to use with ssh key?

If you need a ssh key to access your repository use the following command:

k3s kubectl create secret generic tretboot-ssh \
  --namespace tretboot \
  --from-file=ssh-privatekey=$HOME/.ssh/id_ed25519 \
  --from-file=ssh-publickey=$HOME/.ssh/id_ed25519.pub

Show logs

kubectl logs -f --namespace tretboot --selector=app=tretboot

ConfigMap reference

apiVersion: v1
kind: ConfigMap
metadata:
  name: tretboot-config
  namespace: tretboot
data:
  repository: "https://user:[email protected]/somerepo.git" # URL to the git repository
  autoupdate: "https://raw.githubusercontent.com/Deltachaos/tretboot/main/tretboot.yaml" # URL for auto update. Empty string for disable.
  path: "some/path" # Relative path in the git repository to look for your helm charts and fleet bundles
  interval: "60" # Sleep interval before git fetch and upgrade of helm charts
  namespace: "default" # The kubernetes namespace, tretboot installs helmcharts into
  # Custom shell script to be executed before the git clone of the repository (sourced)
  hook-before-clone: |
    echo "Hello World"
  # Custom shell script executed in the reconciliation loop
  hook-loop: |
    echo "Hello World"
  helmreleasename.yaml: |
    override:
      any:
        helm:
           value: true

Supported resources

Tretboot is looking for directories containing fleet.yaml or Chart.yaml files. The first matching file in a directory, determines how the directory is treated.

fleet.yaml

Tretboot implements a minimal feature set of Rancher fleet.yaml syntax. Currently supported:

defaultNamespace: default

helm:
  chart: ./chart # Or a chart name
  repo: https://charts.rancher.io # Only required if chart is not a local chart
  disableUpdate: true # If chart is already installed, it will not get updated even with changes
  values:
   any-custom: value

Chat.yaml

If tretboot finds a Chart.yaml it asumes the directory name as release name for the Helm chart, and installes it into the configured namespace (default namespace is default).