Skip to content

Commit

Permalink
Merge pull request #313 from keeganwitt/noble
Browse files Browse the repository at this point in the history
Add Noble images (closes #312)
  • Loading branch information
keeganwitt authored Feb 6, 2025
2 parents 92b6722 + ed84a0b commit 845d53d
Show file tree
Hide file tree
Showing 18 changed files with 431 additions and 52 deletions.
42 changes: 20 additions & 22 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,54 +18,54 @@ jobs:
strategy:
matrix:
versions:
- directory: jdk11
- directory: jdk11-jammy
ltsJavaVersion: 11
- directory: jdk11-focal
ltsJavaVersion: 11
- directory: jdk11-alpine
ltsJavaVersion: 11
variant: alpine
- directory: jdk11-corretto
ltsJavaVersion: 11
variant: corretto
- directory: jdk11-focal
ltsJavaVersion: 11
variant: focal
- directory: jdk17
- directory: jdk17-noble
ltsJavaVersion: 17
- directory: jdk17-jammy
ltsJavaVersion: 17
- directory: jdk17-alpine
ltsJavaVersion: 17
variant: alpine
- directory: jdk17-corretto
ltsJavaVersion: 17
variant: corretto
- directory: jdk17-focal
ltsJavaVersion: 17
variant: focal
- directory: jdk17-graal
- directory: jdk17-noble-graal
ltsJavaVersion: 17
variant: graal
- directory: jdk17-jammy-graal
ltsJavaVersion: 17
variant: graal
- directory: jdk17-focal-graal
ltsJavaVersion: 17
variant: focal-graal
- directory: jdk21
variant: graal
- directory: jdk21-noble
ltsJavaVersion: 21
- directory: jdk21-jammy
ltsJavaVersion: 21
- directory: jdk21-alpine
ltsJavaVersion: 21
variant: alpine
- directory: jdk21-corretto
ltsJavaVersion: 21
variant: corretto
- directory: jdk21-graal
- directory: jdk21-noble-graal
ltsJavaVersion: 21
variant: graal
- directory: jdk21-jammy-graal
ltsJavaVersion: 21
variant: graal
- directory: jdk23
- directory: jdk23-noble
ltsJavaVersion: 23
- directory: jdk23-alpine
ltsJavaVersion: 23
variant: alpine
- directory: jdk23-corretto
ltsJavaVersion: 23
variant: corretto
- directory: jdk23-graal
- directory: jdk23-noble-graal
ltsJavaVersion: 23
variant: graal
- directory: jdk-lts-and-current
Expand All @@ -74,11 +74,9 @@ jobs:
- directory: jdk-lts-and-current-alpine
ltsJavaVersion: 21
currentJavaVersion: 23
variant: alpine
- directory: jdk-lts-and-current-corretto
ltsJavaVersion: 21
currentJavaVersion: 23
variant: corretto
- directory: jdk-lts-and-current-graal
ltsJavaVersion: 21
currentJavaVersion: 23
Expand Down
12 changes: 8 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,24 @@

## Supported tags and respective Dockerfile links

* [jdk8, jdk8-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk8/Dockerfile)
* [jdk8, jdk8-noble](https://github.com/keeganwitt/docker-gradle/blob/master/jdk8-noble/Dockerfile)
* [jdk8-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk8-jammy/Dockerfile)
* [jdk8-focal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk8-focal/Dockerfile)
* [jdk8-corretto](https://github.com/keeganwitt/docker-gradle/blob/master/jdk8-corretto/Dockerfile)
* [jdk11, jdk11-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11/Dockerfile)
* [jdk11, jdk11-noble](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11-noble/Dockerfile)
* [jdk11-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11-jammy/Dockerfile)
* [jdk11-focal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11-focal/Dockerfile)
* [jdk11-alpine](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11-alpine/Dockerfile)
* [jdk11, jdk11-corretto](https://github.com/keeganwitt/docker-gradle/blob/master/jdk11-corretto/Dockerfile)
* [jdk17, jdk17-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17/Dockerfile)
* [jdk17, jdk17-noble](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-noble/Dockerfile)
* [jdk17-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-jammy/Dockerfile)
* [jdk17-focal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-focal/Dockerfile)
* [jdk17-alpine](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-alpine/Dockerfile)
* [jdk17-corretto](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-corretto/Dockerfile)
* [jdk17-graal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-graal/Dockerfile)
* [jdk17-focal-graal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk17-focal-graal/Dockerfile)
* [jdk21, jdk21-jammy, latest](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21/Dockerfile)
* [jdk21, jdk21-noble, latest](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21-noble/Dockerfile)
* [jdk21-jammy](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21-jammy/Dockerfile)
* [jdk21-alpine, alpine](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21-alpine/Dockerfile)
* [jdk21-corretto, corretto](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21-corretto/Dockerfile)
* [jdk21-graal, graal](https://github.com/keeganwitt/docker-gradle/blob/master/jdk21-graal/Dockerfile)
Expand Down
12 changes: 8 additions & 4 deletions jdk-lts-and-current-graal/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,14 +1,18 @@
FROM ubuntu:jammy
FROM ubuntu:noble

CMD ["gradle"]

ENV GRADLE_HOME=/opt/gradle

RUN set -o errexit -o nounset \
&& echo "Adding gradle user and group" \
&& groupadd --system --gid 1000 gradle \
&& useradd --system --gid gradle --uid 1000 --shell /bin/bash --create-home gradle \
&& echo "Renaming ubuntu user and group to gradle" \
&& groupmod --new-name gradle ubuntu \
&& mkdir /home/gradle \
&& usermod --login gradle --home /home/gradle --groups gradle ubuntu \
&& chown gradle /home/gradle \
&& mkdir /home/gradle/.gradle \
&& chown --recursive gradle:gradle /home/gradle \
&& chmod --recursive o+rwx /home/gradle \
\
&& echo "Symlinking root Gradle cache to gradle Gradle cache" \
&& ln --symbolic /home/gradle/.gradle /root/.gradle \
Expand Down
11 changes: 7 additions & 4 deletions jdk-lts-and-current/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM eclipse-temurin:21-jdk-jammy
FROM eclipse-temurin:21-jdk-noble

COPY --from=eclipse-temurin:23-jdk-noble /opt/java/openjdk /opt/java/openjdk23
RUN set -o errexit -o nounset \
Expand All @@ -11,11 +11,14 @@ CMD ["gradle"]
ENV GRADLE_HOME=/opt/gradle

RUN set -o errexit -o nounset \
&& echo "Adding gradle user and group" \
&& groupadd --system --gid 1000 gradle \
&& useradd --system --gid gradle --uid 1000 --shell /bin/bash --create-home gradle \
&& echo "Renaming ubuntu user and group to gradle" \
&& groupmod --new-name gradle ubuntu \
&& mkdir /home/gradle \
&& usermod --login gradle --home /home/gradle --groups gradle ubuntu \
&& chown gradle /home/gradle \
&& mkdir /home/gradle/.gradle \
&& chown --recursive gradle:gradle /home/gradle \
&& chmod --recursive o+rwx /home/gradle \
\
&& echo "Symlinking root Gradle cache to gradle Gradle cache" \
&& ln --symbolic /home/gradle/.gradle /root/.gradle \
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
114 changes: 114 additions & 0 deletions jdk17-noble-graal/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
FROM ubuntu:noble

CMD ["gradle"]

ENV GRADLE_HOME=/opt/gradle

RUN set -o errexit -o nounset \
&& echo "Renaming ubuntu user and group to gradle" \
&& groupmod --new-name gradle ubuntu \
&& mkdir /home/gradle \
&& usermod --login gradle --home /home/gradle --groups gradle ubuntu \
&& chown gradle /home/gradle \
&& mkdir /home/gradle/.gradle \
&& chown --recursive gradle:gradle /home/gradle \
&& chmod --recursive o+rwx /home/gradle \
\
&& echo "Symlinking root Gradle cache to gradle Gradle cache" \
&& ln --symbolic /home/gradle/.gradle /root/.gradle

VOLUME /home/gradle/.gradle

WORKDIR /home/gradle

RUN set -o errexit -o nounset \
&& export DEBIAN_FRONTEND=noninteractive \
&& apt-get update \
&& apt-get install --yes --no-install-recommends \
binutils \
ca-certificates \
curl \
fontconfig \
locales \
p11-kit \
tzdata \
unzip \
wget \
\
gcc \
libc-dev \
libz-dev \
zlib1g-dev \
\
bzr \
git \
git-lfs \
mercurial \
openssh-client \
subversion \
&& rm --recursive --force /var/lib/apt/lists/* \
\
&& echo "Testing VCSes" \
&& which bzr \
&& which git \
&& which git-lfs \
&& which hg \
&& which svn

ENV JAVA_HOME=/opt/java/graalvm
ENV JAVA_VERSION=17.0.9
RUN set -o errexit -o nounset \
&& mkdir /opt/java \
\
&& echo "Downloading GraalVM" \
&& GRAALVM_AMD64_DOWNLOAD_SHA256=e47ba7229cef02393e19d5b8f46f7f1cab4829dd17bfe84d5431fc8ff0e22a96 \
&& GRAALVM_AARCH64_DOWNLOAD_SHA256=c3281b21f5220c2f76cf6fa0d646bc42e2d729af2c022bb06e557a613ba16102 \
&& ARCHITECTURE=$(dpkg --print-architecture) \
&& if [ "${ARCHITECTURE}" = "amd64" ]; then GRAALVM_ARCHITECTURE=linux-x64; fi \
&& if [ "${ARCHITECTURE}" = "arm64" ]; then GRAALVM_ARCHITECTURE=linux-aarch64; fi \
&& GRAALVM_PKG=https://github.com/graalvm/graalvm-ce-builds/releases/download/jdk-${JAVA_VERSION}/graalvm-community-jdk-${JAVA_VERSION}_${GRAALVM_ARCHITECTURE}_bin.tar.gz \
&& wget --no-verbose --output-document=graalvm.tar.gz "${GRAALVM_PKG}" \
\
&& echo "Checking GraalVM download hash" \
&& if [ "${ARCHITECTURE}" = "amd64" ]; then GRAALVM_DOWNLOAD_SHA256="${GRAALVM_AMD64_DOWNLOAD_SHA256}"; fi \
&& if [ "${ARCHITECTURE}" = "arm64" ]; then GRAALVM_DOWNLOAD_SHA256="${GRAALVM_AARCH64_DOWNLOAD_SHA256}"; fi \
&& echo "${GRAALVM_DOWNLOAD_SHA256} *graalvm.tar.gz" | sha256sum --check - \
\
&& echo "Installing GraalVM" \
&& tar --extract --gunzip --file graalvm.tar.gz \
&& rm graalvm.tar.gz \
&& mv graalvm-* "${JAVA_HOME}" \
&& for bin in "$JAVA_HOME/bin/"*; do \
base="$(basename "$bin")"; \
[ ! -e "/usr/bin/$base" ]; \
update-alternatives --install "/usr/bin/${base}" "${base}" "${bin}" 1; \
done \
\
&& echo "Testing GraalVM installation" \
&& java --version \
&& javac --version \
&& gu --version \
&& native-image --version

ENV GRADLE_VERSION=8.12.1
ARG GRADLE_DOWNLOAD_SHA256=8d97a97984f6cbd2b85fe4c60a743440a347544bf18818048e611f5288d46c94
RUN set -o errexit -o nounset \
&& echo "Downloading Gradle" \
&& wget --no-verbose --output-document=gradle.zip "https://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin.zip" \
\
&& echo "Checking Gradle download hash" \
&& echo "${GRADLE_DOWNLOAD_SHA256} *gradle.zip" | sha256sum --check - \
\
&& echo "Installing Gradle" \
&& unzip gradle.zip \
&& rm gradle.zip \
&& mv "gradle-${GRADLE_VERSION}" "${GRADLE_HOME}/" \
&& ln --symbolic "${GRADLE_HOME}/bin/gradle" /usr/bin/gradle

USER gradle

RUN set -o errexit -o nounset \
&& echo "Testing Gradle installation" \
&& gradle --version

USER root
66 changes: 66 additions & 0 deletions jdk17-noble/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
FROM eclipse-temurin:17-jdk-noble

CMD ["gradle"]

ENV GRADLE_HOME=/opt/gradle

RUN set -o errexit -o nounset \
&& echo "Renaming ubuntu user and group to gradle" \
&& groupmod --new-name gradle ubuntu \
&& mkdir /home/gradle \
&& usermod --login gradle --home /home/gradle --groups gradle ubuntu \
&& chown gradle /home/gradle \
&& mkdir /home/gradle/.gradle \
&& chown --recursive gradle:gradle /home/gradle \
&& chmod --recursive o+rwx /home/gradle \
\
&& echo "Symlinking root Gradle cache to gradle Gradle cache" \
&& ln --symbolic /home/gradle/.gradle /root/.gradle

VOLUME /home/gradle/.gradle

WORKDIR /home/gradle

RUN set -o errexit -o nounset \
&& apt-get update \
&& apt-get install --yes --no-install-recommends \
unzip \
wget \
\
bzr \
git \
git-lfs \
mercurial \
openssh-client \
subversion \
&& rm --recursive --force /var/lib/apt/lists/* \
\
&& echo "Testing VCSes" \
&& which bzr \
&& which git \
&& which git-lfs \
&& which hg \
&& which svn

ENV GRADLE_VERSION=8.12.1
ARG GRADLE_DOWNLOAD_SHA256=8d97a97984f6cbd2b85fe4c60a743440a347544bf18818048e611f5288d46c94
RUN set -o errexit -o nounset \
&& echo "Downloading Gradle" \
&& wget --no-verbose --output-document=gradle.zip "https://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin.zip" \
\
&& echo "Checking Gradle download hash" \
&& echo "${GRADLE_DOWNLOAD_SHA256} *gradle.zip" | sha256sum --check - \
\
&& echo "Installing Gradle" \
&& unzip gradle.zip \
&& rm gradle.zip \
&& mv "gradle-${GRADLE_VERSION}" "${GRADLE_HOME}/" \
&& ln --symbolic "${GRADLE_HOME}/bin/gradle" /usr/bin/gradle

USER gradle

RUN set -o errexit -o nounset \
&& echo "Testing Gradle installation" \
&& gradle --version

USER root
File renamed without changes.
File renamed without changes.
Loading

0 comments on commit 845d53d

Please sign in to comment.