diff --git a/4.8/windows/nanoserver/Dockerfile b/4.8/windows/nanoserver/Dockerfile new file mode 100644 index 0000000000..d3ab115371 --- /dev/null +++ b/4.8/windows/nanoserver/Dockerfile @@ -0,0 +1,18 @@ +FROM microsoft/nanoserver + +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ENV NPM_CONFIG_LOGLEVEL info +ENV NODE_VERSION 4.8.1 +ENV NODE_SHA256 edb47c31de7891ddb58d5e1024e31c91b49b4f2226cf6c3e0c41e715ee6111e4 + +RUN Invoke-WebRequest $('https://nodejs.org/dist/v{0}/node-v{0}-win-x64.zip' -f $env:NODE_VERSION) -OutFile 'node.zip' -UseBasicParsing ; \ + if ((Get-FileHash node.zip -Algorithm sha256).Hash -ne $env:NODE_SHA256) {exit 1} ; \ + Expand-Archive node.zip -DestinationPath C:\ ; \ + Rename-Item -Path $('C:\node-v{0}-win-x64' -f $env:NODE_VERSION) -NewName 'C:\nodejs' ; \ + New-Item $($env:APPDATA + '\npm') ; \ + $env:PATH = 'C:\nodejs;{0}\npm;{1}' -f $env:APPDATA, $env:PATH ; \ + Set-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\' -Name Path -Value $env:PATH ; \ + Remove-Item -Path node.zip + +CMD [ "node.exe" ] diff --git a/4.8/windows/nanoserver/onbuild/Dockerfile b/4.8/windows/nanoserver/onbuild/Dockerfile new file mode 100644 index 0000000000..22e9b17094 --- /dev/null +++ b/4.8/windows/nanoserver/onbuild/Dockerfile @@ -0,0 +1,10 @@ +FROM node:4.8.1-nanoserver + +RUN mkdir \app +WORKDIR /app + +ONBUILD COPY package.json package.json +ONBUILD RUN npm install ; Remove-Item $($env:APPDATA + '\npm-cache') -Force -Recurse ; Remove-Item $($env:TEMP + '\npm-*') -Force -Recurse +ONBUILD COPY . . + +CMD [ "npm.cmd", "start" ] diff --git a/6.10/windows/nanoserver/Dockerfile b/6.10/windows/nanoserver/Dockerfile new file mode 100644 index 0000000000..21a5418e49 --- /dev/null +++ b/6.10/windows/nanoserver/Dockerfile @@ -0,0 +1,18 @@ +FROM microsoft/nanoserver + +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ENV NPM_CONFIG_LOGLEVEL info +ENV NODE_VERSION 6.10.1 +ENV NODE_SHA256 28923f51691bb34dc399af4ceb567da487d7f4806aec5e6f0cfab1e6c3f2dd1c + +RUN Invoke-WebRequest $('https://nodejs.org/dist/v{0}/node-v{0}-win-x64.zip' -f $env:NODE_VERSION) -OutFile 'node.zip' -UseBasicParsing ; \ + if ((Get-FileHash node.zip -Algorithm sha256).Hash -ne $env:NODE_SHA256) {exit 1} ; \ + Expand-Archive node.zip -DestinationPath C:\ ; \ + Rename-Item -Path $('C:\node-v{0}-win-x64' -f $env:NODE_VERSION) -NewName 'C:\nodejs' ; \ + New-Item $($env:APPDATA + '\npm') ; \ + $env:PATH = 'C:\nodejs;{0}\npm;{1}' -f $env:APPDATA, $env:PATH ; \ + Set-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\' -Name Path -Value $env:PATH ; \ + Remove-Item -Path node.zip + +CMD [ "node.exe" ] diff --git a/6.10/windows/nanoserver/onbuild/Dockerfile b/6.10/windows/nanoserver/onbuild/Dockerfile new file mode 100644 index 0000000000..21dd60d356 --- /dev/null +++ b/6.10/windows/nanoserver/onbuild/Dockerfile @@ -0,0 +1,10 @@ +FROM node:6.10.1-nanoserver + +RUN mkdir \app +WORKDIR /app + +ONBUILD COPY package.json package.json +ONBUILD RUN npm install ; Remove-Item $($env:APPDATA + '\npm-cache') -Force -Recurse ; Remove-Item $($env:TEMP + '\npm-*') -Force -Recurse +ONBUILD COPY . . + +CMD [ "npm.cmd", "start" ] diff --git a/7.7/windows/nanoserver/Dockerfile b/7.7/windows/nanoserver/Dockerfile new file mode 100644 index 0000000000..ad650967db --- /dev/null +++ b/7.7/windows/nanoserver/Dockerfile @@ -0,0 +1,18 @@ +FROM microsoft/nanoserver + +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ENV NPM_CONFIG_LOGLEVEL info +ENV NODE_VERSION 7.7.4 +ENV NODE_SHA256 dd573367cda68db3594544b973be2367c0df8fc5345402672079e6be873931cd + +RUN Invoke-WebRequest $('https://nodejs.org/dist/v{0}/node-v{0}-win-x64.zip' -f $env:NODE_VERSION) -OutFile 'node.zip' -UseBasicParsing ; \ + if ((Get-FileHash node.zip -Algorithm sha256).Hash -ne $env:NODE_SHA256) {exit 1} ; \ + Expand-Archive node.zip -DestinationPath C:\ ; \ + Rename-Item -Path $('C:\node-v{0}-win-x64' -f $env:NODE_VERSION) -NewName 'C:\nodejs' ; \ + New-Item $($env:APPDATA + '\npm') ; \ + $env:PATH = 'C:\nodejs;{0}\npm;{1}' -f $env:APPDATA, $env:PATH ; \ + Set-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\' -Name Path -Value $env:PATH ; \ + Remove-Item -Path node.zip + +CMD [ "node.exe" ] diff --git a/7.7/windows/nanoserver/onbuild/Dockerfile b/7.7/windows/nanoserver/onbuild/Dockerfile new file mode 100644 index 0000000000..dd1aa9ac43 --- /dev/null +++ b/7.7/windows/nanoserver/onbuild/Dockerfile @@ -0,0 +1,10 @@ +FROM node:7.7.4-nanoserver + +RUN mkdir \app +WORKDIR /app + +ONBUILD COPY package.json package.json +ONBUILD RUN npm install ; Remove-Item $($env:APPDATA + '\npm-cache') -Force -Recurse ; Remove-Item $($env:TEMP + '\npm-*') -Force -Recurse +ONBUILD COPY . . + +CMD [ "npm.cmd", "start" ] diff --git a/test-build.ps1 b/test-build.ps1 new file mode 100755 index 0000000000..ad44b66349 --- /dev/null +++ b/test-build.ps1 @@ -0,0 +1,8 @@ +docker build --isolation=hyperv -t node:4.8.1-nanoserver 4.8/windows/nanoserver +docker build --isolation=hyperv -t node:4.8.1-nanoserver-onbuild 4.8/windows/nanoserver/onbuild + +docker build --isolation=hyperv -t node:6.10.1-nanoserver 6.10/windows/nanoserver +docker build --isolation=hyperv -t node:6.10.1-nanoserver-onbuild 6.10/windows/nanoserver/onbuild + +docker build --isolation=hyperv -t node:7.7.4-nanoserver 7.7/windows/nanoserver +docker build --isolation=hyperv -t node:7.7.4-nanoserver-onbuild 7.7/windows/nanoserver/onbuild