/binnacle

An opinionated tool to interact with Kubernetes' Helm

Primary LanguageGoMIT LicenseMIT

binnacle Release Test

binnacle is an opinionated automation tool used to interact with Kubernetes' Helm. By offering a single file to manage one or many charts, you can easily control all aspects of your Helm managed applications.

binnacle is similar in nature to Helmfile with a slightly different approach to managing Helm Charts.

Installation

A binary for various operating systems is available through Github Releases. Download the appropriate archive, and extract into a directory within your PATH.

Usage

For the full list of options:

binnacle --help

To see the version of binnacle you can use the following:

binnacle --version

Getting Started

Configuration File Format

Configuration files can be written in YAML, TOML or JSON.

---
# charts takes a list of chart configurations
charts:
    # This is the name of the chart
  - name: concourse
    # This is the namespace into which the chart is launched
    namespace: apps
    # This is the name for the release of this chart
    release: apps-concourse
    # This is the name of the repository within which the helm chart is located
    repo: stable
    # This determines if the release is created or removed. Default: present Options: absent, present
    state: present
    # Any data under values are passed to Helm to configure the given chart
    values:
      image: concourse/concourse
      imageTag: "3.10.0"
    # This is the version of the Helm chart.  If this is omitted, the latest is used.
    version: 1.3.1

# repositories takes a list of repository configurations
repositories:
    # This is the name of the repository
  - name: stable
    # This is the URL of the repository
    url: https://kubernetes-charts.storage.googleapis.com
    # This determines if the repository is created or removed. Default: present Options: absent, present
    state: present

Using Binnacle

The standard workflow when using binnacle is to use the template command to verify the desired configuration files are generated, use the sync command to create/update the existing release configuration within Helm, and status to get the status of a release.

Using the configuration available at test-data/demo.yml you can run the template command:

$ binnacle template -c ./test-data/demo.yml 
Loading config file: ./test-data/demo.yml
---
# Source: concourse/templates/namespace.yaml

---
apiVersion: v1
kind: Namespace
metadata:
  annotations:
    "helm.sh/resource-policy": keep
  name: apps-concourse-main
  labels:
...

By reviewing the output you are able to verify that you have specificied all of the necessary configuration aspects of the chart. Once you are happy with how the chart is configured you can sync the charts to Helm:

$  binnacle sync -c ./test-data/demo.yml 
Loading config file: ./test-data/demo.yml
"stable" has been added to your repositories
Release "apps-concourse" does not exist. Installing it now.
NAME:   apps-concourse
LAST DEPLOYED: Fri Apr 27 14:24:19 2018
NAMESPACE: apps
STATUS: DEPLOYED

RESOURCES:
==> v1beta1/StatefulSet
NAME                   DESIRED  CURRENT  AGE
apps-concourse-worker  2        0        1s

==> v1/Pod(related)
NAME                                        READY  STATUS             RESTARTS  AGE
apps-concourse-postgresql-5f964dd587-6ng8f  0/1    Pending            0         1s
apps-concourse-web-5dd649b7f6-7v78w         0/1    ContainerCreating  0         1s

==> v1/Namespace
NAME                 STATUS  AGE
apps-concourse-main  Active  1s

==> v1/Secret
NAME                       TYPE    DATA  AGE
apps-concourse-postgresql  Opaque  1     1s
apps-concourse-concourse   Opaque  7     1s

==> v1/PersistentVolumeClaim
NAME                       STATUS   VOLUME  CAPACITY  ACCESS MODES  STORAGECLASS  AGE
apps-concourse-postgresql  Pending  1s

==> v1beta1/ClusterRole
NAME                AGE
apps-concourse-web  1s

==> v1/Service
NAME                       TYPE       CLUSTER-IP     EXTERNAL-IP  PORT(S)            AGE
apps-concourse-postgresql  ClusterIP  10.233.89.90   <none>       5432/TCP           1s
apps-concourse-web         ClusterIP  10.233.57.192  <none>       8080/TCP,2222/TCP  1s
apps-concourse-worker      ClusterIP  None           <none>       <none>             1s

==> v1/ServiceAccount
NAME                   SECRETS  AGE
apps-concourse-web     1        1s
apps-concourse-worker  1        1s

==> v1beta1/Role
NAME                   AGE
apps-concourse-worker  1s

==> v1beta1/RoleBinding
NAME                     AGE
apps-concourse-web-main  1s
apps-concourse-worker    1s

==> v1beta1/Deployment
NAME                       DESIRED  CURRENT  UP-TO-DATE  AVAILABLE  AGE
apps-concourse-postgresql  1        1        1           0          1s
apps-concourse-web         1        1        1           0          1s

==> v1beta1/PodDisruptionBudget
NAME                   MIN AVAILABLE  MAX UNAVAILABLE  ALLOWED DISRUPTIONS  AGE
apps-concourse-worker  1              N/A              0                    1s


NOTES:

* Concourse can be accessed:

  * Within your cluster, at the following DNS name at port 8080:

    apps-concourse-web.apps.svc.cluster.local

  * From outside the cluster, run these commands in the same shell:

    export POD_NAME=$(kubectl get pods --namespace apps -l "app=apps-concourse-web" -o jsonpath="{.items[0].metadata.name}")
    echo "Visit http://127.0.0.1:8080 to use Concourse"
    kubectl port-forward --namespace apps $POD_NAME 8080:8080

* Login with the following credentials
  
  Username: concourse
  Password: concourse
  
* If this is your first time using Concourse, follow the tutorial at https://concourse-ci.org/hello-world.html

*******************
******WARNING******
*******************

You are using the "naive" baggage claim driver, which is also the default value for this chart. This is the default for compatibility reasons, but is very space inefficient, and should be changed to either "btrfs" (recommended) or "overlay" depending on that filesystem's support in the Linux kernel your cluster is using. Please see https://github.com/concourse/concourse/issues/1230 and https://github.com/concourse/concourse/issues/1966 for background.

From the output you can see that the release did not exist "apps-concourse" so Helm created it. To get updates on the status of the deployment you can use the status command:

$ binnacle status -c ./test-data/demo.yml 
Loading config file: ./test-data/demo.yml
LAST DEPLOYED: Fri Apr 27 14:24:19 2018
NAMESPACE: apps
STATUS: DEPLOYED

RESOURCES:
==> v1/Pod(related)
NAME                                        READY  STATUS   RESTARTS  AGE
apps-concourse-postgresql-5f964dd587-6ng8f  0/1    Pending  0         1m
apps-concourse-web-5dd649b7f6-7v78w         0/1    Running  0         1m

==> v1/Namespace
NAME                 STATUS  AGE
apps-concourse-main  Active  1m

==> v1/Secret
NAME                       TYPE    DATA  AGE
apps-concourse-postgresql  Opaque  1     1m
apps-concourse-concourse   Opaque  7     1m

==> v1beta1/Role
NAME                   AGE
apps-concourse-worker  1m

==> v1/Service
NAME                       TYPE       CLUSTER-IP     EXTERNAL-IP  PORT(S)            AGE
apps-concourse-postgresql  ClusterIP  10.233.89.90   <none>       5432/TCP           1m
apps-concourse-web         ClusterIP  10.233.57.192  <none>       8080/TCP,2222/TCP  1m
apps-concourse-worker      ClusterIP  None           <none>       <none>             1m

==> v1beta1/PodDisruptionBudget
NAME                   MIN AVAILABLE  MAX UNAVAILABLE  ALLOWED DISRUPTIONS  AGE
apps-concourse-worker  1              N/A              0                    1m

==> v1beta1/StatefulSet
NAME                   DESIRED  CURRENT  AGE
apps-concourse-worker  2        2        1m

==> v1/PersistentVolumeClaim
NAME                       STATUS   VOLUME  CAPACITY  ACCESS MODES  STORAGECLASS  AGE
apps-concourse-postgresql  Pending  1m

==> v1/ServiceAccount
NAME                   SECRETS  AGE
apps-concourse-web     1        1m
apps-concourse-worker  1        1m

==> v1beta1/ClusterRole
NAME                AGE
apps-concourse-web  1m

==> v1beta1/RoleBinding
NAME                     AGE
apps-concourse-web-main  1m
apps-concourse-worker    1m

==> v1beta1/Deployment
NAME                       DESIRED  CURRENT  UP-TO-DATE  AVAILABLE  AGE
apps-concourse-postgresql  1        1        1           0          1m
apps-concourse-web         1        1        1           0          1m


NOTES:

* Concourse can be accessed:

  * Within your cluster, at the following DNS name at port 8080:

    apps-concourse-web.apps.svc.cluster.local

  * From outside the cluster, run these commands in the same shell:

    export POD_NAME=$(kubectl get pods --namespace apps -l "app=apps-concourse-web" -o jsonpath="{.items[0].metadata.name}")
    echo "Visit http://127.0.0.1:8080 to use Concourse"
    kubectl port-forward --namespace apps $POD_NAME 8080:8080

* Login with the following credentials
  
  Username: concourse
  Password: concourse
  
* If this is your first time using Concourse, follow the tutorial at https://concourse-ci.org/hello-world.html

*******************
******WARNING******
*******************

You are using the "naive" baggage claim driver, which is also the default value for this chart. This is the default for compatibility reasons, but is very space inefficient, and should be changed to either "btrfs" (recommended) or "overlay" depending on that filesystem's support in the Linux kernel your cluster is using. Please see https://github.com/concourse/concourse/issues/1230 and https://github.com/concourse/concourse/issues/1966 for background.

If you want to remove a release, you can change the state from present to absent and run the sync command:

$ binnacle sync -c ./test-data/demo.yml 
Loading config file: ./test-data/demo.yml
"stable" has been added to your repositories
These resources were kept due to the resource policy:
[Namespace] apps-concourse-main

release "apps-concourse" deleted

Development

Prerequisites:

  • go 1.17

Local Go Environment

First, check out the repository:

git clone https://github.com/Traackr/binnacle.git
cd binnacle

To compile a version of binnacle for your local machine you can run:

make build

This will generate a binary within the ./bin directory of the project.

To run the unit tests:

make test