diff --git a/Dockerfile b/Dockerfile index 60505e1..182a7e2 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,36 +1,47 @@ -# Ver: 1.8 by Endial Fang (endial@126.com) +# Ver: 1.9 by Endial Fang (endial@126.com) # +# 默认变量 ======================================================================== +# 该部分变量为系统根据编译命令默认设置 + +# `TARGETPLATFORM`:构建后的目标平台信息。如 `linux/amd64`,`linux/arm/v7`,`windows/amd64` +# `TARGETOS`:目标平台信息(TARGETPLATFORM)中的操作系统部分,如:`linux`、`windows` +# `TARGETARCH`:目标平台信息(TARGETPLATFORM)中的平台架构部分,如:`amd64`、`arm` +# `TARGETVARIANT`:目标平台信息(TARGETPLATFORM)中的版本变体部分,如:`v7` +# `BUILDPLATFORM`:用于构建的节点平台信息 +# `BUILDOS`:用于构建的节点平台信息(BUILDPLATFORM)中的操作系统部分 +# `BUILDARCH`用于构建的节点平台信息(BUILDPLATFORM)中的平台架构部分 +# `BUILDVARIANT`用于构建的节点平台信息(BUILDPLATFORM)中的版本变体部分 + # 可变参数 ======================================================================== +# 该部分变量,在编译命令中通过 `--build-arg` 传入;如果未设置,则使用下面对应的默认值 # 设置当前应用名称及版本 -ARG app_name=openjdk -ARG app_version=11.0.11 -ARG app_subver=9 +ARG APP_NAME=openjdk +ARG APP_VER=11.0.11 +ARG APP_VER_SUB=9 -# 设置默认仓库地址,默认为 阿里云 仓库 -ARG registry_url="registry.cn-shenzhen.aliyuncs.com" +# 设置默认仓库地址,默认为本地仓库;定义时需要包含末尾的`/` +ARG REGISTRY_URL="docker.colovu.com/" -# 设置 apt-get 源:default / tencent / ustc / aliyun / huawei -ARG apt_source=aliyun - -# 编译镜像时指定用于加速的本地服务器地址 -ARG local_url="" +# 设置 apt-get 源:default / ustc / aliyun +ARG APT_SOURCE=aliyun +# 编译镜像时指定用于加速的本地软件包存储服务器地址 +ARG LOCAL_URL="http://local.colovu.com/dist" # 0. 预处理 ====================================================================== -FROM ${registry_url}/colovu/dbuilder as builder +FROM --platform=${TARGETPLATFORM:-linux/amd64} ${REGISTRY_URL}colovu/dbuilder:12 as builder # 声明需要使用的全局可变参数 -ARG app_name -ARG app_version -ARG app_subver -ARG registry_url -ARG apt_source -ARG local_url +ARG APP_NAME +ARG APP_VER +ARG APP_VER_SUB +ARG APT_SOURCE +ARG LOCAL_URL # 选择软件包源(Optional),以加速后续软件包安装 -RUN select_source ${apt_source}; +RUN select_source ${APT_SOURCE}; # 安装依赖的软件包及库(Optional) #RUN install_pkg xz-utils @@ -40,55 +51,60 @@ WORKDIR /tmp # 下载并解压软件包 RUN set -eux; \ - appName=OpenJDK11U-jdk_x64_linux_${app_version}_${app_subver}.tar.gz; \ + appName=OpenJDK11U-jdk_x64_linux_${APP_VER}_${APP_VER_SUB}.tar.gz; \ appKeys="0xCA5F11C6CE22644D42C6AC4492EF8D39DC13168F 0xEAC843EBD3EFDB98CC772FADA5CD6035332FA671"; \ - [ -n ${local_url} ] && localURL=${local_url}/openjdk; \ + [ -n ${LOCAL_URL} ] && localURL=${LOCAL_URL}/openjdk; \ appUrls="${localURL:-} \ - https://github.com/AdoptOpenJDK/openjdk11-upstream-binaries/releases/download/jdk-${app_version}%2B${app_subver} \ + https://github.com/AdoptOpenJDK/openjdk11-upstream-binaries/releases/download/jdk-${APP_VER}%2B${APP_VER_SUB} \ "; \ download_pkg unpack ${appName} "${appUrls}"; # 1. 生成镜像 ===================================================================== -FROM ${registry_url}/colovu/debian:buster +FROM --platform=${TARGETPLATFORM:-linux/amd64} ${REGISTRY_URL}colovu/debian:11 -# 声明需要使用的全局可变参数 -ARG app_name -ARG app_version -ARG app_subver -ARG registry_url -ARG apt_source -ARG local_url +# 声明需要使用的全局可变参数(ARG声明的变量仅编译打包阶段有效) +ARG APP_NAME +ARG APP_VER +ARG APP_VER_SUB +ARG APT_SOURCE -# 镜像所包含应用的基础信息,定义环境变量,供后续脚本使用 -ENV APP_NAME=${app_name} \ - APP_VERSION=${app_version} - -ENV JAVA_HOME=/usr/local/${APP_NAME} \ +# 定义应用的基础信息变量(ENV声明的变量实例化后容器内有效) +ENV JAVA_HOME=/usr/local/${APP_NAME} \ JRE_HOME=/usr/local/${APP_NAME}/jre -ENV PATH="${JAVA_HOME}/bin:${JAVA_HOME}/jre/bin:${PATH}" \ - CLASSPATH=".:${JAVA_HOME}/lib:${JAVA_HOME}/jre/lib" \ +# 增加应用可执行文件及库文件搜索路径 +ENV PATH="${JAVA_HOME}/bin:${JRE_HOME}/bin:${PATH}" \ + CLASSPATH=".:${JAVA_HOME}/lib:${JRE_HOME}/lib" \ LANG=zh_CN.UTF-8 LABEL \ - "Version"="v${app_version}" \ - "Description"="Docker image for ${app_name}(v${app_version})." \ - "Dockerfile"="https://github.com/colovu/docker-${app_name}" \ + "Version"="v${APP_VER}" \ + "Description"="Docker image for ${APP_NAME}." \ + "Github"="https://github.com/colovu/docker-${APP_NAME}" \ "Vendor"="Endial Fang (endial@126.com)" # 从预处理过程中拷贝软件包(Optional),可以使用阶段编号或阶段命名定义来源 -COPY --from=builder /tmp/openjdk-${APP_VERSION}_${app_subver} ${JAVA_HOME} +COPY --from=builder /tmp/openjdk-${APP_VER}_${APP_VER_SUB} ${JAVA_HOME} -# 选择软件包源(Optional),以加速后续软件包安装 -RUN select_source ${apt_source} - -# 安装依赖的软件包及库(Optional) -RUN install_pkg p11-kit ca-certificates dmidecode - -# 更新 OpenJDK 绑定的证书 -# 8-jdk uses "${JAVA_HOME}/jre/lib/security/cacerts" and -# 8-jre and 11+ uses "${JAVA_HOME}/lib/security/cacerts" directly (no "jre" directory) RUN set -eux; \ + \ + # 创建对应的用户及数据存储目录 + \ + # 选择软件包源(Optional),以加速后续软件包安装 + select_source ${APT_SOURCE}; \ + \ + # 安装依赖的软件包及库(Optional) + install_pkg p11-kit ca-certificates dmidecode; \ + \ + # 增加中文支持,并配置 locale 为 zh_CN.UTF-8 + sed -i -e 's/# zh_CN.UTF-8 UTF-8/zh_CN.UTF-8 UTF-8/' /etc/locale.gen; \ + locale-gen; \ + update-locale LC_ALL=zh_CN.UTF-8 LANG=zh_CN.UTF-8 LANGUAGE=zh_CN.UTF-8 LC_MESSAGES=POSIX; \ + dpkg-reconfigure -f noninteractive locales; \ + \ + # 更新 OpenJDK 绑定的证书 + # 8-jdk uses "${JAVA_HOME}/jre/lib/security/cacerts" and + # 8-jre and 11+ uses "${JAVA_HOME}/lib/security/cacerts" directly (no "jre" directory) { \ echo '#!/usr/bin/env bash'; \ echo 'set -Eeuo pipefail'; \ @@ -100,22 +116,20 @@ RUN set -eux; \ chmod +x /etc/ca-certificates/update.d/docker-openjdk; \ /etc/ca-certificates/update.d/docker-openjdk; \ \ + # 更新库搜索路径 find "${JAVA_HOME}/lib" -name '*.so' -exec dirname '{}' ';' | sort -u > /etc/ld.so.conf.d/docker-openjdk.conf; \ ldconfig; \ \ -# 解决应用安装jre-headless时错误:update-alternatives: error: error creating symbolic link '/usr/share/man/man - mkdir -p /usr/share/man/man1; - -# 执行预处理脚本,并验证安装的软件包 -RUN set -eux; \ - override_file="/usr/local/overrides/overrides-${APP_VERSION}.sh"; \ + # 解决应用安装jre-headless时错误:update-alternatives: error: error creating symbolic link '/usr/share/man/man + mkdir -p /usr/share/man/man1; \ + \ + # 执行后处理脚本,并验证安装的应用 + override_file="/usr/local/overrides/overrides-${APP_VER}.sh"; \ [ -e "${override_file}" ] && /bin/bash "${override_file}"; \ java --version; \ javac --version; -# 设置工作目录 -WORKDIR /srv - -# 应用程序的启动命令,必须使用非守护进程方式运行 +# 应用程序的启动命令,可为应用程序可执行命令或脚本 +# 必须使用非守护进程方式运行 CMD []