Add debian docker image, drop helm2, upgrade packages. (#1956)
- Add debian image based on `stable-slim`, desire for this is largely around my use case using Azure DevOps which makes it challenging to use images which are not glibc based. - Drop support for helm2 in the docker images. This is a tricky one but given that I was having errors during the docker build for helm2 and the fact that it has been EoL for a long time now made me think that this was the correct move. - As a "while I'm in here" I've upgraded kubectl and helm. I've popped on the most current patch of the last release (v1.20.3) to give a slightly broader support for different Kubernetes versions. - Reworked CI to support pushing a debian and alpine base, and dropped support for the helm2 versions.
This commit is contained in:
parent
ccd81de77e
commit
ad2f8e87e6
|
|
@ -1,5 +1,4 @@
|
||||||
HELM_VERSION ?= v3.5.3
|
HELM_VERSION ?= v3.5.3
|
||||||
HELM2_VERSION ?= v2.17.0
|
|
||||||
KUSTOMIZE_VERSION ?= v3.8.8
|
KUSTOMIZE_VERSION ?= v3.8.8
|
||||||
K8S_VERSION ?= v1.13.12
|
K8S_VERSION ?= v1.13.12
|
||||||
MINIKUBE_VERSION ?= v0.30.0
|
MINIKUBE_VERSION ?= v0.30.0
|
||||||
|
|
@ -15,7 +14,6 @@ VAULT_TOKEN := toor
|
||||||
|
|
||||||
tmp := $(shell mktemp -d)
|
tmp := $(shell mktemp -d)
|
||||||
HELM_FILENAME := helm-${HELM_VERSION}-linux-amd64.tar.gz
|
HELM_FILENAME := helm-${HELM_VERSION}-linux-amd64.tar.gz
|
||||||
HELM2_FILENAME := helm-${HELM2_VERSION}-linux-amd64.tar.gz
|
|
||||||
KUSTOMIZE_FILENAME := kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
|
KUSTOMIZE_FILENAME := kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -28,13 +26,6 @@ helm:
|
||||||
sudo mv ${tmp}/linux-amd64/helm /usr/local/bin/
|
sudo mv ${tmp}/linux-amd64/helm /usr/local/bin/
|
||||||
.PHONY: helm
|
.PHONY: helm
|
||||||
|
|
||||||
helm2:
|
|
||||||
curl -sSLo $(tmp)/${HELM2_FILENAME} "https://kubernetes-helm.storage.googleapis.com/${HELM2_FILENAME}"
|
|
||||||
tar zxf $(tmp)/${HELM2_FILENAME} --directory ${tmp} linux-amd64/helm
|
|
||||||
chmod +x ${tmp}/linux-amd64/helm
|
|
||||||
sudo mv ${tmp}/linux-amd64/helm /usr/local/bin/
|
|
||||||
.PHONY: helm2
|
|
||||||
|
|
||||||
kustomize:
|
kustomize:
|
||||||
curl -sSLo $(tmp)/${KUSTOMIZE_FILENAME} "https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2F${KUSTOMIZE_VERSION}/${KUSTOMIZE_FILENAME}"
|
curl -sSLo $(tmp)/${KUSTOMIZE_FILENAME} "https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2F${KUSTOMIZE_VERSION}/${KUSTOMIZE_FILENAME}"
|
||||||
tar zxf $(tmp)/${KUSTOMIZE_FILENAME} --directory ${tmp} kustomize
|
tar zxf $(tmp)/${KUSTOMIZE_FILENAME} --directory ${tmp} kustomize
|
||||||
|
|
|
||||||
|
|
@ -42,7 +42,7 @@ jobs:
|
||||||
go mod vendor
|
go mod vendor
|
||||||
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make image
|
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make image
|
||||||
|
|
||||||
image_helm3:
|
image_debian:
|
||||||
docker:
|
docker:
|
||||||
- image: circleci/golang:1.16.3
|
- image: circleci/golang:1.16.3
|
||||||
working_directory: /home/circleci/workspace/helmfile
|
working_directory: /home/circleci/workspace/helmfile
|
||||||
|
|
@ -57,7 +57,7 @@ jobs:
|
||||||
command: |
|
command: |
|
||||||
make tools
|
make tools
|
||||||
go mod vendor
|
go mod vendor
|
||||||
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make image/helm3
|
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make image/debian
|
||||||
|
|
||||||
test:
|
test:
|
||||||
environment:
|
environment:
|
||||||
|
|
@ -135,7 +135,7 @@ jobs:
|
||||||
docker login -u="$DOCKER_USER" -p="$DOCKER_PASS" quay.io
|
docker login -u="$DOCKER_USER" -p="$DOCKER_PASS" quay.io
|
||||||
make tools
|
make tools
|
||||||
go mod vendor
|
go mod vendor
|
||||||
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make push push/helm3 release
|
ORG=roboll BUILD_URL="$CIRCLE_BUILD_URL" make push push/debian release
|
||||||
|
|
||||||
workflows:
|
workflows:
|
||||||
version: 2
|
version: 2
|
||||||
|
|
@ -143,14 +143,14 @@ workflows:
|
||||||
jobs:
|
jobs:
|
||||||
- build
|
- build
|
||||||
- image
|
- image
|
||||||
- image_helm3
|
- image_debian
|
||||||
- test
|
- test
|
||||||
- integration_tests:
|
- integration_tests:
|
||||||
requires:
|
requires:
|
||||||
- build
|
- build
|
||||||
matrix:
|
matrix:
|
||||||
parameters:
|
parameters:
|
||||||
helm-version: ["v2.17.0", "v3.4.2", "v3.5.4"]
|
helm-version: ["v2.17.0", "v3.4.2", "v3.5.4", "v3.6.3"]
|
||||||
- release:
|
- release:
|
||||||
filters:
|
filters:
|
||||||
branches:
|
branches:
|
||||||
|
|
|
||||||
35
Dockerfile
35
Dockerfile
|
|
@ -11,17 +11,17 @@ FROM alpine:3.11
|
||||||
|
|
||||||
RUN apk add --no-cache ca-certificates git bash curl jq
|
RUN apk add --no-cache ca-certificates git bash curl jq
|
||||||
|
|
||||||
ARG HELM_VERSION="v2.17.0"
|
ARG HELM_VERSION="v3.6.3"
|
||||||
ARG HELM_LOCATION="https://kubernetes-helm.storage.googleapis.com"
|
ARG HELM_SHA256="07c100849925623dc1913209cd1a30f0a9b80a5b4d6ff2153c609d11b043e262"
|
||||||
|
ARG HELM_LOCATION="https://get.helm.sh"
|
||||||
ARG HELM_FILENAME="helm-${HELM_VERSION}-linux-amd64.tar.gz"
|
ARG HELM_FILENAME="helm-${HELM_VERSION}-linux-amd64.tar.gz"
|
||||||
ARG HELM_SHA256="f3bec3c7c55f6a9eb9e6586b8c503f370af92fe987fcbf741f37707606d70296"
|
|
||||||
RUN set -x && \
|
RUN set -x && \
|
||||||
wget ${HELM_LOCATION}/${HELM_FILENAME} && \
|
wget ${HELM_LOCATION}/${HELM_FILENAME} && \
|
||||||
echo Verifying ${HELM_FILENAME}... && \
|
echo Verifying ${HELM_FILENAME}... && \
|
||||||
sha256sum ${HELM_FILENAME} | grep -q "${HELM_SHA256}" && \
|
sha256sum ${HELM_FILENAME} | grep -q "${HELM_SHA256}" && \
|
||||||
echo Extracting ${HELM_FILENAME}... && \
|
echo Extracting ${HELM_FILENAME}... && \
|
||||||
tar zxvf ${HELM_FILENAME} && mv /linux-amd64/helm /usr/local/bin/ && \
|
tar zxvf ${HELM_FILENAME} && mv /linux-amd64/helm /usr/local/bin/ && \
|
||||||
mv /linux-amd64/tiller /usr/local/bin/ && \
|
|
||||||
rm ${HELM_FILENAME} && rm -r /linux-amd64
|
rm ${HELM_FILENAME} && rm -r /linux-amd64
|
||||||
|
|
||||||
# using the install documentation found at https://kubernetes.io/docs/tasks/tools/install-kubectl/
|
# using the install documentation found at https://kubernetes.io/docs/tasks/tools/install-kubectl/
|
||||||
|
|
@ -29,21 +29,28 @@ RUN set -x && \
|
||||||
# we should be able to install using apk add.
|
# we should be able to install using apk add.
|
||||||
# the sha256 sum can be found at https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl.sha256
|
# the sha256 sum can be found at https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl.sha256
|
||||||
# maybe a good idea to automate in the future?
|
# maybe a good idea to automate in the future?
|
||||||
ENV KUBECTL_VERSION="v1.18.9"
|
ENV KUBECTL_VERSION="v1.21.4"
|
||||||
ENV KUBECTL_SHA256="6a68756a2d3d04b4d0f52b00de6493ba2c1fcb28b32f3e4a0e99b3d9f6c4e8ed"
|
ENV KUBECTL_SHA256="9410572396fb31e49d088f9816beaebad7420c7686697578691be1651d3bf85a"
|
||||||
RUN set -x & \
|
RUN set -x && \
|
||||||
curl --retry 5 --retry-connrefused -LO "https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl" && \
|
curl --retry 5 --retry-connrefused -LO "https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl" && \
|
||||||
sha256sum kubectl | grep ${KUBECTL_SHA256} && \
|
sha256sum kubectl | grep ${KUBECTL_SHA256} && \
|
||||||
chmod +x kubectl && \
|
chmod +x kubectl && \
|
||||||
mv kubectl /usr/local/bin/kubectl
|
mv kubectl /usr/local/bin/kubectl
|
||||||
|
|
||||||
RUN ["helm", "init", "--client-only", "--stable-repo-url", "https://charts.helm.sh/stable"]
|
ENV KUSTOMIZE_VERSION="v3.8.8"
|
||||||
RUN helm plugin install https://github.com/databus23/helm-diff && \
|
ENV KUSTOMIZE_SHA256="175938206f23956ec18dac3da0816ea5b5b485a8493a839da278faac82e3c303"
|
||||||
helm plugin install https://github.com/futuresimple/helm-secrets && \
|
RUN set -x && \
|
||||||
helm plugin install https://github.com/hypnoglow/helm-s3.git && \
|
curl --retry 5 --retry-connrefused -LO https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/${KUSTOMIZE_VERSION}/kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
helm plugin install https://github.com/aslafy-z/helm-git.git && \
|
sha256sum kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz | grep ${KUSTOMIZE_SHA256} && \
|
||||||
helm plugin install https://github.com/rimusz/helm-tiller
|
tar zxf kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
|
rm kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
|
mv kustomize /usr/local/bin/kustomize
|
||||||
|
|
||||||
|
RUN helm plugin install https://github.com/databus23/helm-diff --version v3.1.3 && \
|
||||||
|
helm plugin install https://github.com/jkroepke/helm-secrets --version v3.5.0 && \
|
||||||
|
helm plugin install https://github.com/hypnoglow/helm-s3.git --version v0.10.0 && \
|
||||||
|
helm plugin install https://github.com/aslafy-z/helm-git.git --version v0.10.0
|
||||||
|
|
||||||
COPY --from=builder /workspace/helmfile/dist/helmfile_linux_amd64 /usr/local/bin/helmfile
|
COPY --from=builder /workspace/helmfile/dist/helmfile_linux_amd64 /usr/local/bin/helmfile
|
||||||
|
|
||||||
CMD ["/usr/local/bin/helmfile", "--help"]
|
CMD ["/usr/local/bin/helmfile"]
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,70 @@
|
||||||
|
FROM golang:1.16.7 as builder
|
||||||
|
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install --no-install-recommends -y \
|
||||||
|
build-essential \
|
||||||
|
git \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
WORKDIR /workspace/helmfile
|
||||||
|
COPY . /workspace/helmfile
|
||||||
|
|
||||||
|
RUN make static-linux
|
||||||
|
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
FROM debian:stable-slim
|
||||||
|
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y --no-install-recommends \
|
||||||
|
ca-certificates \
|
||||||
|
git \
|
||||||
|
bash \
|
||||||
|
curl \
|
||||||
|
jq \
|
||||||
|
wget \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
ARG HELM_VERSION="v3.6.3"
|
||||||
|
ARG HELM_SHA256="07c100849925623dc1913209cd1a30f0a9b80a5b4d6ff2153c609d11b043e262"
|
||||||
|
ARG HELM_LOCATION="https://get.helm.sh"
|
||||||
|
ARG HELM_FILENAME="helm-${HELM_VERSION}-linux-amd64.tar.gz"
|
||||||
|
|
||||||
|
RUN set -x && \
|
||||||
|
wget "${HELM_LOCATION}/${HELM_FILENAME}" && \
|
||||||
|
echo "Verifying ${HELM_FILENAME}..." && \
|
||||||
|
sha256sum "${HELM_FILENAME}" | grep -q "${HELM_SHA256}" && \
|
||||||
|
echo "Extracting ${HELM_FILENAME}..." && \
|
||||||
|
tar zxvf "${HELM_FILENAME}" && mv /linux-amd64/helm /usr/local/bin/ && \
|
||||||
|
rm ${HELM_FILENAME} && rm -r /linux-amd64
|
||||||
|
|
||||||
|
# using the install documentation found at https://kubernetes.io/docs/tasks/tools/install-kubectl/
|
||||||
|
# for now but in a future version of alpine (in the testing version at the time of writing)
|
||||||
|
# we should be able to install using apk add.
|
||||||
|
# the sha256 sum can be found at https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl.sha256
|
||||||
|
# maybe a good idea to automate in the future?
|
||||||
|
ENV KUBECTL_VERSION="v1.21.4"
|
||||||
|
ENV KUBECTL_SHA256="9410572396fb31e49d088f9816beaebad7420c7686697578691be1651d3bf85a"
|
||||||
|
RUN set -x && \
|
||||||
|
wget "https://storage.googleapis.com/kubernetes-release/release/${KUBECTL_VERSION}/bin/linux/amd64/kubectl" && \
|
||||||
|
sha256sum kubectl | grep ${KUBECTL_SHA256} && \
|
||||||
|
chmod +x kubectl && \
|
||||||
|
mv kubectl /usr/local/bin/kubectl
|
||||||
|
|
||||||
|
ENV KUSTOMIZE_VERSION="v3.8.8"
|
||||||
|
ENV KUSTOMIZE_SHA256="175938206f23956ec18dac3da0816ea5b5b485a8493a839da278faac82e3c303"
|
||||||
|
RUN set -x && \
|
||||||
|
curl --retry 5 --retry-connrefused -LO https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/${KUSTOMIZE_VERSION}/kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
|
sha256sum kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz | grep ${KUSTOMIZE_SHA256} && \
|
||||||
|
tar zxf kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
|
rm kustomize_${KUSTOMIZE_VERSION}_linux_amd64.tar.gz && \
|
||||||
|
mv kustomize /usr/local/bin/kustomize
|
||||||
|
|
||||||
|
RUN helm plugin install https://github.com/databus23/helm-diff --version v3.1.3 && \
|
||||||
|
helm plugin install https://github.com/jkroepke/helm-secrets --version v3.5.0 && \
|
||||||
|
helm plugin install https://github.com/hypnoglow/helm-s3.git --version v0.10.0 && \
|
||||||
|
helm plugin install https://github.com/aslafy-z/helm-git.git --version v0.10.0
|
||||||
|
|
||||||
|
COPY --from=builder /workspace/helmfile/dist/helmfile_linux_amd64 /usr/local/bin/helmfile
|
||||||
|
|
||||||
|
CMD ["/usr/local/bin/helmfile"]
|
||||||
8
Makefile
8
Makefile
|
|
@ -71,11 +71,11 @@ run: image
|
||||||
push: image
|
push: image
|
||||||
docker push quay.io/${ORG}/helmfile:${TAG}
|
docker push quay.io/${ORG}/helmfile:${TAG}
|
||||||
|
|
||||||
image/helm3:
|
image/debian:
|
||||||
docker build -f Dockerfile.helm3 -t quay.io/${ORG}/helmfile:helm3-${TAG} .
|
docker build -f Dockerfile.debian -t quay.io/${ORG}/helmfile:${TAG}-stable-slim .
|
||||||
|
|
||||||
push/helm3: image/helm3
|
push/debian: image/debian
|
||||||
docker push quay.io/${ORG}/helmfile:helm3-${TAG}
|
docker push quay.io/${ORG}/helmfile:${TAG}-stable-slim
|
||||||
|
|
||||||
tools:
|
tools:
|
||||||
go get -u github.com/tcnksm/ghr github.com/mitchellh/gox
|
go get -u github.com/tcnksm/ghr github.com/mitchellh/gox
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue