Go to file
Afonso Garcia 3c8cb78603
Change README to reflect real default value of persistence.enabled (#791)
2025-01-07 08:37:50 +01:00
.dependabot add dependabot config 2020-04-19 20:45:47 +02:00
.github/workflows Initial fixes 2024-11-04 20:02:58 +01:00
.pipeline GCP cloud build integration and chart lint and install test 2018-11-23 12:54:57 +00:00
.scripts Revert unnecessary sh --> bash change 2020-09-08 23:05:48 -05:00
.test ci: fix ct timeout 2021-01-05 13:33:11 +01:00
approvals chore: remove refs to deprecated io/ioutil (#778) 2024-11-06 10:46:52 +01:00
bot chore: remove refs to deprecated io/ioutil (#778) 2024-11-06 10:46:52 +01:00
chart/keel Change README to reflect real default value of persistence.enabled (#791) 2025-01-07 08:37:50 +01:00
cmd/keel New keel.sh/monitorContainers annotation to allow explicitly setting which containers should be monitored (#777) 2024-11-05 19:20:03 +01:00
constants Fix slack bot to use the new socket API. 2024-07-31 21:22:05 +02:00
deployment Merge pull request #692 from vorburger/patch-1 2023-03-05 20:11:05 +00:00
extension chore: remove refs to deprecated io/ioutil (#778) 2024-11-06 10:46:52 +01:00
internal feat: Allow poll trigger to work with glob and regexp (#745) 2024-11-06 11:46:37 +01:00
pkg chore: remove refs to deprecated io/ioutil (#778) 2024-11-06 10:46:52 +01:00
provider chore: remove refs to deprecated io/ioutil (#778) 2024-11-06 10:46:52 +01:00
registry Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
secrets Build with kube 1.24 (#1) 2023-03-01 11:51:58 -05:00
static added readme 2019-05-29 23:06:16 +01:00
tests Add support for OCI images 2023-04-11 15:53:31 +10:00
trigger feat: Allow poll trigger to work with glob and regexp (#745) 2024-11-06 11:46:37 +01:00
types feat: Allow poll trigger to work with glob and regexp (#745) 2024-11-06 11:46:37 +01:00
ui Updated copyright year 2020-10-18 13:04:53 -06:00
util Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
version updated repo 2017-11-01 18:25:28 +00:00
.dockerignore New keel.sh/monitorContainers annotation to allow explicitly setting which containers should be monitored (#777) 2024-11-05 19:20:03 +01:00
.drone.yml Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
.gitignore Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
Dockerfile Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
Dockerfile.aarch64 Dockerfiles for arm 2018-10-14 14:00:55 +01:00
Dockerfile.armhf makefile for arm 2020-03-02 23:44:15 +00:00
Dockerfile.debian Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
Dockerfile.debug Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
Dockerfile.local vendor updated 2017-08-04 22:15:11 +01:00
Dockerfile.tests Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
LICENSE license, readme 2017-06-11 23:44:13 +01:00
Makefile Initial fixes 2024-11-04 20:02:58 +01:00
azure-pipelines.yml Initial fixes 2024-11-04 20:02:58 +01:00
build.ps1 Initial fixes 2024-11-04 20:02:58 +01:00
compose.debug.yml Initial fixes 2024-11-04 20:02:58 +01:00
compose.tests.yml Initial fixes 2024-11-04 20:02:58 +01:00
compose.yml Initial fixes 2024-11-04 20:02:58 +01:00
envsettings.ps1.template Initial fixes 2024-11-04 20:02:58 +01:00
go.mod Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
go.sum Bump packages versions in go.mod 2024-12-10 16:38:04 +01:00
helpers.ps1 Initial fixes 2024-11-04 20:02:58 +01:00
readme.md New keel.sh/monitorContainers annotation to allow explicitly setting which containers should be monitored (#777) 2024-11-05 19:20:03 +01:00
values.yaml cleanup 2023-03-05 20:26:11 +00:00

readme.md

Go Report Docker Pulls Drone Status

Keel - automated Kubernetes deployments for the rest of us

Keel is a tool for automating Kubernetes deployment updates. Keel is stateless, robust and lightweight.

Keel provides several key features:

  • Kubernetes and Helm providers - Keel has direct integrations with Kubernetes and Helm.

  • No CLI/API - tired of f***ctl for everything? Keel doesn't have one. Gets job done through labels, annotations, charts.

  • Semver policies - specify update policy for each deployment/Helm release individually.

  • Automatic Google Container Registry configuration - Keel automatically sets up topic and subscriptions for your deployment images by periodically scanning your environment.

  • Native, DockerHub, Quay and Azure container registry webhooks support - once webhook is received impacted deployments will be identified and updated.

  • Polling - when webhooks and pubsub aren't available - Keel can still be useful by checking Docker Registry for new tags (if current tag is semver) or same tag SHA digest change (ie: latest).

  • Notifications - out of the box Keel has Slack, Hipchat, Mattermost and standard webhook notifications, more info here

Support

Support Keel's development by:

Helm quick start

Prerequisites:

You need to add this Chart repo to Helm:

helm repo add keel https://keel-hq.github.io/keel/ 
helm repo update

Install through Helm (with Helm provider enabled by default):

helm upgrade --install keel --namespace=kube-system keel/keel

If you work mostly with regular Kubernetes manifests, you can install Keel without Helm provider support:

helm upgrade --install keel --namespace=keel keel/keel --set helmProvider.enabled="false" 

To install for Helm v3, set helmProvider.version="v3" (default is "v2"):

helm install keel keel/keel --set helmProvider.version="v3" 

To install using terraform:

resource "helm_release" "keel" {
  provider   = helm.helm
  name       = "keel"
  namespace  = "keel"
  repository = "https://keel-hq.github.io/keel"
  chart      = "keel"
  version    = "v1.0.4"

  set {
    name  = "basicauth.enabled"
    value = "true"
  }

  set {
    name  = "basicauth.user"
    value = "admin"
  }

  set {
    name  = "basicauth.password"
    value = "admin"
  }

  set {
    name  = "image.repository"
    value = "keelhq/keel"
  }

  set {
    name  = "image.tag"
    value = "0.19.1"
  }
}

That's it, see Configuration section now.

Quick Start

A step-by-step guide to install Keel on your Kubernetes cluster is viewable on the Keel website:

https://keel.sh/examples/#example-1-push-to-deploy

Configuration

Once Keel is deployed, you only need to specify update policy on your deployment file or Helm chart:

apiVersion: apps/v1
kind: Deployment
metadata: 
  name: wd
  namespace: default
  labels: 
    name: "wd"
  annotations:
    keel.sh/policy: minor # <-- policy name according to https://semver.org/
    keel.sh/trigger: poll # <-- actively query registry, otherwise defaults to webhooks
spec:
  template:
    metadata:
      name: wd
      labels:
        app: wd        
    spec:
      containers:                    
        - image: karolisr/webhook-demo:0.0.8
          imagePullPolicy: Always            
          name: wd
          command: ["/bin/webhook-demo"]
          ports:
            - containerPort: 8090

No additional configuration is required. Enabling continuous delivery for your workloads has never been this easy!

Documentation

Documentation is viewable on the Keel Website:

https://keel.sh/docs/#introduction

Contributing

Before starting to work on some big or medium features - raise an issue here so we can coordinate our efforts.

We use pull requests, so:

  1. Fork this repository
  2. Create a branch on your local copy with a sensible name
  3. Push to your fork and open a pull request

Developing Keel

If you wish to work on Keel itself, you will need Go 1.12+ installed. Make sure you put Keel into correct Gopath and go build (dependency management is done through dep).

To test Keel while developing:

  1. Launch a Kubernetes cluster like Minikube or Docker for Mac with Kubernetes.
  2. Change config to use it: kubectl config use-context docker-for-desktop
  3. Build Keel from cmd/keel directory.
  4. Start Keel with: keel --no-incluster. This will use Kubeconfig from your home.

Debugging Keel on Windows

# Ensure we have gcc and go
choco upgrade mingw -y
choco upgrade golang -y

# Move and build
cd cmd/keel
go build

$Env:XDG_DATA_HOME      = $Env:APPDATA; # Data volume for the local database
$Env:HOME               = $Env:USERPROFILE; # This is where the .kube/config will be read from
$Env:KUBERNETES_CONTEXT = "mycontext" #Use if you have more than one context in .kube/config

.\keel --no-incluster

Running unit tests

Get a test parser (makes output nice):

go get github.com/mfridman/tparse

To run unit tests:

make test

Running e2e tests

Prerequisites:

  • configured kubectl + kubeconfig
  • a running cluster (test suite will create testing namespaces and delete them after tests)
  • Go environment (will compile Keel before running)

Once prerequisites are ready:

make e2e

Debugging keel inside the container against your remote cluster (Windows)

The repository contains a debug version of keel container ready for remote debugging.

You can start the debug container with powershell (docker desktop needed):

.\build.ps1 -StartDebugContainers

To connect to your cluster, copy the authentication details from within the keel pod in your cluster from:

/var/run/secrets/kubernetes.io/serviceaccount

to the serviceaccount folder at the root of the repository and make sure you set the environment variable for the K8S management API endpoint:

# This can be configured in envesttings.ps1 to be picked up automatically by the build script
$ENV:KUBERNETES_SERVICE_HOST = "mycluster-o5ff3caf.hcp.myregion.azmk8s.io"
$ENV:KUBERNETES_SERVICE_PORT = "443"

And make sure your API server is accesible from your client (VPN, IP whitelisting or whatever you use to secure your cluster management API).

Once started, simply use the debug option in a Go debugger, such as Jetbrains GoLand:

Debugging a Go application inside a Docker container | The GoLand Blog