From 0019a97457d59c7368b94a79b5288e65c1a058b3 Mon Sep 17 00:00:00 2001 From: Damien Duportal Date: Thu, 7 Oct 2021 16:56:22 +0200 Subject: [PATCH] feat [windows] introduces 2 new JDK17 windows images using Adoptium Signed-off-by: Damien Duportal --- 17/windows/nanoserver-1809/Dockerfile | 98 +++++++++++++++++++ .../windowsservercore-ltsc2019/Dockerfile | 92 +++++++++++++++++ 2 files changed, 190 insertions(+) create mode 100644 17/windows/nanoserver-1809/Dockerfile create mode 100644 17/windows/windowsservercore-ltsc2019/Dockerfile diff --git a/17/windows/nanoserver-1809/Dockerfile b/17/windows/nanoserver-1809/Dockerfile new file mode 100644 index 000000000..5a0eb4ff2 --- /dev/null +++ b/17/windows/nanoserver-1809/Dockerfile @@ -0,0 +1,98 @@ +# escape=` + +# The MIT License +# +# Copyright (c) 2020, Alex Earl and other Jenkins Contributors +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +# THE SOFTWARE. + +FROM mcr.microsoft.com/windows/servercore:1809 AS core + +FROM eclipse-temurin:17_35-jdk-nanoserver-1809 + +# The nanoserver image is nice and small, but we need a couple of things to get SSH working +COPY --from=core /windows/system32/netapi32.dll /windows/system32/netapi32.dll +COPY --from=core /windows/system32/whoami.exe /windows/system32/whoami.exe + +SHELL ["pwsh.exe", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ARG VERSION=4.10 +LABEL Description="This is a base image, which provides the Jenkins agent executable (agent.jar)" Vendor="Jenkins project" Version="${VERSION}" + +ARG GIT_VERSION=2.33.0 +ARG GIT_PATCH_VERSION=2 +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + $url = $('https://github.com/git-for-windows/git/releases/download/v{0}.windows.{1}/MinGit-{0}.{1}-64-bit.zip' -f $env:GIT_VERSION, $env:GIT_PATCH_VERSION) ; ` + Write-Host "Retrieving $url..." ; ` + Invoke-WebRequest $url -OutFile 'mingit.zip' -UseBasicParsing ; ` + Expand-Archive mingit.zip -DestinationPath c:\mingit ; ` + Remove-Item mingit.zip -Force + +ARG GIT_LFS_VERSION=2.13.3 +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + $url = $('https://github.com/git-lfs/git-lfs/releases/download/v{0}/git-lfs-windows-amd64-v{0}.zip' -f $env:GIT_LFS_VERSION) ; ` + Write-Host "Retrieving $url..." ; ` + Invoke-WebRequest $url -OutFile 'GitLfs.zip' -UseBasicParsing ; ` + Expand-Archive GitLfs.zip -DestinationPath c:\mingit\mingw64\bin ; ` + Remove-Item GitLfs.zip -Force ; ` + & C:\mingit\cmd\git.exe lfs install ; ` + $CurrentPath = (Get-Itemproperty -path 'hklm:\system\currentcontrolset\control\session manager\environment' -Name Path).Path ; ` + $NewPath = $CurrentPath + ';C:\mingit\cmd' ; ` + Set-ItemProperty -path 'hklm:\system\currentcontrolset\control\session manager\environment' -Name Path -Value $NewPath + +ARG user=jenkins + +ARG AGENT_FILENAME=agent.jar +ARG AGENT_HASH_FILENAME=$AGENT_FILENAME.sha1 + +RUN net accounts /maxpwage:unlimited ; ` + net user "$env:user" /add /expire:never /passwordreq:no ; ` + net localgroup Administrators /add $env:user ; ` + Set-LocalUser -Name $env:user -PasswordNeverExpires 1; ` + New-Item -ItemType Directory -Path C:/ProgramData/Jenkins | Out-Null + +ARG AGENT_ROOT=C:/Users/$user +ARG AGENT_WORKDIR=${AGENT_ROOT}/Work + +ENV AGENT_WORKDIR=${AGENT_WORKDIR} + +# Get the Agent from the Jenkins Artifacts Repository +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + Invoke-WebRequest $('https://repo.jenkins-ci.org/public/org/jenkins-ci/main/remoting/{0}/remoting-{0}.jar' -f $env:VERSION) -OutFile $(Join-Path C:/ProgramData/Jenkins $env:AGENT_FILENAME) -UseBasicParsing ; ` + Invoke-WebRequest $('https://repo.jenkins-ci.org/public/org/jenkins-ci/main/remoting/{0}/remoting-{0}.jar.sha1' -f $env:VERSION) -OutFile (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME) -UseBasicParsing ; ` + if ((Get-FileHash (Join-Path C:/ProgramData/Jenkins $env:AGENT_FILENAME) -Algorithm SHA1).Hash -ne (Get-Content (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME))) {exit 1} ; ` + Remove-Item -Force (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME) + +USER $user + +RUN New-Item -Type Directory $('{0}/.jenkins' -f $env:AGENT_ROOT) | Out-Null ; ` + New-Item -Type Directory $env:AGENT_WORKDIR | Out-Null + +VOLUME ${AGENT_ROOT}/.jenkins +VOLUME ${AGENT_WORKDIR} +WORKDIR ${AGENT_ROOT} + +LABEL ` + org.opencontainers.image.vendor="Jenkins project" ` + org.opencontainers.image.title="Official Jenkins Agent Base Docker image" ` + org.opencontainers.image.description="This is a base image, which provides the Jenkins agent executable (agent.jar)" ` + org.opencontainers.image.version="${VERSION}" ` + org.opencontainers.image.url="https://www.jenkins.io/" ` + org.opencontainers.image.source="https://github.com/jenkinsci/docker-agent" ` + org.opencontainers.image.licenses="MIT" diff --git a/17/windows/windowsservercore-ltsc2019/Dockerfile b/17/windows/windowsservercore-ltsc2019/Dockerfile new file mode 100644 index 000000000..7f6836908 --- /dev/null +++ b/17/windows/windowsservercore-ltsc2019/Dockerfile @@ -0,0 +1,92 @@ +# escape=` + +# The MIT License +# +# Copyright (c) 2020, Alex Earl and other Jenkins Contributors +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +# THE SOFTWARE. + +FROM eclipse-temurin:17_35-jdk-windowsservercore-1809 + +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ARG VERSION=4.10 +LABEL Description="This is a base image, which provides the Jenkins agent executable (agent.jar)" Vendor="Jenkins project" Version="${VERSION}" + +ARG GIT_VERSION=2.33.0 +ARG GIT_PATCH_VERSION=2 +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + $url = $('https://github.com/git-for-windows/git/releases/download/v{0}.windows.{1}/MinGit-{0}.{1}-64-bit.zip' -f $env:GIT_VERSION, $env:GIT_PATCH_VERSION) ; ` + Write-Host "Retrieving $url..." ; ` + Invoke-WebRequest $url -OutFile 'mingit.zip' -UseBasicParsing ; ` + Expand-Archive mingit.zip -DestinationPath c:\mingit ; ` + Remove-Item mingit.zip -Force + +ARG GIT_LFS_VERSION=2.13.3 +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + $url = $('https://github.com/git-lfs/git-lfs/releases/download/v{0}/git-lfs-windows-amd64-v{0}.zip' -f $env:GIT_LFS_VERSION) ; ` + Write-Host "Retrieving $url..." ; ` + Invoke-WebRequest $url -OutFile 'GitLfs.zip' -UseBasicParsing ; ` + Expand-Archive GitLfs.zip -DestinationPath c:\mingit\mingw64\bin ; ` + Remove-Item GitLfs.zip -Force ; ` + & C:\mingit\cmd\git.exe lfs install ; ` + $CurrentPath = (Get-Itemproperty -path 'hklm:\system\currentcontrolset\control\session manager\environment' -Name Path).Path ; ` + $NewPath = $CurrentPath + ';C:\mingit\cmd' ; ` + Set-ItemProperty -path 'hklm:\system\currentcontrolset\control\session manager\environment' -Name Path -Value $NewPath + +ARG user=jenkins + +ARG AGENT_FILENAME=agent.jar +ARG AGENT_HASH_FILENAME=$AGENT_FILENAME.sha1 + +RUN net accounts /maxpwage:unlimited ; ` + net user "$env:user" /add /expire:never /passwordreq:no ; ` + net localgroup Administrators /add $env:user ; ` + Set-LocalUser -Name $env:user -PasswordNeverExpires 1; ` + New-Item -ItemType Directory -Path C:/ProgramData/Jenkins | Out-Null + +ARG AGENT_ROOT=C:/Users/$user +ARG AGENT_WORKDIR=${AGENT_ROOT}/Work + +ENV AGENT_WORKDIR=${AGENT_WORKDIR} + +# Get the Agent from the Jenkins Artifacts Repository +RUN [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 ; ` + Invoke-WebRequest $('https://repo.jenkins-ci.org/public/org/jenkins-ci/main/remoting/{0}/remoting-{0}.jar' -f $env:VERSION) -OutFile $(Join-Path C:/ProgramData/Jenkins $env:AGENT_FILENAME) -UseBasicParsing ; ` + Invoke-WebRequest $('https://repo.jenkins-ci.org/public/org/jenkins-ci/main/remoting/{0}/remoting-{0}.jar.sha1' -f $env:VERSION) -OutFile (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME) -UseBasicParsing ; ` + if ((Get-FileHash (Join-Path C:/ProgramData/Jenkins $env:AGENT_FILENAME) -Algorithm SHA1).Hash -ne (Get-Content (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME))) {exit 1} ; ` + Remove-Item -Force (Join-Path C:/ProgramData/Jenkins $env:AGENT_HASH_FILENAME) + +USER $user + +RUN New-Item -Type Directory $('{0}/.jenkins' -f $env:AGENT_ROOT) | Out-Null ; ` + New-Item -Type Directory $env:AGENT_WORKDIR | Out-Null + +VOLUME ${AGENT_ROOT}/.jenkins +VOLUME ${AGENT_WORKDIR} +WORKDIR ${AGENT_ROOT} + +LABEL ` + org.opencontainers.image.vendor="Jenkins project" ` + org.opencontainers.image.title="Official Jenkins Agent Base Docker image" ` + org.opencontainers.image.description="This is a base image, which provides the Jenkins agent executable (agent.jar)" ` + org.opencontainers.image.version="${VERSION}" ` + org.opencontainers.image.url="https://www.jenkins.io/" ` + org.opencontainers.image.source="https://github.com/jenkinsci/docker-agent" ` + org.opencontainers.image.licenses="MIT"