From 67e998d7b49ac28cf9d71349fb9801f657fea531 Mon Sep 17 00:00:00 2001 From: diverdane Date: Mon, 9 Mar 2020 17:35:33 -0400 Subject: [PATCH] Deploys project on GKE 1.15.7 This change fixes a problem whereby deployment of the marketplace app would fail on GKE clusters with Kubernetes versions >= 1.15. The main problem was that we were using the Google Marketplace Tools Version 0.7.0, and this uses a version of kubectl (1.12) that does not know how to authenticate with Kubernetes version 1.15 or newer. The changes included are as follows: * Upgraded the Google Marketplace Tools container image used by the Deployer from 0.7.0 to 0.10.0. The newer version of these tools provide an adaptive Kubectl client version (tools read the Kubernetes server version, then select a matching kubectl binary). * Upgraded the Google Marketplace Tools submodule to 0.10.0. * Upgraded the version of Helm used by the deployer from 2.6.1 to 2.16.1 to eliminate this Helm bug: https://github.com/helm/helm/issues/2998 * Deleted x-google-marketplace section for tester.image in schema.yaml to be consistent for Google Marketplace Tools v0.10.0 * Added a build.sh flag (`-p` or `--persist`) to persist the application deployment after testing. * Fixed the deployment's `deploy-info` annotations to use keys that are valid JSON keys (i.e. with quotes). Fixes Issue #25 "Project fails to deploy on GKE 1.15.7-gke.23" --- CHANGELOG.md | 7 +++++++ DEVELOPMENT.md | 28 +++++++++++++++++++++++----- Jenkinsfile | 4 ++++ Makefile | 2 ++ README.md | 23 ++++++++++++----------- app.Makefile | 3 +++ apptest/deployer/schema.yaml | 2 -- build.sh | 8 ++++++-- conjur/templates/application.yaml | 2 +- crd.Makefile | 4 +++- deployer/Dockerfile | 4 ++-- 11 files changed, 63 insertions(+), 24 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 87b516e..9050ad7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,13 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). ## [Unreleased] +### Changed +- Upgraded the Google Marketplace Tools container image used by the Deployer from 0.7.0 to 0.10.0. The newer version of these tools provide an adaptive Kubectl client version (tools read the Kubernetes server version, then select a matching kubectl binary). +- Upgraded the Google Marketplace Tools submodule to 0.10.0. +- Upgraded the version of Helm used by the deployer from 2.6.1 to 2.16.1 to eliminate this Helm bug: https://github.com/helm/helm/issues/2998 +- Deleted x-google-marketplace section for tester.image in schema.yaml to be consistent for Google Marketplace Tools v0.10.0 +- Added a build.sh flag (`-p` or `--persist`) to persist the application deployment after testing. +- Fixed the deployment's `deploy-info` annotations to use keys that are valid JSON keys (i.e. with quotes). ## [1.3.4](https://github.com/cyberark/conjur-google-cloud-launcher/releases/tag/v1.3.4) - 2019-01-08 ### Changed diff --git a/DEVELOPMENT.md b/DEVELOPMENT.md index f35057a..da7112d 100644 --- a/DEVELOPMENT.md +++ b/DEVELOPMENT.md @@ -19,13 +19,30 @@ The project URL is: https://console.cloud.google.com/home/dashboard?organizationId=854380395992&project=conjur-cloud-launcher-onboard +Before proceeding, make sure that: +* You are authorized to access to the `conjur-cloud-launcher-onboard` GCP project. +* Your current GCP project is set to `conjur-cloud-launcher-onboard`: +``` +gcloud config set project conjur-cloud-launcher-onboard +``` +* Your current GCP cluster is set to the desired cluster in the `conjur-cloud-launcher-onboard` project: +``` +gcloud container cluster list +gcloud container clusters get-credentials +``` + ## Cluster Setup 0. Run the following command to create the Application CRD: `$ make crd/install`. -1. Create the namespace from `setenv.sh`: `kubectl create ns "$(whoami)"` +1. Create the namespace from `setenv.sh`, and set to that namespace: +``` + export NAMESPACE="$(whoami)" + kubectl create ns "$NAMESPACE" + kubectl config set-context --current --namespace="$NAMESPACE" +``` -2. Run the following to create the app: `$ make app/install`. +2. Run the following to create the app: `$ make app/install-test`. 3. Run the following to watch the app: `$ make app/watch`. @@ -48,6 +65,7 @@ This is done automatically by Jenkins in the build pipeline. ## Testing -`./build.sh` will automatically test the application with the configured kubectl context. -It will launch the application in a custom namespace, test it, and then delete the namespace. -This step is also automatically done by the build pipeline. +The `build.sh` script can be run a couple of ways: + +* `./build.sh` will automatically test the application with the configured kubectl context. It will launch the application in a custom namespace, test it, and then delete the namespace. This step is also automatically done by the build pipeline. +* `./build.sh -p` (or `./build.sh --persist`) will automatically test the application with the configured kubectl context. It will launch the application in a custom namespace, test it, and leave the application running. diff --git a/Jenkinsfile b/Jenkinsfile index 3fa8b22..b1271d2 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -8,6 +8,10 @@ pipeline { buildDiscarder(logRotator(numToKeepStr: '30')) } + triggers { + cron(getDailyCronString()) + } + environment { REGISTRY = 'gcr.io/conjur-cloud-launcher-onboard' } diff --git a/Makefile b/Makefile index 5e010c2..0d8b6b6 100644 --- a/Makefile +++ b/Makefile @@ -64,6 +64,8 @@ app/build:: .build/conjur/deployer \ .build/var/REGISTRY \ .build/var/TAG \ | .build/conjur + # Note: print_target displays a highlighted (in yellow) message + # indicating the target that is being built. $(call print_target, $@) docker build \ --build-arg REGISTRY="$(REGISTRY)" \ diff --git a/README.md b/README.md index 93219f1..de82ee2 100644 --- a/README.md +++ b/README.md @@ -89,7 +89,7 @@ export NAMESPACE=conjur Configure the container images: ```shell -export TAG_VERSION=1.3.4 +export TAG_VERSION=1.4.0 export IMAGE_CONJUR="gcr.io/cloud-marketplace/cyberark/conjur-open-source:$TAG_VERSION" export IMAGE_POSTGRES="gcr.io/cloud-marketplace/cyberark/conjur-open-source/postgres:$TAG_VERSION" export IMAGE_NGINX="gcr.io/cloud-marketplace/cyberark/conjur-open-source/nginx:$TAG_VERSION" @@ -112,10 +112,6 @@ for i in "IMAGE_CONJUR" "IMAGE_POSTGRES" "IMAGE_NGINX"; do done ``` -The Conjur data key is generated by the -deployer and does not need to be created -beforehand. - #### Create namespace in your Kubernetes cluster We recommend running Conjur in its own namespace. @@ -123,11 +119,14 @@ If you use a different namespace than the `default`, run the command below to cr ```shell kubectl create namespace "$NAMESPACE" +kubectl config set-context --current --namespace="$NAMESPACE" ``` -#### Install the application with Helm to your Kubernetes cluster +#### Install the application with Helm (v2) to your Kubernetes cluster + +These instructions assume that your local `helm` client is version 2. -This project uses the upstream [cyberark/conjur-oss Helm chart](https://github.com/cyberark/conjur-oss-helm-chart). +This project uses the upstream [cyberark/conjur-oss Helm chart](https://github.com/cyberark/conjur-oss-helm-chart). (You do not need to clone or helm install this repo directly; this will be done indirectly via the helm install of conjur below.) Use `helm` to deploy the application to your Kubernetes cluster: @@ -138,7 +137,8 @@ See [conjur-oss/values.yaml](https://github.com/cyberark/conjur-oss-helm-chart/b for all available upstream Helm chart parameters and their defaults. ```shell -helm install ./conjur +helm dependency update ./conjur +helm install conjur --set conjur-oss.dataKey="$(docker run --rm cyberark/conjur data-key generate)" ./conjur ``` #### View the app in the Google Cloud Console @@ -264,11 +264,12 @@ Delete the application release using Helm: ```sh-session # Find the release $ helm list | grep conjur -reeling-greyhound 1 Fri Jul 20 16:36:03 2018 DEPLOYED conjur-1.0.0 + +conjur conjur 1 2020-03-09 15:36:14.293351857 -0400 EDT deployed conjur-1.3.7 # Delete the release -$ helm delete reeling-greyhound -release "reeling-greyhound" deleted +$ helm delete conjur +release "conjur" uninstalled ``` ## License diff --git a/app.Makefile b/app.Makefile index 1ce26e7..e2ff164 100644 --- a/app.Makefile +++ b/app.Makefile @@ -41,6 +41,9 @@ endef .PHONY: .build/app/dev .build/app/dev: .build/var/MARKETPLACE_TOOLS_TAG \ | .build/app + # Note: print_target displays a highlighted (in yellow) message + # indicating the target that is being built. + $(call print_target, $@) docker run \ "gcr.io/cloud-marketplace-tools/k8s/dev:$(MARKETPLACE_TOOLS_TAG)" \ cat /scripts/dev > "$@" diff --git a/apptest/deployer/schema.yaml b/apptest/deployer/schema.yaml index 75d6e1d..b3dc7cd 100644 --- a/apptest/deployer/schema.yaml +++ b/apptest/deployer/schema.yaml @@ -2,8 +2,6 @@ properties: tester.image: type: string default: $REGISTRY/tester:$TAG - x-google-marketplace: - type: IMAGE conjur-oss.ssl.hostname: type: string diff --git a/build.sh b/build.sh index f99ed9d..e28df4e 100755 --- a/build.sh +++ b/build.sh @@ -9,12 +9,16 @@ make crd/install gcloud auth configure-docker chart_dir="" +build_target="app/verify" while [ "$1" != "" ]; do case $1 in -c | --chart-dir ) shift chart_dir="${1}" ;; + # Use the -p | --persist flag to keep the application running + -p | --persist ) build_target="app/install-test" + ;; * ) >&2 echo "Unknown argument: ${1}" exit 1 ;; @@ -39,13 +43,13 @@ if [ "${chart_dir}" != "" ]; then fi echo "Getting the desired marketplace Docker image..." -MARKETPLACE_TOOLS_TAG="0.7.0" +MARKETPLACE_TOOLS_TAG="0.10.0" LOCAL_MARKETPLACE_TOOLS_TAG="local-$USER" docker pull "gcr.io/cloud-marketplace-tools/k8s/dev:$MARKETPLACE_TOOLS_TAG" docker tag "gcr.io/cloud-marketplace-tools/k8s/dev:$MARKETPLACE_TOOLS_TAG" \ "gcr.io/cloud-marketplace-tools/k8s/dev:$LOCAL_MARKETPLACE_TOOLS_TAG" echo "Building/verifying app..." -make -j4 -e app/verify +make -j4 -e "$build_target" echo "Done!" diff --git a/conjur/templates/application.yaml b/conjur/templates/application.yaml index 878d541..7d14aa2 100644 --- a/conjur/templates/application.yaml +++ b/conjur/templates/application.yaml @@ -7,7 +7,7 @@ metadata: annotations: kubernetes-engine.cloud.google.com/icon: >-  - marketplace.cloud.google.com/deploy-info: '{partner_id: "cyberark", product_id: "conjur-open-source", partner_name: "CyberArk"}' + marketplace.cloud.google.com/deploy-info: '{"partner_id": "cyberark", "product_id": "conjur-open-source", "partner_name": "CyberArk"}' labels: app.kubernetes.io/name: "{{ .Release.Name }}" spec: diff --git a/crd.Makefile b/crd.Makefile index 2eb89a1..f8a5ac1 100644 --- a/crd.Makefile +++ b/crd.Makefile @@ -7,7 +7,9 @@ include common.Makefile # Installs the application CRD on the cluster. .PHONY: crd/install crd/install: - kubectl apply -f "https://raw.githubusercontent.com/GoogleCloudPlatform/marketplace-k8s-app-tools/master/crd/app-crd.yaml" + # Ignore errors on kubectl apply. `AlreadyExists` Errors can occur if + # another parallel test is doing a kubectl apply at the same time. + -kubectl apply -f "https://raw.githubusercontent.com/GoogleCloudPlatform/marketplace-k8s-app-tools/master/crd/app-crd.yaml" # Uninstalls the application CRD from the cluster. diff --git a/deployer/Dockerfile b/deployer/Dockerfile index 0312daf..28b850e 100644 --- a/deployer/Dockerfile +++ b/deployer/Dockerfile @@ -5,7 +5,7 @@ RUN echo "cachebuster-20190118" >/dev/null \ && apt-get update \ && apt-get install -y --no-install-recommends gettext curl -RUN curl -L -o /tmp/helm.tgz https://storage.googleapis.com/kubernetes-helm/helm-v2.6.1-linux-amd64.tar.gz && \ +RUN curl -L -o /tmp/helm.tgz https://storage.googleapis.com/kubernetes-helm/helm-v2.16.1-linux-amd64.tar.gz && \ cd /tmp && \ tar xvzf helm.tgz && \ cp linux-amd64/helm /usr/local/bin/helm && \ @@ -43,7 +43,7 @@ RUN cat /tmp/test/schema.yaml \ && mv /tmp/test/schema.yaml.new /tmp/test/schema.yaml -FROM gcr.io/cloud-marketplace-tools/k8s/deployer_helm:0.7.0 +FROM gcr.io/cloud-marketplace-tools/k8s/deployer_helm:0.10.0 COPY --from=build /tmp/conjur.tar.gz /data/chart/ COPY --from=build /tmp/test/conjur.tar.gz /data-test/chart/ COPY --from=build /tmp/schema.yaml /data/