From 3c2fddf9bf38e87fc87449024bac5cc38f2fe906 Mon Sep 17 00:00:00 2001 From: Mark Harrison Date: Mon, 15 Jan 2024 16:24:26 +0000 Subject: [PATCH] Remove win 2019 build --- .github/workflows/docker-build-push.yml | 55 ++++--------------------- README.md | 1 - windows-2019/Dockerfile | 53 ------------------------ 3 files changed, 7 insertions(+), 102 deletions(-) delete mode 100644 windows-2019/Dockerfile diff --git a/.github/workflows/docker-build-push.yml b/.github/workflows/docker-build-push.yml index 6436da8..a99c61c 100644 --- a/.github/workflows/docker-build-push.yml +++ b/.github/workflows/docker-build-push.yml @@ -15,7 +15,6 @@ jobs: VERSION: ${{ steps.step1.outputs.VERSION }} GCLOUD_CLI_VERSION: ${{ steps.step1.outputs.GCLOUD_CLI_VERSION }} CONTINUE: ${{ steps.step1.outputs.Continue }} - WIN2019_VERSION: ${{ steps.step1.outputs.WIN2019_VERSION }} WIN2022_VERSION: ${{ steps.step1.outputs.WIN2022_VERSION }} steps: - uses: actions/checkout@v3 @@ -88,20 +87,15 @@ jobs: { Write-Host "We need to upgrade the container to $versionToCompare" - Write-Host "Getting OS versions for windows 2022 and 2019" - $win2019_manifest = (docker manifest inspect --verbose "octopuslabs/workertools:latest-windows.2019" | ConvertFrom-Json) - $WIN2019_VERSION = $win2019_manifest.Descriptor.Platform.'os.version' - Write-Host "WIN2019_VERSION: $WIN2019_VERSION" - + Write-Host "Getting OS versions for windows 2022" $win2022_manifest = (docker manifest inspect --verbose "octopuslabs/workertools:latest-windows.2022" | ConvertFrom-Json) $WIN2022_VERSION = $win2022_manifest.Descriptor.Platform.'os.version' Write-Host "WIN2022_VERSION: $WIN2022_VERSION" - if([string]::IsNullOrWhiteSpace($WIN2019_VERSION) -or [string]::IsNullOrWhiteSpace($WIN2022_VERSION)) { - throw "Could not establish OS versions for windows 2022 and 2019 needed for docker manifest" + if([string]::IsNullOrWhiteSpace($WIN2022_VERSION)) { + throw "Could not establish OS versions for windows 2022 needed for docker manifest" } - echo "WIN2019_VERSION=$WIN2019_VERSION" >> $env:GITHUB_OUTPUT echo "WIN2022_VERSION=$WIN2022_VERSION" >> $env:GITHUB_OUTPUT Write-Host "We have everything we need, continuing." @@ -155,38 +149,7 @@ jobs: - name: Push the ubuntu.2204 latest image run: docker push octopuslabs/k8s-workertools:latest-ubuntu.2204 if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - - build-win-2019: - needs: [get-version-number] - runs-on: windows-2019 - - steps: - - uses: actions/checkout@v3 - - - name: DockerHub Login - env: - USERNAME: ${{ secrets.DOCKER_HUB_USER }} - PASSWORD: ${{ secrets.DOCKER_HUB_PAT }} - run: docker login --username ${env:USERNAME} --password "${env:PASSWORD}" - if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - - - name: Build the win2019 image - env: - VERSION_NUMBER: ${{ needs.get-version-number.outputs.VERSION }} - GCLOUD_CLI_VERSION: ${{ needs.get-version-number.outputs.GCLOUD_CLI_VERSION }} - run: docker build ./windows-2019 --build-arg GCLOUD_CLI_VERSION=${env:GCLOUD_CLI_VERSION} --tag octopuslabs/k8s-workertools:${env:VERSION_NUMBER}-windows.2019 --tag octopuslabs/k8s-workertools:latest-windows.2019 - if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - - - name: Push the win2019 version-specific image - env: - VERSION_NUMBER: ${{ needs.get-version-number.outputs.VERSION }} - run: docker push octopuslabs/k8s-workertools:${env:VERSION_NUMBER}-windows.2019 - if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - - - name: Push the win2019 latest image - run: docker push octopuslabs/k8s-workertools:latest-windows.2019 - if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - + build-win-2022: needs: [get-version-number] runs-on: windows-2022 @@ -219,7 +182,7 @@ jobs: if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} build-docker-manifest: - needs: [get-version-number, build-ubuntu, build-win-2019, build-win-2022] + needs: [get-version-number, build-ubuntu, build-win-2022] runs-on: ubuntu-latest steps: @@ -231,15 +194,13 @@ jobs: if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - name: Create docker manifest for latest tag - run: docker manifest create octopuslabs/k8s-workertools:latest octopuslabs/k8s-workertools:latest-windows.2019 octopuslabs/k8s-workertools:latest-windows.2022 octopuslabs/k8s-workertools:latest-ubuntu.2204 + run: docker manifest create octopuslabs/k8s-workertools:latest octopuslabs/k8s-workertools:latest-windows.2022 octopuslabs/k8s-workertools:latest-ubuntu.2204 if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - name: Annotate docker manifest for latest tag env: - WIN2019_VERSION: ${{ needs.get-version-number.outputs.WIN2019_VERSION }} WIN2022_VERSION: ${{ needs.get-version-number.outputs.WIN2022_VERSION }} run: | - docker manifest annotate --os "windows" --os-version "$WIN2019_VERSION" --arch "amd64" "octopuslabs/k8s-workertools:latest" "octopuslabs/k8s-workertools:latest-windows.2019" && \ docker manifest annotate --os "windows" --os-version "$WIN2022_VERSION" --arch "amd64" "octopuslabs/k8s-workertools:latest" "octopuslabs/k8s-workertools:latest-windows.2022" if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} @@ -250,16 +211,14 @@ jobs: - name: Create docker manifest for version-specific tag env: VERSION_NUMBER: ${{ needs.get-version-number.outputs.VERSION }} - run: docker manifest create octopuslabs/k8s-workertools:$VERSION_NUMBER octopuslabs/k8s-workertools:$VERSION_NUMBER-windows.2019 octopuslabs/k8s-workertools:$VERSION_NUMBER-windows.2022 octopuslabs/k8s-workertools:$VERSION_NUMBER-ubuntu.2204 + run: docker manifest create octopuslabs/k8s-workertools:$VERSION_NUMBER octopuslabs/k8s-workertools:$VERSION_NUMBER-windows.2022 octopuslabs/k8s-workertools:$VERSION_NUMBER-ubuntu.2204 if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} - name: Annotate docker manifest for version-specific tag env: VERSION_NUMBER: ${{ needs.get-version-number.outputs.VERSION }} - WIN2019_VERSION: ${{ needs.get-version-number.outputs.WIN2019_VERSION }} WIN2022_VERSION: ${{ needs.get-version-number.outputs.WIN2022_VERSION }} run: | - docker manifest annotate --os "windows" --os-version "$WIN2019_VERSION" --arch "amd64" "octopuslabs/k8s-workertools:$VERSION_NUMBER" "octopuslabs/k8s-workertools:$VERSION_NUMBER-windows.2019" && \ docker manifest annotate --os "windows" --os-version "$WIN2022_VERSION" --arch "amd64" "octopuslabs/k8s-workertools:$VERSION_NUMBER" "octopuslabs/k8s-workertools:$VERSION_NUMBER-windows.2022" if: ${{ needs.get-version-number.outputs.CONTINUE == 'Yes' }} diff --git a/README.md b/README.md index d531da0..6c5c686 100644 --- a/README.md +++ b/README.md @@ -12,7 +12,6 @@ The following images are built in this repo: - Ubuntu 22.04 - Ubuntu 20.04 - Windows 2022 -- Windows 2019 A new image will be built each time a new version of `kubectl` is created. The version numbers will be based on the version of `kubectl`. diff --git a/windows-2019/Dockerfile b/windows-2019/Dockerfile deleted file mode 100644 index 175a8f6..0000000 --- a/windows-2019/Dockerfile +++ /dev/null @@ -1,53 +0,0 @@ -# escape=` - -FROM octopuslabs/workertools:latest-windows.2019 -SHELL ["powershell", "-Command"] - -# gcloud cli needed for gke auth plugin -ARG GCLOUD_CLI_VERSION=433.0.0 - -RUN choco install kubernetes-cli -y --no-progress - -RUN choco install -y kubernetes-helm --no-progress - -# Get Kubelogin -RUN choco install azure-kubelogin --no-progress -y - -RUN choco install eksctl -y --no-progress - -RUN choco install awscli -y --no-progress - -# Get Argo -RUN choco install argocd-cli -y --no-progress - -# Install Azure CLI -RUN choco install azure-cli -y --no-progress - -RUN Install-PackageProvider -Name NuGet -MinimumVersion 2.8.5.201 -Force; ` - Install-Module -Force -Name Az -AllowClobber -Scope AllUsers - -# Install gcloud (required for gke-auth-plugin) -RUN $GCLOUD_VERSION = $env:GCLOUD_CLI_VERSION; ` - Write-Host "GCLOUD_VERSION: ${env:GCLOUD_CLI_VERSION}"; ` - Write-Host "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-${env:GCLOUD_CLI_VERSION}-windows-x86_64.zip"; ` - Invoke-WebRequest "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-${env:GCLOUD_CLI_VERSION}-windows-x86_64.zip" -OutFile google-cloud-sdk-$env:GCLOUD_CLI_VERSION-windows-x86_64.zip; ` - & '.\Program Files\7-Zip\7z.exe' x .\google-cloud-sdk-$env:GCLOUD_CLI_VERSION-windows-x86_64.zip; ` - .\google-cloud-sdk\install.bat --quiet; ` - rm .\google-cloud-sdk-$env:GCLOUD_CLI_VERSION-windows-x86_64.zip - -# Update Path -RUN $old = (Get-ItemProperty -Path 'Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment' -Name path).path; ` - Write-Host $old; ` - $gcloudPath = ';C:\google-cloud-sdk\bin'; ` - $new = $old + $gcloudPath; ` - Write-Host $new; ` - Set-ItemProperty -Path 'Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment' -Name path -Value $new; ` - Import-Module $env:ChocolateyInstall\helpers\chocolateyProfile.psm1; ` - refreshenv - -# Install gke-gcloud-auth-plugin (gcloud cli doesnt make this easy) -RUN Write-Host "Installing gke-gcloud-auth-plugin"; ` - $env:CLOUDSDK_PYTHON = (& gcloud components copy-bundled-python); ` - Write-Host "GCLOUDSDK_PYTHON path: ${env:CLOUDSDK_PYTHON}"; ` - $env:GCloud_output = (gcloud components install gke-gcloud-auth-plugin --quiet 2>&1); ` - if(-not [string]::IsNullOrWhiteSpace($env:GCloud_output)) { Write-Host "${env:GCloud_output}"; }