Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/int128/flux-continuous-deployment-demo

A demo of Continuous Deployment with Flux using the automated image update feature
https://github.com/int128/flux-continuous-deployment-demo

continuous-deployment flux kubernetes

Last synced: about 1 month ago
JSON representation

A demo of Continuous Deployment with Flux using the automated image update feature

Awesome Lists containing this project

README

        

# flux-continuous-deployment-demo

This is a demo of Continuous Deployment with Flux using the feature of [automated deployment of new container images](https://docs.fluxcd.io/en/stable/references/automated-image-update.html).

## Introduction

In a typical GitOps flow, you need to build a new Docker image and update the manifest to deploy the application.

![gitops-basic-flow.svg](gitops-basic-flow.svg)

In continuous deployment flow, you only need to build a new Docker image. Flux will update the manifest when a newer image is found.

![gitops-continuous-deployment-flow.svg](gitops-continuous-deployment-flow.svg)

## Demo

This demo uses the following components:

- Application repository: https://github.com/int128/hellopage
- Google Cloud Build
- Google Container Registry: https://gcr.io/int128-1313/github.com/int128/hellopage
- Manifest repository: https://github.com/int128/flux-continuous-deployment-demo

You can use your own components by replacing URLs in [`helmfile.yaml`](helmfile.yaml).

### 1. Set up the tools

You need to install the following tools:

- Docker
- Kind
- Helmfile
- fluxctl

To check if the commands are available:

```sh
make check
```

### 2. Provision a cluster

Run make.

```sh
make
```

It will create a cluster and deploy the following components:

1. `Deployment`, `Service` and `Ingress` for the demo app
1. NGINX Ingress
1. Flux

Open http://hellopage-127-0-0-1.nip.io:30080 and make sure you can access the demo app.

### 3. Configure Git access

```sh
export KUBECONFIG=output/kubeconfig.yaml
```

Open https://github.com/int128/flux-continuous-deployment-demo/settings/keys and add the deploy key with write access.
You can get the deploy key as follows:

```console
% fluxctl identity
ssh-rsa ...
```

Make sure that Flux recognizes the deployment.

```console
% fluxctl list-workloads -n hellopage
WORKLOAD CONTAINER IMAGE RELEASE POLICY
hellopage:deployment/hellopage app gcr.io/int128-1313/github.com/int128/hellopage:dev-81f12fd ready automated

% fluxctl list-images -n hellopage
WORKLOAD CONTAINER IMAGE CREATED
hellopage:deployment/hellopage app gcr.io/int128-1313/github.com/int128/hellopage
'-> dev-81f12fd 14 Jun 20 07:11 UTC
```

You can see Flux log for debug.

```sh
make logs-flux
```

### 4. Deploy a new version

Open https://github.com/int128/hellopage and create a commit.
Google Cloud Build will build an image and push it to GCR.

Flux will create a commit to this repository for updating the image tag of deployment.
You can see the image tags which Flux scans.

```console
% fluxctl list-images -n hellopage
WORKLOAD CONTAINER IMAGE CREATED
hellopage:deployment/hellopage app gcr.io/int128-1313/github.com/int128/hellopage
'-> dev-7be21e9 15 Jun 20 01:52 UTC
dev-81f12fd 14 Jun 20 07:11 UTC
```

You can see the new version within a minute.

### 5. Clean up

```sh
make delete-cluster
```

## Troubleshoot

You can see Flux log for debug.

```sh
make logs-flux
```

When Flux found a newer image, it writes logs like:

```
ts=2020-06-15T01:53:47.6752392Z caller=images.go:17 component=sync-loop msg="polling for new images for automated workloads"
ts=2020-06-15T01:53:47.7193163Z caller=images.go:111 component=sync-loop workload=hellopage:deployment/hellopage container=app repo=gcr.io/int128-1313/github.com/int128/hellopage pattern=glob:* current=gcr.io/int128-1313/github.com/int128/hellopage:dev-81f12fd info="added update to automation run" new=gcr.io/int128-1313/github.com/int128/hellopage:dev-7be21e9 reason="latest dev-7be21e9 (2020-06-15 01:52:55.214282133 +0000 UTC) > current dev-81f12fd (2020-06-14 07:11:00.193482088 +0000 UTC)"
```

When Flux pushed a commit, it writes logs like:

```
ts=2020-06-15T01:53:47.7215553Z caller=loop.go:141 component=sync-loop jobID=d23d293c-cf44-52b9-0624-e9e6a62462b7 state=in-progress
ts=2020-06-15T01:53:47.8430268Z caller=releaser.go:59 component=sync-loop jobID=d23d293c-cf44-52b9-0624-e9e6a62462b7 type=release updates=1
ts=2020-06-15T01:53:52.4599673Z caller=daemon.go:292 component=sync-loop jobID=d23d293c-cf44-52b9-0624-e9e6a62462b7 revision=dbf62188f5f4426c1ad6b8043383800b1a4903fb
ts=2020-06-15T01:53:52.4605235Z caller=daemon.go:701 component=daemon event="Commit: dbf6218, hellopage:deployment/hellopage" logupstream=false
ts=2020-06-15T01:53:52.4608724Z caller=loop.go:153 component=sync-loop jobID=d23d293c-cf44-52b9-0624-e9e6a62462b7 state=done success=true
ts=2020-06-15T01:53:54.3104503Z caller=loop.go:133 component=sync-loop event=refreshed url=ssh://[email protected]/int128/continuous-deployment-flux-demo branch=master HEAD=dbf62188f5f4426c1ad6b8043383800b1a4903fb
```