Compare commits
No commits in common. "4a53ed21cb14b26ea3dd70c9df852406d8089106" and "6830263bae0c5ff09b57b74930327d2f7a4fe2b7" have entirely different histories.
4a53ed21cb
...
6830263bae
3
.jenkins/.env.yml
Normal file
3
.jenkins/.env.yml
Normal file
@ -0,0 +1,3 @@
|
||||
masterProfiles: ['','uat','prod']
|
||||
Profiles: ['','dev']
|
||||
jobConfigFile: "imagesConfig.yml"
|
||||
3
.jenkins/Jenkinsfile
vendored
Normal file
3
.jenkins/Jenkinsfile
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
@Library('share-library@master')_
|
||||
orgName = 'xiaomayi'
|
||||
pipelineDockerService(orgName)
|
||||
2
LICENSE
2
LICENSE
@ -58,7 +58,7 @@ APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following boilerplate notice, with the fields enclosed by brackets "[]" replaced with your own identifying information. (Don't include the brackets!) The text should be enclosed in the appropriate comment syntax for the file format. We also recommend that a file or class name and description of purpose be included on the same "printed page" as the copyright notice for easier identification within third-party archives.
|
||||
|
||||
Copyright 2026 devops
|
||||
Copyright 2025 cicd
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
|
||||
@ -1,3 +1,9 @@
|
||||
# jenkins-docker-images
|
||||
|
||||
Jenkins 自定义 Docker 镜像仓库。用于存放 Jenkins 构建环境所需的 Dockerfile 及相关配置文件,涵盖不同语言(Java、Node.js、Python、Go 等)和工具链(Maven、Gradle、npm、pip 等)的基础镜像,支持 Agent 按需运行与 CI/CD 环境一致性。
|
||||
基于 Jenkins 构建企业级基础镜像自动化构建平台,实现从 Dockerfile 管理到镜像推送的全流程自动化,建立标准化的基础环境供应体系。通过集中式 Dockerfile 仓库管理和版本控制,确保基础环境一致性,提升软件交付效率与质量。
|
||||
|
||||
删除镜像:
|
||||
|
||||
```
|
||||
docker images | grep none | awk '{print $3}' | xargs docker rmi
|
||||
```
|
||||
101
dockerfiles/golang/1.25.1-centos8-dos/Dockerfile
Normal file
101
dockerfiles/golang/1.25.1-centos8-dos/Dockerfile
Normal file
@ -0,0 +1,101 @@
|
||||
# 使用CentOS 8作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于RockyLinux 8的Go语言运行环境" \
|
||||
golang.version="1.25.1"
|
||||
|
||||
# 设置环境变量
|
||||
ENV GO_VERSION=1.25.1 \
|
||||
GOPATH=/go \
|
||||
GOROOT=/usr/local/go \
|
||||
PATH=/usr/local/go/bin:/go/bin:${PATH} \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 安装必要的系统依赖和配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装基础工具(包括shadow-utils用于用户管理)
|
||||
microdnf update -y && \
|
||||
microdnf install -y \
|
||||
curl \
|
||||
tar \
|
||||
gzip \
|
||||
git \
|
||||
make \
|
||||
gcc \
|
||||
glibc-devel \
|
||||
glibc-langpack-en \
|
||||
shadow-utils \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
microdnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
echo 'LANG="en_US.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="en_US.UTF-8"' >> /etc/locale.conf;
|
||||
|
||||
# 添加Go安装包(确保go1.25.1.linux-amd64.tar.gz在构建上下文)
|
||||
ADD go1.25.1.linux-amd64.tar.gz /usr/local/
|
||||
|
||||
# 创建Go工作目录和配置locale
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建Go工作目录
|
||||
mkdir -p /go/src /go/bin /go/pkg && \
|
||||
chmod -R 755 /go; \
|
||||
\
|
||||
# 检查系统locale设置
|
||||
echo "=== Locale Settings ==="; \
|
||||
cat /etc/locale.conf || echo "No locale.conf"; \
|
||||
echo "=== Environment Locale ==="; \
|
||||
echo "LANG=$LANG"; \
|
||||
\
|
||||
# 检查Go版本
|
||||
echo "=== Go Version ==="; \
|
||||
go version && \
|
||||
\
|
||||
# 检查环境变量
|
||||
echo "=== Go Environment ==="; \
|
||||
go env && \
|
||||
\
|
||||
# 简单的Go程序编译测试
|
||||
echo 'package main; import "fmt"; func main() { fmt.Println("Go环境安装成功!") }' > /tmp/test.go && \
|
||||
go run /tmp/test.go && \
|
||||
rm -f /tmp/test.go;
|
||||
|
||||
# 设置工作目录(Go项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Go应用(安全性考虑)
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi /go;
|
||||
|
||||
# 设置默认用户(注释掉以便调试)
|
||||
# USER esxi
|
||||
|
||||
# 设置健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD go version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["go", "version"]
|
||||
124
dockerfiles/golang/1.25.1-centos8-dos/Dockerfile2
Normal file
124
dockerfiles/golang/1.25.1-centos8-dos/Dockerfile2
Normal file
@ -0,0 +1,124 @@
|
||||
# 使用CentOS 8作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于CentOS 8的Go语言运行环境" \
|
||||
golang.version="1.25.1"
|
||||
|
||||
# 设置环境变量
|
||||
ENV GO_VERSION=1.25.1 \
|
||||
GOPATH=/go \
|
||||
GOROOT=/usr/local/go \
|
||||
PATH=/usr/local/go/bin:/go/bin:${PATH} \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 安装必要的系统依赖和配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装基础工具
|
||||
dnf update -y && \
|
||||
dnf install -y \
|
||||
curl \
|
||||
tar \
|
||||
gzip \
|
||||
git \
|
||||
make \
|
||||
gcc \
|
||||
glibc-devel \
|
||||
glibc-langpack-en \
|
||||
glibc-locale-source \
|
||||
glibc-common \
|
||||
&& \
|
||||
\
|
||||
# 清理dnf缓存以减少镜像大小
|
||||
dnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 正确的locale配置方式 - 使用locale-gen或直接设置
|
||||
# 方法1: 使用locale配置文件
|
||||
echo 'LANG="en_US.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="en_US.UTF-8"' >> /etc/locale.conf; \
|
||||
\
|
||||
# 方法2: 生成locale(CentOS 8的正确方式)
|
||||
localedef -c -i en_US -f UTF-8 en_US.UTF-8 || echo "Locale generation completed"; \
|
||||
\
|
||||
# 验证locale设置
|
||||
locale -a | grep en_US.UTF-8 || echo "en_US.UTF-8 locale available";
|
||||
|
||||
# 添加软件包
|
||||
ADD go1.25.1.linux-amd64.tar.gz /usr/local
|
||||
|
||||
# 下载并安装Go
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 删除临时文件
|
||||
rm -f "go$GO_VERSION.linux-amd64.tar.gz"; \
|
||||
\
|
||||
# 创建Go工作目录
|
||||
mkdir -p /go/src /go/bin /go/pkg && \
|
||||
chmod -R 755 /go;
|
||||
|
||||
# # 下载并安装Go
|
||||
# RUN set -eux; \
|
||||
# \
|
||||
# # 下载Go安装包
|
||||
# curl -SLO "https://dl.google.com/go/go$GO_VERSION.linux-amd64.tar.gz" && \
|
||||
# \
|
||||
# # 解压到/usr/local目录
|
||||
# tar -C /usr/local -xzf "go$GO_VERSION.linux-amd64.tar.gz" && \
|
||||
# \
|
||||
# # 删除临时文件
|
||||
# rm -f "go$GO_VERSION.linux-amd64.tar.gz"; \
|
||||
# \
|
||||
# # 创建Go工作目录
|
||||
# mkdir -p /go/src /go/bin /go/pkg && \
|
||||
# chmod -R 755 /go;
|
||||
|
||||
# 验证Go安装和locale
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查系统locale设置
|
||||
echo "=== Locale Settings ==="; \
|
||||
cat /etc/locale.conf || echo "No locale.conf"; \
|
||||
echo "=== Environment Locale ==="; \
|
||||
echo "LANG=$LANG"; \
|
||||
\
|
||||
# 检查Go版本
|
||||
go version && \
|
||||
\
|
||||
# 检查环境变量
|
||||
go env && \
|
||||
\
|
||||
# 简单的Go程序编译测试
|
||||
echo 'package main; import "fmt"; func main() { fmt.Println("Go环境安装成功!") }' > /tmp/test.go && \
|
||||
go run /tmp/test.go && \
|
||||
rm -f /tmp/test.go;
|
||||
|
||||
# 设置工作目录(Go项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Go应用(安全性考虑)
|
||||
RUN groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi /go
|
||||
|
||||
# 设置默认用户(注释掉以便调试)
|
||||
# USER esxi
|
||||
|
||||
# 设置健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD go version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["go", "version"]
|
||||
203
dockerfiles/golang/1.25.1-centos8-dos/deploy.sh
Normal file
203
dockerfiles/golang/1.25.1-centos8-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="go"
|
||||
VERSION="1.25.1-centos8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "go1.25.1.linux-amd64.tar.gz" ]; then
|
||||
red "错误: go1.25.1.linux-amd64.tar.gz 不存在"
|
||||
echo "请从Golang官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Golang版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" go version; then
|
||||
green "✓ Go测试通过"
|
||||
else
|
||||
red "✗ Go测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} go version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 Go 1.25.1 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
122
dockerfiles/golang/1.25.1-debian12-dos/Dockerfile
Normal file
122
dockerfiles/golang/1.25.1-debian12-dos/Dockerfile
Normal file
@ -0,0 +1,122 @@
|
||||
# 使用Debian 12 (bookworm) 最小化镜像作为基础
|
||||
FROM debian:bookworm-slim
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Debian的Go语言运行环境" \
|
||||
golang.version="1.25.1"
|
||||
|
||||
# 设置环境变量
|
||||
ENV GO_VERSION=1.25.1 \
|
||||
GOPATH=/go \
|
||||
GOROOT=/usr/local/go \
|
||||
PATH=/usr/local/go/bin:/go/bin:${PATH} \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8 \
|
||||
LC_ALL=en_US.UTF-8 \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 安装必要的系统依赖和配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 配置阿里云Debian镜像源
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm main non-free non-free-firmware" > /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-updates main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-backports main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian-security bookworm-security main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
\
|
||||
# 更新系统并安装基础工具
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
curl \
|
||||
tar \
|
||||
gzip \
|
||||
git \
|
||||
make \
|
||||
gcc \
|
||||
libc6-dev \
|
||||
locales \
|
||||
&& \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境(Debian方式)
|
||||
echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && \
|
||||
echo "zh_CN.UTF-8 UTF-8" >> /etc/locale.gen && \
|
||||
locale-gen && \
|
||||
update-locale LANG=en_US.UTF-8 LC_ALL=en_US.UTF-8; \
|
||||
\
|
||||
# 清理apt缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# 添加Go安装包(确保go1.25.1.linux-amd64.tar.gz在构建上下文)
|
||||
ADD go1.25.1.linux-amd64.tar.gz /usr/local/
|
||||
|
||||
# 创建Go工作目录和配置
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建Go工作目录
|
||||
mkdir -p /go/src /go/bin /go/pkg && \
|
||||
chmod -R 755 /go; \
|
||||
\
|
||||
# 验证Go安装
|
||||
echo "=== 验证Go安装 ==="; \
|
||||
echo "Go二进制路径: $(which go)"; \
|
||||
echo "=== Go Version ==="; \
|
||||
go version && \
|
||||
\
|
||||
# 检查环境变量
|
||||
echo "=== Go Environment ==="; \
|
||||
go env && \
|
||||
\
|
||||
# 设置GOPROXY为国内镜像加速后续的go get操作
|
||||
go env -w GOPROXY=https://goproxy.cn,direct; \
|
||||
go env -w GOSUMDB=off; \
|
||||
\
|
||||
# 简单的Go程序编译测试
|
||||
echo 'package main; import "fmt"; func main() { fmt.Println("Go环境安装成功!") }' > /tmp/test.go && \
|
||||
go run /tmp/test.go && \
|
||||
rm -f /tmp/test.go; \
|
||||
\
|
||||
# 验证locale设置
|
||||
echo "=== Locale验证 ==="; \
|
||||
echo "系统Locale: $(locale)"; \
|
||||
echo "环境变量LANG: $LANG"; \
|
||||
echo "环境变量LC_ALL: $LC_ALL"
|
||||
|
||||
# 设置工作目录(Go项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Go应用(安全性考虑)
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi /go; \
|
||||
\
|
||||
# 验证用户创建
|
||||
echo "=== 用户验证 ==="; \
|
||||
id esxi && \
|
||||
echo "家目录权限: $(ls -ld /opt/apps)"
|
||||
|
||||
# 设置默认用户(注释掉以便调试)
|
||||
# USER esxi
|
||||
|
||||
# 设置健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD go version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["go", "version"]
|
||||
203
dockerfiles/golang/1.25.1-debian12-dos/deploy.sh
Normal file
203
dockerfiles/golang/1.25.1-debian12-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="go"
|
||||
VERSION="1.25.1-debian12-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "go1.25.1.linux-amd64.tar.gz" ]; then
|
||||
red "错误: go1.25.1.linux-amd64.tar.gz 不存在"
|
||||
echo "请从Golang官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Golang版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" go version; then
|
||||
green "✓ Go测试通过"
|
||||
else
|
||||
red "✗ Go测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} go version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Debian 12 Go 1.25.1 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
101
dockerfiles/golang/1.25.1-rocky8-dos/Dockerfile
Normal file
101
dockerfiles/golang/1.25.1-rocky8-dos/Dockerfile
Normal file
@ -0,0 +1,101 @@
|
||||
# 使用 RockyLinux 8 最小化镜像作为基础
|
||||
FROM rockylinux:8.9-minimal
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于RockyLinux 8的Go语言运行环境" \
|
||||
golang.version="1.25.1"
|
||||
|
||||
# 设置环境变量
|
||||
ENV GO_VERSION=1.25.1 \
|
||||
GOPATH=/go \
|
||||
GOROOT=/usr/local/go \
|
||||
PATH=/usr/local/go/bin:/go/bin:${PATH} \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 安装必要的系统依赖和配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装基础工具(包括shadow-utils用于用户管理)
|
||||
microdnf update -y && \
|
||||
microdnf install -y \
|
||||
curl \
|
||||
tar \
|
||||
gzip \
|
||||
git \
|
||||
make \
|
||||
gcc \
|
||||
glibc-devel \
|
||||
glibc-langpack-en \
|
||||
shadow-utils \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
microdnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
echo 'LANG="en_US.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="en_US.UTF-8"' >> /etc/locale.conf;
|
||||
|
||||
# 添加Go安装包(确保go1.25.1.linux-amd64.tar.gz在构建上下文)
|
||||
ADD go1.25.1.linux-amd64.tar.gz /usr/local/
|
||||
|
||||
# 创建Go工作目录和配置locale
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建Go工作目录
|
||||
mkdir -p /go/src /go/bin /go/pkg && \
|
||||
chmod -R 755 /go; \
|
||||
\
|
||||
# 检查系统locale设置
|
||||
echo "=== Locale Settings ==="; \
|
||||
cat /etc/locale.conf || echo "No locale.conf"; \
|
||||
echo "=== Environment Locale ==="; \
|
||||
echo "LANG=$LANG"; \
|
||||
\
|
||||
# 检查Go版本
|
||||
echo "=== Go Version ==="; \
|
||||
go version && \
|
||||
\
|
||||
# 检查环境变量
|
||||
echo "=== Go Environment ==="; \
|
||||
go env && \
|
||||
\
|
||||
# 简单的Go程序编译测试
|
||||
echo 'package main; import "fmt"; func main() { fmt.Println("Go环境安装成功!") }' > /tmp/test.go && \
|
||||
go run /tmp/test.go && \
|
||||
rm -f /tmp/test.go;
|
||||
|
||||
# 设置工作目录(Go项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Go应用(安全性考虑)
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi /go;
|
||||
|
||||
# 设置默认用户(注释掉以便调试)
|
||||
# USER esxi
|
||||
|
||||
# 设置健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD go version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["go", "version"]
|
||||
203
dockerfiles/golang/1.25.1-rocky8-dos/deploy.sh
Normal file
203
dockerfiles/golang/1.25.1-rocky8-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="go"
|
||||
VERSION="1.25.1-rocky8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "go1.25.1.linux-amd64.tar.gz" ]; then
|
||||
red "错误: go1.25.1.linux-amd64.tar.gz 不存在"
|
||||
echo "请从Golang官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Golang版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" go version; then
|
||||
green "✓ Go测试通过"
|
||||
else
|
||||
red "✗ Go测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} go version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 Go 1.25.1 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
102
dockerfiles/golang/1.25.1-ubuntu22-dos/Dockerfile
Normal file
102
dockerfiles/golang/1.25.1-ubuntu22-dos/Dockerfile
Normal file
@ -0,0 +1,102 @@
|
||||
# 使用Ubuntu 22.04最小化镜像作为基础
|
||||
FROM ubuntu:22.04
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Ubuntu 22.04的Go语言运行环境" \
|
||||
golang.version="1.25.1"
|
||||
|
||||
# 设置环境变量
|
||||
ENV GO_VERSION=1.25.1 \
|
||||
GOPATH=/go \
|
||||
GOROOT=/usr/local/go \
|
||||
PATH=/usr/local/go/bin:/go/bin:${PATH} \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8 \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 安装必要的系统依赖和配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装基础工具
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
curl \
|
||||
tar \
|
||||
gzip \
|
||||
git \
|
||||
make \
|
||||
gcc \
|
||||
libc6-dev \
|
||||
locales \
|
||||
&& \
|
||||
\
|
||||
# 清理apt缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境(Ubuntu方式)
|
||||
locale-gen en_US.UTF-8 && \
|
||||
update-locale LANG=en_US.UTF-8 LC_ALL=en_US.UTF-8;
|
||||
|
||||
# 添加Go安装包(确保go1.25.1.linux-amd64.tar.gz在构建上下文)
|
||||
ADD go1.25.1.linux-amd64.tar.gz /usr/local/
|
||||
|
||||
# 创建Go工作目录和配置
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建Go工作目录
|
||||
mkdir -p /go/src /go/bin /go/pkg && \
|
||||
chmod -R 755 /go; \
|
||||
\
|
||||
# 检查系统locale设置
|
||||
echo "=== Locale Settings ==="; \
|
||||
locale || echo "Locale info"; \
|
||||
echo "=== Environment Locale ==="; \
|
||||
echo "LANG=$LANG"; \
|
||||
\
|
||||
# 检查Go版本
|
||||
echo "=== Go Version ==="; \
|
||||
go version && \
|
||||
\
|
||||
# 检查环境变量
|
||||
echo "=== Go Environment ==="; \
|
||||
go env && \
|
||||
\
|
||||
# 简单的Go程序编译测试
|
||||
echo 'package main; import "fmt"; func main() { fmt.Println("Go环境安装成功!") }' > /tmp/test.go && \
|
||||
go run /tmp/test.go && \
|
||||
rm -f /tmp/test.go;
|
||||
|
||||
# 设置工作目录(Go项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Go应用(安全性考虑)
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi /go;
|
||||
|
||||
# 设置默认用户(注释掉以便调试)
|
||||
# USER esxi
|
||||
|
||||
# 设置健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD go version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["go", "version"]
|
||||
203
dockerfiles/golang/1.25.1-ubuntu22-dos/deploy.sh
Normal file
203
dockerfiles/golang/1.25.1-ubuntu22-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="go"
|
||||
VERSION="1.25.1-ubuntu22-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "go1.25.1.linux-amd64.tar.gz" ]; then
|
||||
red "错误: go1.25.1.linux-amd64.tar.gz 不存在"
|
||||
echo "请从Golang官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Golang版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" go version; then
|
||||
green "✓ Go测试通过"
|
||||
else
|
||||
red "✗ Go测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} go version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Ubuntu 22 Go 1.25.1 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
154
dockerfiles/jdk/17.0.16-centos8-dos/Dockerfile
Normal file
154
dockerfiles/jdk/17.0.16-centos8-dos/Dockerfile
Normal file
@ -0,0 +1,154 @@
|
||||
# 使用 CentOS 8 作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 维护者信息
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
description="JDK 17 on CentOS 8 with Chinese support" \
|
||||
version="1.0"
|
||||
|
||||
# 设置环境变量
|
||||
ENV LANG zh_CN.UTF-8
|
||||
ENV LC_ALL zh_CN.UTF-8
|
||||
ENV JAVA_HOME /opt/jdk-17.0.16
|
||||
ENV PATH $JAVA_HOME/bin:$PATH
|
||||
ENV CLASSPATH .:$JAVA_HOME/lib/jrt-fs.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 备份并替换 yum 源(解决 CentOS 8 EOL 问题)
|
||||
RUN cd /etc/yum.repos.d/ && \
|
||||
# 备份原有 repo 文件
|
||||
rename '.repo' '.repo.bak' /etc/yum.repos.d/*.repo && \
|
||||
# 安装阿里云的 CentOS 8 归档镜像源
|
||||
curl -s -o /etc/yum.repos.d/Centos-vault-8.5.2111.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo && \
|
||||
# 启用阿里云仓库并禁用官方仓库
|
||||
sed -i 's|^mirrorlist=|#mirrorlist=|g' /etc/yum.repos.d/Centos-*.repo && \
|
||||
sed -i 's|^#baseurl=http://mirror.centos.org|baseurl=https://mirrors.aliyun.com|g' /etc/yum.repos.d/Centos-*.repo && \
|
||||
sed -i 's|^baseurl=http://mirror.centos.org|baseurl=https://mirrors.aliyun.com|g' /etc/yum.repos.d/Centos-*.repo && \
|
||||
# 确保仓库启用
|
||||
sed -i 's|^enabled=.*|enabled=1|g' /etc/yum.repos.d/Centos-*.repo
|
||||
|
||||
# 安装基础软件包和中文支持,并一次性清理缓存
|
||||
RUN yum install -y \
|
||||
fontconfig \
|
||||
glibc-langpack-zh \
|
||||
glibc-locale-source \
|
||||
glibc-common && \
|
||||
# yum-utils \
|
||||
# net-tools \
|
||||
# vim \
|
||||
# curl && \
|
||||
# 设置中文语言环境
|
||||
localedef -c -f UTF-8 -i zh_CN zh_CN.utf8 && \
|
||||
localedef -c -f UTF-8 -i C UTF-8 && \
|
||||
# 设置系统locale
|
||||
echo 'LANG="zh_CN.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="zh_CN.UTF-8"' >> /etc/locale.conf && \
|
||||
# 创建字体目录
|
||||
mkdir -p /usr/share/fonts/ && \
|
||||
chmod 755 /usr/share/fonts/ && \
|
||||
# 清理yum缓存
|
||||
yum clean all && \
|
||||
rm -rf /var/cache/yum && \
|
||||
yum makecache
|
||||
|
||||
# 复制字体文件
|
||||
RUN mkdir -p /usr/share/fonts
|
||||
COPY ./fonts/ /usr/share/fonts/
|
||||
|
||||
# 更新字体缓存并设置时区
|
||||
RUN fc-cache -fv && \
|
||||
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
|
||||
echo 'Asia/Shanghai' > /etc/timezone
|
||||
|
||||
# # 安装 JDK
|
||||
# WORKDIR /usr/local
|
||||
# ADD jdk-17.0.16_linux-x64_bin.tar.gz /usr/local/
|
||||
|
||||
# # 验证 JDK 安装
|
||||
# RUN ln -sf ${JAVA_HOME} /usr/local/jdk-17.0.16 && \
|
||||
# java -version && \
|
||||
# javac -version
|
||||
|
||||
# 添加并精简 JDK
|
||||
ADD jdk-17.0.16_linux-x64_bin.tar.gz /opt/
|
||||
|
||||
# 精简JDK:删除不必要的文件
|
||||
RUN set -eux && \
|
||||
# 重命名JDK目录
|
||||
mv /opt/jdk-17.0.16 /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 创建新的精简JDK目录
|
||||
mkdir -p /opt/jdk-17.0.16 && \
|
||||
\
|
||||
# 保留必要的目录和文件
|
||||
cp -r /opt/jdk-17.0.16-original/bin /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/lib /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/conf /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/include /opt/jdk-17.0.16/ && \
|
||||
\
|
||||
# 删除调试文件(使用通配符)
|
||||
rm -rf /opt/jdk-17.0.16/lib/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.pdb && \
|
||||
\
|
||||
# 删除不必要的模块和文件
|
||||
rm -rf /opt/jdk-17.0.16/lib/src.zip \
|
||||
/opt/jdk-17.0.16/lib/missioncontrol \
|
||||
/opt/jdk-17.0.16/lib/visualvm \
|
||||
/opt/jdk-17.0.16/lib/jfr \
|
||||
/opt/jdk-17.0.16/lib/security/cacerts.dummy \
|
||||
\
|
||||
# 删除演示和样例
|
||||
/opt/jdk-17.0.16-original/demo \
|
||||
/opt/jdk-17.0.16-original/sample \
|
||||
/opt/jdk-17.0.16-original/man \
|
||||
\
|
||||
# 删除文档
|
||||
/opt/jdk-17.0.16-original/legal \
|
||||
/opt/jdk-17.0.16-original/README.md \
|
||||
/opt/jdk-17.0.16-original/release && \
|
||||
\
|
||||
# 删除原始JDK目录
|
||||
rm -rf /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 设置权限
|
||||
chmod -R 755 /opt/jdk-17.0.16 && \
|
||||
chown -R root:root /opt/jdk-17.0.16 &&\
|
||||
\
|
||||
# 验证JDK安装
|
||||
/opt/jdk-17.0.16/bin/java -version && \
|
||||
/opt/jdk-17.0.16/bin/javac -version
|
||||
|
||||
# 清理临时文件和缓存
|
||||
RUN rm -rf /tmp/* /var/tmp/* /var/log/*log /var/log/nginx/*log \
|
||||
/var/log/*.log /var/log/dmesg /var/log/audit/*log \
|
||||
/root/.cache /*.repo.bak
|
||||
|
||||
# 创建非 root 用户运行应用
|
||||
RUN groupadd -r esxi && \
|
||||
useradd -r -g esxi -m -d /app esxi && \
|
||||
chown -R esxi:esxi /app && \
|
||||
# 设置JDK目录权限
|
||||
chown -R esxi:esxi $JAVA_HOME
|
||||
|
||||
|
||||
# 设置最终工作目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 切换到非root用户
|
||||
#USER esxi
|
||||
|
||||
# 健康检查(可选)
|
||||
# HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
# CMD java -version || exit 1
|
||||
|
||||
# 默认命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jdk/17.0.16-centos8-dos/deploy.sh
Normal file
209
dockerfiles/jdk/17.0.16-centos8-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jdk"
|
||||
VERSION="17.0.16-centos8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jdk-17.0.16_linux-x64_bin.tar.gz" ]; then
|
||||
red "错误: jdk-17.0.16_linux-x64_bin.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JDK 17.0.16并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 JDK 17 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
129
dockerfiles/jdk/17.0.16-debian13-dos/Dockerfile
Normal file
129
dockerfiles/jdk/17.0.16-debian13-dos/Dockerfile
Normal file
@ -0,0 +1,129 @@
|
||||
# 使用 Debian 13 (trixie) 作为基础镜像
|
||||
# debian:trixie-slim(Debian 13 的代号)
|
||||
FROM debian:trixie-slim
|
||||
|
||||
# 维护者信息
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
description="JDK 17 on Debian with Chinese support" \
|
||||
version="1.0"
|
||||
|
||||
# 设置环境变量
|
||||
ENV LANG zh_CN.UTF-8
|
||||
ENV LC_ALL zh_CN.UTF-8
|
||||
ENV JAVA_HOME /opt/jdk-17.0.16
|
||||
ENV PATH $JAVA_HOME/bin:$PATH
|
||||
ENV TZ Asia/Shanghai
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 配置阿里云 Debian 镜像源并安装基础软件包
|
||||
RUN echo "deb http://mirrors.aliyun.com/debian/ trixie main non-free non-free-firmware" > /etc/apt/sources.list && \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ trixie-updates main non-free non-free-firmware" >> /etc/apt/sources.list && \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ trixie-backports main non-free non-free-firmware" >> /etc/apt/sources.list && \
|
||||
echo "deb http://mirrors.aliyun.com/debian-security trixie-security main non-free non-free-firmware" >> /etc/apt/sources.list && \
|
||||
apt-get update && \
|
||||
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
wget \
|
||||
curl \
|
||||
fontconfig \
|
||||
locales \
|
||||
tzdata \
|
||||
&& \
|
||||
# 安装中文语言支持
|
||||
apt-get install -y --no-install-recommends locales-all && \
|
||||
# 生成中文locale
|
||||
echo "zh_CN.UTF-8 UTF-8" > /etc/locale.gen && \
|
||||
echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen && \
|
||||
locale-gen && \
|
||||
update-locale LANG=zh_CN.UTF-8 LC_ALL=zh_CN.UTF-8 && \
|
||||
# 设置时区
|
||||
ln -fs /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
|
||||
echo "Asia/Shanghai" > /etc/timezone && \
|
||||
dpkg-reconfigure --frontend noninteractive tzdata && \
|
||||
# 清理apt缓存
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
|
||||
# 添加并精简 JDK
|
||||
ADD jdk-17.0.16_linux-x64_bin.tar.gz /opt/
|
||||
|
||||
# 精简JDK:删除不必要的文件
|
||||
RUN set -eux && \
|
||||
# 重命名JDK目录
|
||||
mv /opt/jdk-17.0.16 /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 创建新的精简JDK目录
|
||||
mkdir -p /opt/jdk-17.0.16 && \
|
||||
\
|
||||
# 保留必要的目录和文件
|
||||
cp -r /opt/jdk-17.0.16-original/bin /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/lib /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/conf /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/include /opt/jdk-17.0.16/ && \
|
||||
\
|
||||
# 使用find命令删除调试文件(更可靠)
|
||||
find /opt/jdk-17.0.16 -name "*.diz" -delete && \
|
||||
find /opt/jdk-17.0.16 -name "*.debuginfo" -delete && \
|
||||
find /opt/jdk-17.0.16 -name "*.pdb" -delete && \
|
||||
\
|
||||
# 删除不必要的模块和文件
|
||||
rm -rf /opt/jdk-17.0.16/lib/src.zip \
|
||||
/opt/jdk-17.0.16/lib/missioncontrol \
|
||||
/opt/jdk-17.0.16/lib/visualvm \
|
||||
/opt/jdk-17.0.16/lib/jfr \
|
||||
\
|
||||
# 删除演示和样例
|
||||
/opt/jdk-17.0.16-original/demo \
|
||||
/opt/jdk-17.0.16-original/sample \
|
||||
/opt/jdk-17.0.16-original/man \
|
||||
\
|
||||
# 删除文档
|
||||
/opt/jdk-17.0.16-original/legal \
|
||||
/opt/jdk-17.0.16-original/README.md \
|
||||
/opt/jdk-17.0.16-original/release && \
|
||||
\
|
||||
# 删除原始JDK目录
|
||||
rm -rf /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 设置权限
|
||||
chmod -R 755 /opt/jdk-17.0.16 && \
|
||||
chown -R root:root /opt/jdk-17.0.16 &&\
|
||||
\
|
||||
# 验证JDK安装
|
||||
/opt/jdk-17.0.16/bin/java -version && \
|
||||
/opt/jdk-17.0.16/bin/javac -version
|
||||
|
||||
# 清理临时文件和缓存
|
||||
RUN rm -rf /tmp/* /var/tmp/* /var/log/*log \
|
||||
/var/log/*.log /var/log/dmesg /var/log/audit/*log \
|
||||
/root/.cache
|
||||
|
||||
# 复制字体文件(如果需要)
|
||||
# COPY ./fonts/ /usr/share/fonts/
|
||||
# RUN fc-cache -fv
|
||||
|
||||
# 创建非 root 用户运行应用
|
||||
RUN groupadd -r esxi && \
|
||||
useradd -r -g esxi -m -d /app esxi && \
|
||||
chown -R esxi:esxi /app && \
|
||||
# 设置JDK目录权限
|
||||
chown -R esxi:esxi $JAVA_HOME
|
||||
|
||||
# 验证 JDK 安装
|
||||
RUN $JAVA_HOME/bin/java -version && \
|
||||
$JAVA_HOME/bin/javac -version
|
||||
|
||||
# 设置最终工作目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# # 切换到非root用户
|
||||
# USER esxi
|
||||
|
||||
# 健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD $JAVA_HOME/bin/java -version || exit 1
|
||||
|
||||
# 默认命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jdk/17.0.16-debian13-dos/deploy.sh
Normal file
209
dockerfiles/jdk/17.0.16-debian13-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jdk"
|
||||
VERSION="17.0.16-debian13-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jdk-17.0.16_linux-x64_bin.tar.gz" ]; then
|
||||
red "错误: jdk-17.0.16_linux-x64_bin.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JDK 17.0.16并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Debian 13.10 JDK 17 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
135
dockerfiles/jdk/17.0.16-rocky8-dos/Dockerfile
Normal file
135
dockerfiles/jdk/17.0.16-rocky8-dos/Dockerfile
Normal file
@ -0,0 +1,135 @@
|
||||
# 使用 RockyLinux 8 最小化镜像作为基础
|
||||
FROM rockylinux:8.9-minimal
|
||||
|
||||
# 维护者信息
|
||||
LABEL maintainer="XXXX团队" \
|
||||
description="Minimal JDK 17.0.16 on RockyLinux 8 with Chinese support" \
|
||||
version="1.0" \
|
||||
java.version="17.0.16"
|
||||
|
||||
# 设置环境变量
|
||||
ENV LANG zh_CN.UTF-8
|
||||
ENV LC_ALL zh_CN.UTF-8
|
||||
ENV JAVA_HOME /opt/jdk-17.0.16
|
||||
ENV PATH $JAVA_HOME/bin:$PATH
|
||||
ENV CLASSPATH .:$JAVA_HOME/lib/jrt-fs.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
|
||||
|
||||
# 一次性安装所有依赖并设置环境
|
||||
RUN set -eux && \
|
||||
# 配置国内镜像源加速
|
||||
sed -e 's|^mirrorlist=|#mirrorlist=|g' \
|
||||
-e 's|^#baseurl=http://dl.rockylinux.org/$contentdir|baseurl=https://mirrors.aliyun.com/rockylinux|g' \
|
||||
-i.bak \
|
||||
/etc/yum.repos.d/*.repo && \
|
||||
\
|
||||
# 安装最小必要包(使用microdnf更轻量)
|
||||
microdnf update -y && \
|
||||
microdnf install -y \
|
||||
fontconfig \
|
||||
glibc-langpack-zh \
|
||||
glibc-locale-source \
|
||||
glibc-common \
|
||||
&& \
|
||||
\
|
||||
# 设置中文语言环境
|
||||
localedef -c -f UTF-8 -i zh_CN zh_CN.utf8 && \
|
||||
echo 'LANG="zh_CN.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="zh_CN.UTF-8"' >> /etc/locale.conf && \
|
||||
\
|
||||
# 设置时区
|
||||
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
|
||||
echo 'Asia/Shanghai' > /etc/timezone && \
|
||||
\
|
||||
# 创建字体目录
|
||||
mkdir -p /usr/share/fonts/ && \
|
||||
chmod 755 /usr/share/fonts/ && \
|
||||
\
|
||||
# 清理缓存
|
||||
microdnf clean all && \
|
||||
rm -rf /var/cache/yum /var/tmp/* /tmp/*
|
||||
|
||||
# 复制最小字体文件(只复制必需的中文字体)
|
||||
COPY ./fonts/simsun.ttf /usr/share/fonts/
|
||||
# 可选:如果需要更多字体支持,可以添加其他字体
|
||||
# COPY ./fonts/msyh.ttc /usr/share/fonts/
|
||||
|
||||
# 更新字体缓存
|
||||
RUN fc-cache -fv && rm -rf /var/cache/fontconfig/*
|
||||
|
||||
# 添加并精简 JDK
|
||||
ADD jdk-17.0.16_linux-x64_bin.tar.gz /opt/
|
||||
|
||||
# 精简JDK:删除不必要的文件
|
||||
RUN set -eux && \
|
||||
# 重命名JDK目录
|
||||
mv /opt/jdk-17.0.16 /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 创建新的精简JDK目录
|
||||
mkdir -p /opt/jdk-17.0.16 && \
|
||||
\
|
||||
# 保留必要的目录和文件
|
||||
cp -r /opt/jdk-17.0.16-original/bin /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/lib /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/conf /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/include /opt/jdk-17.0.16/ && \
|
||||
\
|
||||
# 删除调试文件(使用通配符)
|
||||
rm -rf /opt/jdk-17.0.16/lib/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.pdb && \
|
||||
\
|
||||
# 删除不必要的模块和文件
|
||||
rm -rf /opt/jdk-17.0.16/lib/src.zip \
|
||||
/opt/jdk-17.0.16/lib/missioncontrol \
|
||||
/opt/jdk-17.0.16/lib/visualvm \
|
||||
/opt/jdk-17.0.16/lib/jfr \
|
||||
/opt/jdk-17.0.16/lib/security/cacerts.dummy \
|
||||
\
|
||||
# 删除演示和样例
|
||||
/opt/jdk-17.0.16-original/demo \
|
||||
/opt/jdk-17.0.16-original/sample \
|
||||
/opt/jdk-17.0.16-original/man \
|
||||
\
|
||||
# 删除文档
|
||||
/opt/jdk-17.0.16-original/legal \
|
||||
/opt/jdk-17.0.16-original/README.md \
|
||||
/opt/jdk-17.0.16-original/release && \
|
||||
\
|
||||
# 删除原始JDK目录
|
||||
rm -rf /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 设置权限
|
||||
chmod -R 755 /opt/jdk-17.0.16 && \
|
||||
chown -R root:root /opt/jdk-17.0.16 &&\
|
||||
\
|
||||
# 验证JDK安装
|
||||
/opt/jdk-17.0.16/bin/java -version && \
|
||||
/opt/jdk-17.0.16/bin/javac -version
|
||||
|
||||
# 创建非root用户
|
||||
RUN set -eux && \
|
||||
groupadd -r esxi -g 1000 && \
|
||||
useradd -r -g esxi -u 1000 -m -d /app -s /bin/bash esxi && \
|
||||
chown -R esxi:esxi /app
|
||||
|
||||
# 清理临时文件
|
||||
RUN rm -rf /tmp/* /var/tmp/* /var/log/*.log /*.repo.bak
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 切换到非root用户
|
||||
#USER esxi
|
||||
|
||||
# # 健康检查
|
||||
# HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
# CMD java -version || exit 1
|
||||
|
||||
# 默认命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jdk/17.0.16-rocky8-dos/deploy.sh
Normal file
209
dockerfiles/jdk/17.0.16-rocky8-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jdk"
|
||||
VERSION="17.0.16-rocky8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jdk-17.0.16_linux-x64_bin.tar.gz" ]; then
|
||||
red "错误: jdk-17.0.16_linux-x64_bin.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JDK 17.0.16并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 JDK 17 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
163
dockerfiles/jdk/17.0.16-ubuntu22-dos/Dockerfile
Normal file
163
dockerfiles/jdk/17.0.16-ubuntu22-dos/Dockerfile
Normal file
@ -0,0 +1,163 @@
|
||||
# 使用 Ubuntu 22.04 LTS 作为基础镜像
|
||||
FROM ubuntu:22.04
|
||||
|
||||
# 维护者信息
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
description="JDK 17 on Ubuntu with Chinese support" \
|
||||
version="1.0"
|
||||
|
||||
# 设置环境变量
|
||||
ENV LANG zh_CN.UTF-8
|
||||
ENV LC_ALL zh_CN.UTF-8
|
||||
ENV JAVA_HOME /opt/jdk-17.0.16
|
||||
ENV PATH $JAVA_HOME/bin:$PATH
|
||||
ENV TZ Asia/Shanghai
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 配置阿里云Ubuntu镜像源并安装基础软件包
|
||||
RUN sed -i 's/archive.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list && \
|
||||
sed -i 's/security.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list && \
|
||||
apt-get update && \
|
||||
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
wget \
|
||||
curl \
|
||||
fontconfig \
|
||||
locales \
|
||||
tzdata \
|
||||
&& \
|
||||
# 安装中文语言包
|
||||
apt-get install -y --no-install-recommends language-pack-zh-hans && \
|
||||
# 生成中文locale
|
||||
locale-gen zh_CN.UTF-8 && \
|
||||
locale-gen en_US.UTF-8 && \
|
||||
update-locale LANG=zh_CN.UTF-8 LC_ALL=zh_CN.UTF-8 && \
|
||||
# 设置时区
|
||||
ln -fs /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
|
||||
echo "Asia/Shanghai" > /etc/timezone && \
|
||||
dpkg-reconfigure --frontend noninteractive tzdata && \
|
||||
# 清理apt缓存
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
|
||||
# # 下载并安装 JDK 17
|
||||
# RUN set -eux && \
|
||||
# # 下载JDK
|
||||
# wget -O jdk-17.0.16_linux-x64_bin.tar.gz \
|
||||
# https://download.java.net/java/GA/jdk17.0.16/dfd4a8d0985749f896bed50d7138ee7f/8/GPL/openjdk-17.0.16_linux-x64_bin.tar.gz && \
|
||||
# # 创建安装目录
|
||||
# mkdir -p /opt && \
|
||||
# tar -xzf jdk-17.0.16_linux-x64_bin.tar.gz -C /opt && \
|
||||
# # 精简JDK
|
||||
# cd /opt/jdk-17.0.16 && \
|
||||
# rm -rf \
|
||||
# demo/ \
|
||||
# sample/ \
|
||||
# man/ \
|
||||
# legal/ \
|
||||
# lib/src.zip \
|
||||
# lib/missioncontrol/ \
|
||||
# lib/visualvm/ \
|
||||
# lib/jfr/ \
|
||||
# README.md \
|
||||
# release && \
|
||||
# # 删除调试文件
|
||||
# find . -name "*.diz" -delete && \
|
||||
# find . -name "*.debuginfo" -delete && \
|
||||
# find . -name "*.pdb" -delete && \
|
||||
# # 设置权限
|
||||
# chmod -R 755 /opt/jdk-17.0.16 && \
|
||||
# chown -R root:root /opt/jdk-17.0.16 && \
|
||||
# # 清理下载文件
|
||||
# rm -f /tmp/jdk-17.0.16_linux-x64_bin.tar.gz
|
||||
|
||||
# 添加并精简 JDK
|
||||
ADD jdk-17.0.16_linux-x64_bin.tar.gz /opt/
|
||||
|
||||
# 精简JDK:删除不必要的文件
|
||||
RUN set -eux && \
|
||||
# 重命名JDK目录
|
||||
mv /opt/jdk-17.0.16 /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 创建新的精简JDK目录
|
||||
mkdir -p /opt/jdk-17.0.16 && \
|
||||
\
|
||||
# 保留必要的目录和文件
|
||||
cp -r /opt/jdk-17.0.16-original/bin /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/lib /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/conf /opt/jdk-17.0.16/ && \
|
||||
cp -r /opt/jdk-17.0.16-original/include /opt/jdk-17.0.16/ && \
|
||||
\
|
||||
# 删除调试文件(使用通配符)
|
||||
rm -rf /opt/jdk-17.0.16/lib/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.diz \
|
||||
/opt/jdk-17.0.16/lib/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.debuginfo \
|
||||
/opt/jdk-17.0.16/lib/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*.pdb \
|
||||
/opt/jdk-17.0.16/lib/*/*/*.pdb && \
|
||||
\
|
||||
# 删除不必要的模块和文件
|
||||
rm -rf /opt/jdk-17.0.16/lib/src.zip \
|
||||
/opt/jdk-17.0.16/lib/missioncontrol \
|
||||
/opt/jdk-17.0.16/lib/visualvm \
|
||||
/opt/jdk-17.0.16/lib/jfr \
|
||||
/opt/jdk-17.0.16/lib/security/cacerts.dummy \
|
||||
\
|
||||
# 删除演示和样例
|
||||
/opt/jdk-17.0.16-original/demo \
|
||||
/opt/jdk-17.0.16-original/sample \
|
||||
/opt/jdk-17.0.16-original/man \
|
||||
\
|
||||
# 删除文档
|
||||
/opt/jdk-17.0.16-original/legal \
|
||||
/opt/jdk-17.0.16-original/README.md \
|
||||
/opt/jdk-17.0.16-original/release && \
|
||||
\
|
||||
# 删除原始JDK目录
|
||||
rm -rf /opt/jdk-17.0.16-original && \
|
||||
\
|
||||
# 设置权限
|
||||
chmod -R 755 /opt/jdk-17.0.16 && \
|
||||
chown -R root:root /opt/jdk-17.0.16 &&\
|
||||
\
|
||||
# 验证JDK安装
|
||||
/opt/jdk-17.0.16/bin/java -version && \
|
||||
/opt/jdk-17.0.16/bin/javac -version
|
||||
|
||||
# 清理临时文件和缓存
|
||||
RUN rm -rf /tmp/* /var/tmp/* /var/log/*log /var/log/nginx/*log \
|
||||
/var/log/*.log /var/log/dmesg /var/log/audit/*log \
|
||||
/root/.cache /*.repo.bak
|
||||
|
||||
# 复制字体文件(如果需要)
|
||||
# COPY ./fonts/ /usr/share/fonts/
|
||||
# RUN fc-cache -fv
|
||||
|
||||
# 创建非 root 用户运行应用
|
||||
RUN groupadd -r esxi && \
|
||||
useradd -r -g esxi -m -d /app esxi && \
|
||||
chown -R esxi:esxi /app && \
|
||||
# 设置JDK目录权限
|
||||
chown -R esxi:esxi $JAVA_HOME
|
||||
|
||||
# 验证 JDK 安装
|
||||
RUN $JAVA_HOME/bin/java -version && \
|
||||
$JAVA_HOME/bin/javac -version
|
||||
|
||||
# 设置最终工作目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# # 切换到非root用户
|
||||
# USER esxi
|
||||
|
||||
# 健康检查(可选)
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD $JAVA_HOME/bin/java -version || exit 1
|
||||
|
||||
# 默认命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jdk/17.0.16-ubuntu22-dos/deploy.sh
Normal file
209
dockerfiles/jdk/17.0.16-ubuntu22-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jdk"
|
||||
VERSION="17.0.16-ubuntu22-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jdk-17.0.16_linux-x64_bin.tar.gz" ]; then
|
||||
red "错误: jdk-17.0.16_linux-x64_bin.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JDK 17.0.16并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Ubuntu 22.04 JDK 17 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
95
dockerfiles/jre/8u202-centos8-dos/Dockerfile
Normal file
95
dockerfiles/jre/8u202-centos8-dos/Dockerfile
Normal file
@ -0,0 +1,95 @@
|
||||
# 使用CentOS 8作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于CentOS 8的JRE 8u202运行环境(支持中英文)" \
|
||||
java.version="1.8.0_202"
|
||||
|
||||
# 设置环境变量
|
||||
ENV TZ=Asia/Shanghai \
|
||||
LANG=zh_CN.UTF-8 \
|
||||
LANGUAGE=zh_CN:zh:en_US:en \
|
||||
LC_ALL=zh_CN.UTF-8 \
|
||||
JAVA_HOME=/usr/local/jre1.8.0_202 \
|
||||
PATH=/usr/local/jre1.8.0_202/bin:$PATH
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 复制本地JRE压缩包到镜像中
|
||||
COPY jre-8u202-linux-x64.tar.gz /tmp/
|
||||
|
||||
# 安装必要的系统包并配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装中文语言支持
|
||||
dnf update -y && \
|
||||
dnf install -y \
|
||||
tzdata \
|
||||
glibc-langpack-zh \
|
||||
glibc-langpack-en \
|
||||
fontconfig \
|
||||
dejavu-sans-fonts \
|
||||
dejavu-serif-fonts \
|
||||
dejavu-sans-mono-fonts \
|
||||
wqy-microhei-fonts \
|
||||
&& \
|
||||
\
|
||||
# 清理dnf缓存以减少镜像大小
|
||||
dnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 生成中文本地化配置
|
||||
localedef -c -f UTF-8 -i zh_CN zh_CN.UTF-8 && \
|
||||
localedef -c -f UTF-8 -i en_US en_US.UTF-8; \
|
||||
\
|
||||
# 设置系统语言环境
|
||||
echo 'LANG="zh_CN.UTF-8"' > /etc/locale.conf; \
|
||||
\
|
||||
# 创建Java安装目录
|
||||
mkdir -p /usr/local/java; \
|
||||
\
|
||||
# 解压JRE并设置权限(JRE包解压后通常直接包含jre目录)
|
||||
tar -xzf jre-8u202-linux-x64.tar.gz -C /usr/local/ && \
|
||||
\
|
||||
# 删除临时文件
|
||||
rm -f jre-8u202-linux-x64.tar.gz; \
|
||||
\
|
||||
# 创建符号链接以便版本升级时更容易管理
|
||||
ln -sf /usr/local/jre1.8.0_202 /usr/bin/jre; \
|
||||
\
|
||||
# 创建字体目录
|
||||
mkdir -p /usr/share/fonts/ && \
|
||||
chmod 755 /usr/share/fonts/ && \
|
||||
cp ./fonts/simsun.ttf /usr/share/fonts/ && \
|
||||
\
|
||||
# 更新字体缓存
|
||||
fc-cache -fv; \
|
||||
\
|
||||
# 验证JRE安装
|
||||
java -version; \
|
||||
\
|
||||
# 创建非root用户用于运行Java应用
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/esxi -s /bin/bash esxi && \
|
||||
mkdir -p /opt/esxi && \
|
||||
chown -R esxi:esxi /opt/esxi;
|
||||
|
||||
# 切换到应用目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 设置默认用户(推荐在生产环境中启用)
|
||||
#USER esxi
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
||||
CMD java -version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jre/8u202-centos8-dos/deploy.sh
Normal file
209
dockerfiles/jre/8u202-centos8-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jre"
|
||||
VERSION="8u202-centos8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jre-8u202-linux-x64.tar.gz" ]; then
|
||||
red "错误: jre-8u202-linux-x64.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JRE 8u202并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 JRE 8u202 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
110
dockerfiles/jre/8u202-debian13-dos/Dockerfile
Normal file
110
dockerfiles/jre/8u202-debian13-dos/Dockerfile
Normal file
@ -0,0 +1,110 @@
|
||||
# 使用 Debian 13 (trixie) 作为基础镜像
|
||||
# debian:trixie-slim(Debian 13 的代号)
|
||||
FROM debian:trixie-slim
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Debian的JRE 8u202运行环境(支持中英文)" \
|
||||
java.version="1.8.0_202"
|
||||
|
||||
# 设置环境变量
|
||||
ENV TZ=Asia/Shanghai \
|
||||
LANG=zh_CN.UTF-8 \
|
||||
LANGUAGE=zh_CN:zh:en_US:en \
|
||||
LC_ALL=zh_CN.UTF-8 \
|
||||
JAVA_HOME=/usr/local/jre1.8.0_202 \
|
||||
PATH=/usr/local/jre1.8.0_202/bin:$PATH \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 复制本地JRE压缩包到镜像中
|
||||
COPY jre-8u202-linux-x64.tar.gz /tmp/
|
||||
|
||||
# 安装必要的系统包并配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 配置阿里云Debian镜像源
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm main non-free non-free-firmware" > /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-updates main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-backports main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian-security bookworm-security main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
\
|
||||
# 更新系统并安装必要的基础工具
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
tzdata \
|
||||
locales \
|
||||
fontconfig \
|
||||
fonts-dejavu \
|
||||
fonts-wqy-microhei \
|
||||
ca-certificates \
|
||||
tar \
|
||||
bash \
|
||||
&& \
|
||||
\
|
||||
# 清理apt缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 生成中文本地化配置
|
||||
echo "zh_CN.UTF-8 UTF-8" > /etc/locale.gen; \
|
||||
echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen; \
|
||||
locale-gen; \
|
||||
\
|
||||
# 设置系统语言环境
|
||||
update-locale LANG=zh_CN.UTF-8; \
|
||||
\
|
||||
# 解压JRE到/usr/local目录
|
||||
tar -xzf jre-8u202-linux-x64.tar.gz -C /usr/local/ && \
|
||||
\
|
||||
# 删除临时文件
|
||||
rm -f jre-8u202-linux-x64.tar.gz; \
|
||||
\
|
||||
# 创建符号链接以便版本升级时更容易管理
|
||||
ln -sf /usr/local/jre1.8.0_202 /usr/local/jre; \
|
||||
\
|
||||
# 创建全局可执行文件链接
|
||||
update-alternatives --install "/usr/bin/java" "java" "/usr/local/jre/bin/java" 1 && \
|
||||
update-alternatives --install "/usr/bin/javac" "javac" "/usr/local/jre/bin/javac" 1 && \
|
||||
update-alternatives --set java /usr/local/jre/bin/java; \
|
||||
\
|
||||
# 创建字体目录并设置权限
|
||||
mkdir -p /usr/share/fonts/truetype/ && \
|
||||
chmod 755 /usr/share/fonts/truetype/; \
|
||||
\
|
||||
# 更新字体缓存
|
||||
fc-cache -fv; \
|
||||
\
|
||||
# 验证JRE安装
|
||||
java -version && \
|
||||
/usr/local/jre/bin/java -version; \
|
||||
\
|
||||
# 创建非root用户用于运行Java应用(使用sh而不是bash)
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/esxi -s /bin/sh esxi && \
|
||||
mkdir -p /opt/esxi && \
|
||||
chown -R esxi:esxi /opt/esxi; \
|
||||
\
|
||||
# 设置文件权限
|
||||
chmod -R 755 /usr/local/jre1.8.0_202 && \
|
||||
chown -R root:root /usr/local/jre1.8.0_202
|
||||
|
||||
# 切换到应用目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 设置默认用户
|
||||
#USER esxi
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
||||
CMD java -version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jre/8u202-debian13-dos/deploy.sh
Normal file
209
dockerfiles/jre/8u202-debian13-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jre"
|
||||
VERSION="8u202-debian13-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jre-8u202-linux-x64.tar.gz" ]; then
|
||||
red "错误: jre-8u202-linux-x64.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JRE 8u202并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Debian 13 JRE 8u202 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
95
dockerfiles/jre/8u202-rocky8-dos/Dockerfile
Normal file
95
dockerfiles/jre/8u202-rocky8-dos/Dockerfile
Normal file
@ -0,0 +1,95 @@
|
||||
# 使用Rocky Linux 8作为基础镜像
|
||||
FROM rockylinux:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Rocky Linux 8的JRE 8u202运行环境(支持中英文)" \
|
||||
java.version="1.8.0_202"
|
||||
|
||||
# 设置环境变量
|
||||
ENV TZ=Asia/Shanghai \
|
||||
LANG=zh_CN.UTF-8 \
|
||||
LANGUAGE=zh_CN:zh:en_US:en \
|
||||
LC_ALL=zh_CN.UTF-8 \
|
||||
JAVA_HOME=/usr/local/jre1.8.0_202 \
|
||||
PATH=/usr/local/jre1.8.0_202/bin:$PATH
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 复制本地JRE压缩包到镜像中
|
||||
COPY jre-8u202-linux-x64.tar.gz /tmp/
|
||||
|
||||
# 安装必要的系统包并配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装中文语言支持
|
||||
dnf update -y && \
|
||||
dnf install -y \
|
||||
tzdata \
|
||||
glibc-langpack-zh \
|
||||
glibc-langpack-en \
|
||||
fontconfig \
|
||||
dejavu-sans-fonts \
|
||||
dejavu-serif-fonts \
|
||||
dejavu-sans-mono-fonts \
|
||||
wqy-microhei-fonts \
|
||||
&& \
|
||||
\
|
||||
# 清理dnf缓存以减少镜像大小
|
||||
dnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 生成中文本地化配置
|
||||
localedef -c -f UTF-8 -i zh_CN zh_CN.UTF-8 && \
|
||||
localedef -c -f UTF-8 -i en_US en_US.UTF-8; \
|
||||
\
|
||||
# 设置系统语言环境
|
||||
echo 'LANG="zh_CN.UTF-8"' > /etc/locale.conf; \
|
||||
\
|
||||
# 创建Java安装目录
|
||||
mkdir -p /usr/local/java; \
|
||||
\
|
||||
# 解压JRE并设置权限(JRE包解压后通常直接包含jre目录)
|
||||
tar -xzf jre-8u202-linux-x64.tar.gz -C /usr/local/ && \
|
||||
\
|
||||
# 删除临时文件
|
||||
rm -f jre-8u202-linux-x64.tar.gz; \
|
||||
\
|
||||
# 创建符号链接以便版本升级时更容易管理
|
||||
ln -sf /usr/local/jre1.8.0_202 /usr/bin/jre; \
|
||||
\
|
||||
# 创建字体目录
|
||||
mkdir -p /usr/share/fonts/ && \
|
||||
chmod 755 /usr/share/fonts/ && \
|
||||
cp ./fonts/simsun.ttf /usr/share/fonts/ && \
|
||||
\
|
||||
# 更新字体缓存
|
||||
fc-cache -fv; \
|
||||
\
|
||||
# 验证JRE安装
|
||||
java -version; \
|
||||
\
|
||||
# 创建非root用户用于运行Java应用
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/esxi -s /bin/bash esxi && \
|
||||
mkdir -p /opt/esxi && \
|
||||
chown -R esxi:esxi /opt/esxi;
|
||||
|
||||
# 切换到应用目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 设置默认用户(推荐在生产环境中启用)
|
||||
#USER esxi
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
||||
CMD java -version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["java", "-version"]
|
||||
133
dockerfiles/jre/8u202-rocky8-dos/README.md
Normal file
133
dockerfiles/jre/8u202-rocky8-dos/README.md
Normal file
@ -0,0 +1,133 @@
|
||||
1、下载jdk/jre
|
||||
|
||||
[官网下载地址](https://www.oracle.com/java/technologies/downloads/archive/) ,由于服务器上只需要java运行时环境,所以这里选择下载jre,如下图下载需要的对应的版本:
|
||||
|
||||
2、删除jre中无用的文件
|
||||
|
||||
```
|
||||
#解压
|
||||
tar -zxvf jre-8u202-linux-x64.tar.gz
|
||||
|
||||
cd jre1.8.0_202
|
||||
#删除文本文件
|
||||
rm -rf COPYRIGHT LICENSE README release THIRDPARTYLICENSEREADME-JAVAFX.txt THIRDPARTYLICENSEREADME.txt Welcome.html
|
||||
|
||||
#删除其他无用文件
|
||||
rm -rf lib/plugin.jar \
|
||||
lib/ext/jfxrt.jar \
|
||||
bin/javaws \
|
||||
lib/javaws.jar \
|
||||
lib/desktop \
|
||||
plugin \
|
||||
lib/deploy* \
|
||||
lib/*javafx* \
|
||||
lib/*jfx* \
|
||||
lib/amd64/libdecora_sse.so \
|
||||
lib/amd64/libprism_*.so \
|
||||
lib/amd64/libfxplugins.so \
|
||||
lib/amd64/libglass.so \
|
||||
lib/amd64/libgstreamer-lite.so \
|
||||
lib/amd64/libjavafx*.so \
|
||||
lib/amd64/libjfx*.so
|
||||
|
||||
#将解压文件重新压缩
|
||||
tar -zcvf jre-8u202.tar.gz jre/
|
||||
```
|
||||
|
||||
3、制作Dockerfile文件
|
||||
|
||||
```
|
||||
# 使用CentOS 8作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 维护者
|
||||
MAINTAINER author 小蚂蚁
|
||||
|
||||
# 创建一个新目录来存储jdk文件
|
||||
RUN mkdir /usr/local/java
|
||||
|
||||
# 将jdk压缩文件复制到镜像中,它将自动解压缩tar文件
|
||||
ADD jre-8u202.tar.gz /usr/local/java/
|
||||
|
||||
# 设置时区
|
||||
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
|
||||
|
||||
# 设置环境变量
|
||||
ENV LANG=en_US.UTF-8 LANGUAGE=en_US.UTF-8
|
||||
ENV JAVA_HOME /usr/local/java/jre1.8.0_202
|
||||
ENV PATH $JAVA_HOME/bin:$PATH
|
||||
|
||||
# VOLUME 指定了临时文件目录为/tmp
|
||||
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
|
||||
VOLUME /tmp
|
||||
|
||||
# 工作目录
|
||||
WORKDIR /opt/
|
||||
```
|
||||
|
||||
4、构建镜像
|
||||
|
||||
```
|
||||
docker build -t jre:8u202-centos8 .
|
||||
```
|
||||
|
||||
5、创建容器
|
||||
|
||||
```
|
||||
docker run -it --name docker_jre8 jre:8u202-centos8
|
||||
```
|
||||
|
||||
```
|
||||
docker run -i -t jre:8u202-centos8 /bin/bash
|
||||
|
||||
查看版本:
|
||||
[root@3a881fab5716 opt]# java -version
|
||||
java version "1.8.0_202"
|
||||
Java(TM) SE Runtime Environment (build 1.8.0_202-b08)
|
||||
Java HotSpot(TM) 64-Bit Server VM (build 25.202-b08, mixed mode)
|
||||
```
|
||||
|
||||
6、上传
|
||||
|
||||
```
|
||||
# 打标签
|
||||
docker tag jre:8u202-centos8 192.168.10.101:8001/xiaomayi-base/jre:8u202-centos8
|
||||
# 上传镜像
|
||||
docker push 192.168.10.101:8001/xiaomayi-base/jre:8u202-centos8
|
||||
```
|
||||
|
||||
|
||||
特别备注:
|
||||
|
||||
目标服务器非 root 用户权限问题解决:
|
||||
|
||||
```
|
||||
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
|
||||
permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post "http://%2Fvar%2Frun%2Fdocker.sock/v1.24/auth": dial unix /var/run/docker.sock: connect: permission denied
|
||||
permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post "http://%2Fvar%2Frun%2Fdocker.sock/v1.24/images/create?fromImage=manage.harbor.djangoadmin.cn%2Fxiaomayi%2Fxiaomayi-elevue&tag=dev-137": dial unix /var/run/docker.sock: connect: permission denied
|
||||
```
|
||||
|
||||
解决办法:把我们当前的用户添加到docker组中就可以了;
|
||||
|
||||
参考地址:https://blog.csdn.net/weixin_43321041/article/details/120399194
|
||||
chmod 666 /var/run/docker.sock
|
||||
|
||||
或者
|
||||
|
||||
权限问题:
|
||||
chmod 600 ~/.docker/config.json
|
||||
chmod 700 ~/.docker
|
||||
|
||||
sudo chown $USER:$USER ~/.docker
|
||||
sudo chown $USER:$USER ~/.docker/config.json
|
||||
|
||||
应用部署服务器需要设置docker配置:
|
||||
|
||||
```
|
||||
vim /usr/lib/systemd/system/docker.service
|
||||
--insecure-registry manage.harbor.xiaomayicloud.com --insecure-registry 192.168.10.202:8001
|
||||
|
||||
chmod 666 /var/run/docker.sock
|
||||
```
|
||||
|
||||
|
||||
209
dockerfiles/jre/8u202-rocky8-dos/deploy.sh
Normal file
209
dockerfiles/jre/8u202-rocky8-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jre"
|
||||
VERSION="8u202-rocky8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jre-8u202-linux-x64.tar.gz" ]; then
|
||||
red "错误: jre-8u202-linux-x64.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JRE 8u202并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 JRE 8u202 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
100
dockerfiles/jre/8u202-utunbu22-dos/Dockerfile
Normal file
100
dockerfiles/jre/8u202-utunbu22-dos/Dockerfile
Normal file
@ -0,0 +1,100 @@
|
||||
# 使用Ubuntu 22.04作为基础镜像
|
||||
FROM ubuntu:22.04
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Ubuntu 22.04的JRE 8u202运行环境(支持中英文)" \
|
||||
java.version="1.8.0_202"
|
||||
|
||||
# 设置环境变量
|
||||
ENV TZ=Asia/Shanghai \
|
||||
LANG=zh_CN.UTF-8 \
|
||||
LANGUAGE=zh_CN:zh:en_US:en \
|
||||
LC_ALL=zh_CN.UTF-8 \
|
||||
JAVA_HOME=/usr/local/jre1.8.0_202 \
|
||||
PATH=/usr/local/jre1.8.0_202/bin:$PATH \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 复制本地JRE压缩包到镜像中
|
||||
COPY jre-8u202-linux-x64.tar.gz /tmp/
|
||||
|
||||
# 安装必要的系统包并配置环境
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新系统并安装中文语言支持
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
tzdata \
|
||||
locales \
|
||||
fontconfig \
|
||||
fonts-dejavu \
|
||||
fonts-wqy-microhei \
|
||||
ca-certificates \
|
||||
&& \
|
||||
\
|
||||
# 清理apt缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 生成中文本地化配置
|
||||
locale-gen zh_CN.UTF-8 && \
|
||||
locale-gen en_US.UTF-8; \
|
||||
\
|
||||
# 设置系统语言环境
|
||||
update-locale LANG=zh_CN.UTF-8; \
|
||||
\
|
||||
# 解压JRE到/usr/local目录
|
||||
tar -xzf jre-8u202-linux-x64.tar.gz -C /usr/local/ && \
|
||||
\
|
||||
# 删除临时文件
|
||||
rm -f jre-8u202-linux-x64.tar.gz; \
|
||||
\
|
||||
# 创建符号链接以便版本升级时更容易管理
|
||||
ln -sf /usr/local/jre1.8.0_202 /usr/local/jre; \
|
||||
\
|
||||
# 创建全局可执行文件链接
|
||||
update-alternatives --install "/usr/bin/java" "java" "/usr/local/jre/bin/java" 1 && \
|
||||
update-alternatives --install "/usr/bin/javac" "javac" "/usr/local/jre/bin/javac" 1 && \
|
||||
update-alternatives --set java /usr/local/jre/bin/java; \
|
||||
\
|
||||
# 创建字体目录并设置权限
|
||||
mkdir -p /usr/share/fonts/truetype/ && \
|
||||
chmod 755 /usr/share/fonts/truetype/; \
|
||||
\
|
||||
# 更新字体缓存
|
||||
fc-cache -fv; \
|
||||
\
|
||||
# 验证JRE安装
|
||||
java -version && \
|
||||
/usr/local/jre/bin/java -version; \
|
||||
\
|
||||
# 创建非root用户用于运行Java应用
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/esxi -s /bin/bash esxi && \
|
||||
mkdir -p /opt/esxi && \
|
||||
chown -R esxi:esxi /opt/esxi; \
|
||||
\
|
||||
# 设置文件权限
|
||||
chmod -R 755 /usr/local/jre1.8.0_202 && \
|
||||
chown -R root:root /usr/local/jre1.8.0_202
|
||||
|
||||
# 切换到应用目录
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 设置默认用户
|
||||
#USER esxi
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
||||
CMD java -version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["java", "-version"]
|
||||
209
dockerfiles/jre/8u202-utunbu22-dos/deploy.sh
Normal file
209
dockerfiles/jre/8u202-utunbu22-dos/deploy.sh
Normal file
@ -0,0 +1,209 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="jre"
|
||||
VERSION="8u202-ubuntu22-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "jre-8u202-linux-x64.tar.gz" ]; then
|
||||
red "错误: jre-8u202-linux-x64.tar.gz 不存在"
|
||||
echo "请从Oracle官网下载JRE 8u202并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -d "fonts" ]; then
|
||||
yellow "提示: fonts 目录不存在,创建空目录"
|
||||
mkdir -p fonts/
|
||||
yellow "可以放置中文字体文件到 fonts/ 目录以获得更好的中文支持"
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Java版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" java -version; then
|
||||
green "✓ Java测试通过"
|
||||
else
|
||||
red "✗ Java测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} java -version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Ubuntu 22.04 JRE 8u202 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
45
dockerfiles/nginx/nginx1.24-alpine/Dockerfile
Normal file
45
dockerfiles/nginx/nginx1.24-alpine/Dockerfile
Normal file
@ -0,0 +1,45 @@
|
||||
# 使用官方Nginx Alpine基础镜像(更轻量)
|
||||
FROM nginx:1.24-alpine
|
||||
|
||||
# 维护者信息
|
||||
LABEL maintainer="xiaomayicloud@163.com"
|
||||
LABEL description="Nginx 1.24 for Node.js frontend deployment"
|
||||
LABEL version="1.24"
|
||||
|
||||
# 安装必要的工具
|
||||
RUN apk update && \
|
||||
apk add --no-cache \
|
||||
curl \
|
||||
bash \
|
||||
tzdata \
|
||||
&& rm -rf /var/cache/apk/*
|
||||
|
||||
# 设置时区(可选,根据需要修改)
|
||||
ENV TZ=Asia/Shanghai
|
||||
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
|
||||
|
||||
# 创建应用目录
|
||||
RUN mkdir -p /app/dist && \
|
||||
mkdir -p /app/logs && \
|
||||
mkdir -p /app/conf
|
||||
|
||||
# 移除默认的Nginx配置
|
||||
RUN rm -rf /etc/nginx/conf.d/default.conf
|
||||
|
||||
# 复制自定义Nginx配置
|
||||
COPY nginx.conf /etc/nginx/nginx.conf
|
||||
COPY conf.d/ /etc/nginx/conf.d/
|
||||
|
||||
# 复制健康检查脚本
|
||||
COPY healthcheck.sh /usr/local/bin/healthcheck.sh
|
||||
RUN chmod +x /usr/local/bin/healthcheck.sh
|
||||
|
||||
# 暴露端口
|
||||
EXPOSE 80 443
|
||||
|
||||
# 健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --retries=3 \
|
||||
CMD /usr/local/bin/healthcheck.sh
|
||||
|
||||
# 启动Nginx
|
||||
CMD ["nginx", "-g", "daemon off;"]
|
||||
44
dockerfiles/nginx/nginx1.24-alpine/conf.d/app.conf
Normal file
44
dockerfiles/nginx/nginx1.24-alpine/conf.d/app.conf
Normal file
@ -0,0 +1,44 @@
|
||||
server {
|
||||
listen 80;
|
||||
server_name localhost;
|
||||
root /app/dist;
|
||||
index index.html index.htm;
|
||||
|
||||
# 访问日志
|
||||
access_log /app/logs/access.log main;
|
||||
error_log /app/logs/error.log warn;
|
||||
|
||||
# 静态文件缓存
|
||||
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff|woff2|ttf|eot)$ {
|
||||
expires 1y;
|
||||
add_header Cache-Control "public, immutable";
|
||||
add_header Access-Control-Allow-Origin "*";
|
||||
try_files $uri $uri/ =404;
|
||||
}
|
||||
|
||||
# HTML文件不缓存
|
||||
location ~* \.(html|htm)$ {
|
||||
expires -1;
|
||||
add_header Cache-Control "no-store, no-cache, must-revalidate";
|
||||
try_files $uri $uri/ =404;
|
||||
}
|
||||
|
||||
# SPA应用路由处理
|
||||
location / {
|
||||
try_files $uri $uri/ /index.html;
|
||||
}
|
||||
|
||||
# 健康检查端点
|
||||
location /health {
|
||||
access_log off;
|
||||
return 200 "healthy\n";
|
||||
add_header Content-Type text/plain;
|
||||
}
|
||||
|
||||
# 禁止访问隐藏文件
|
||||
location ~ /\. {
|
||||
deny all;
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
}
|
||||
}
|
||||
175
dockerfiles/nginx/nginx1.24-alpine/deploy.sh
Normal file
175
dockerfiles/nginx/nginx1.24-alpine/deploy.sh
Normal file
@ -0,0 +1,175 @@
|
||||
#!/bin/bash
|
||||
|
||||
# 颜色定义
|
||||
RED='\033[0;31m'
|
||||
GREEN='\033[0;32m'
|
||||
YELLOW='\033[1;33m'
|
||||
BLUE='\033[0;34m'
|
||||
NC='\033[0m' # No Color
|
||||
|
||||
# 配置变量
|
||||
IMAGE_NAME="nginx"
|
||||
IMAGE_TAG="1.24-alpine"
|
||||
HARBOR_URL="192.168.10.102:8001" # 替换为你的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为你的项目名
|
||||
HARBOR_USERNAME="deploy" # 从环境变量获取
|
||||
HARBOR_PASSWORD="Harbor20240330" # 从环境变量获取
|
||||
|
||||
# 日志函数
|
||||
log_info() { echo -e "${BLUE}[INFO]${NC} $1"; }
|
||||
log_success() { echo -e "${GREEN}[SUCCESS]${NC} $1"; }
|
||||
log_warning() { echo -e "${YELLOW}[WARNING]${NC} $1"; }
|
||||
log_error() { echo -e "${RED}[ERROR]${NC} $1"; }
|
||||
|
||||
# 检查依赖
|
||||
check_dependencies() {
|
||||
local deps=("docker" "curl")
|
||||
for dep in "${deps[@]}"; do
|
||||
if ! command -v "$dep" &> /dev/null; then
|
||||
log_error "缺少依赖: $dep"
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
# 检查Docker服务
|
||||
check_docker() {
|
||||
if ! docker info > /dev/null 2>&1; then
|
||||
log_error "Docker服务未运行"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建镜像
|
||||
build_image() {
|
||||
log_info "开始构建Nginx镜像..."
|
||||
|
||||
if docker build -t "${IMAGE_NAME}:${IMAGE_TAG}" . ; then
|
||||
log_success "镜像构建成功: ${IMAGE_NAME}:${IMAGE_TAG}"
|
||||
else
|
||||
log_error "镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 添加额外标签(可选)
|
||||
add_additional_tags() {
|
||||
local tags=("latest" "prod" "dev")
|
||||
|
||||
for extra_tag in "${tags[@]}"; do
|
||||
log_info "添加额外标签: ${extra_tag}"
|
||||
docker tag "${IMAGE_NAME}:${IMAGE_TAG}" "${IMAGE_NAME}:${extra_tag}"
|
||||
done
|
||||
}
|
||||
|
||||
# 登录Harbor
|
||||
login_to_harbor() {
|
||||
if [ -z "$HARBOR_USERNAME" ] || [ -z "$HARBOR_PASSWORD" ]; then
|
||||
log_error "Harbor用户名或密码未设置"
|
||||
log_warning "请设置环境变量: HARBOR_USERNAME 和 HARBOR_PASSWORD"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
log_info "登录到Harbor仓库..."
|
||||
if echo "$HARBOR_PASSWORD" | docker login -u "$HARBOR_USERNAME" --password-stdin "$HARBOR_URL"; then
|
||||
log_success "Harbor登录成功"
|
||||
else
|
||||
log_error "Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 打标签
|
||||
tag_image() {
|
||||
local target_tag="${1:-$IMAGE_TAG}"
|
||||
local full_image_name="${HARBOR_URL}/${HARBOR_PROJECT}/${IMAGE_NAME}:${target_tag}"
|
||||
|
||||
log_info "打标签: ${full_image_name}"
|
||||
if docker tag "${IMAGE_NAME}:${target_tag}" "$full_image_name"; then
|
||||
log_success "标签打成功"
|
||||
else
|
||||
log_error "标签打失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像
|
||||
push_image() {
|
||||
local target_tag="${1:-$IMAGE_TAG}"
|
||||
local full_image_name="${HARBOR_URL}/${HARBOR_PROJECT}/${IMAGE_NAME}:${target_tag}"
|
||||
|
||||
log_info "推送镜像: ${full_image_name}"
|
||||
if docker push "$full_image_name"; then
|
||||
log_success "镜像推送成功"
|
||||
else
|
||||
log_error "镜像推送失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup() {
|
||||
log_info "清理本地镜像..."
|
||||
|
||||
# 清理主标签
|
||||
docker rmi "${IMAGE_NAME}:${IMAGE_TAG}" 2>/dev/null || true
|
||||
|
||||
# 清理额外标签
|
||||
local tags=("latest" "prod" "dev")
|
||||
for tag in "${tags[@]}"; do
|
||||
docker rmi "${IMAGE_NAME}:${tag}" 2>/dev/null || true
|
||||
done
|
||||
|
||||
# 清理Harbor标签
|
||||
local harbor_tags=("$IMAGE_TAG" "latest" "prod" "dev")
|
||||
for tag in "${harbor_tags[@]}"; do
|
||||
docker rmi "${HARBOR_URL}/${HARBOR_PROJECT}/${IMAGE_NAME}:${tag}" 2>/dev/null || true
|
||||
done
|
||||
|
||||
log_success "清理完成"
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
log_info "镜像信息:"
|
||||
echo "名称: ${IMAGE_NAME}"
|
||||
echo "版本: ${IMAGE_TAG}"
|
||||
echo "Harbor地址: ${HARBOR_URL}"
|
||||
echo "项目: ${HARBOR_PROJECT}"
|
||||
echo "完整镜像名: ${HARBOR_URL}/${HARBOR_PROJECT}/${IMAGE_NAME}:${IMAGE_TAG}"
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
log_info "====== Nginx镜像构建推送脚本 ======"
|
||||
|
||||
check_dependencies
|
||||
check_docker
|
||||
show_image_info
|
||||
|
||||
# 构建镜像
|
||||
build_image
|
||||
|
||||
# 添加额外标签
|
||||
#add_additional_tags
|
||||
|
||||
# 登录Harbor
|
||||
login_to_harbor
|
||||
|
||||
# 推送所有标签
|
||||
#local tags=("$IMAGE_TAG" "latest" "prod" "dev")
|
||||
local tags=("$IMAGE_TAG")
|
||||
for tag in "${tags[@]}"; do
|
||||
tag_image "$tag"
|
||||
push_image "$tag"
|
||||
done
|
||||
|
||||
# 清理
|
||||
cleanup
|
||||
|
||||
log_success "====== 所有操作完成! ======"
|
||||
log_info "镜像地址: ${HARBOR_URL}/${HARBOR_PROJECT}/${IMAGE_NAME}:${IMAGE_TAG}"
|
||||
}
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
8
dockerfiles/nginx/nginx1.24-alpine/healthcheck.sh
Normal file
8
dockerfiles/nginx/nginx1.24-alpine/healthcheck.sh
Normal file
@ -0,0 +1,8 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Nginx健康检查脚本
|
||||
if curl -f http://localhost/health > /dev/null 2>&1; then
|
||||
exit 0
|
||||
else
|
||||
exit 1
|
||||
fi
|
||||
40
dockerfiles/nginx/nginx1.24-alpine/nginx.conf
Normal file
40
dockerfiles/nginx/nginx1.24-alpine/nginx.conf
Normal file
@ -0,0 +1,40 @@
|
||||
user nginx;
|
||||
worker_processes auto;
|
||||
error_log /var/log/nginx/error.log warn;
|
||||
pid /var/run/nginx.pid;
|
||||
|
||||
events {
|
||||
worker_connections 1024;
|
||||
use epoll;
|
||||
multi_accept on;
|
||||
}
|
||||
|
||||
http {
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
|
||||
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||
'$status $body_bytes_sent "$http_referer" '
|
||||
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||
|
||||
access_log /var/log/nginx/access.log main;
|
||||
|
||||
sendfile on;
|
||||
tcp_nopush on;
|
||||
tcp_nodelay on;
|
||||
keepalive_timeout 65;
|
||||
types_hash_max_size 2048;
|
||||
|
||||
# Gzip压缩配置
|
||||
gzip on;
|
||||
gzip_vary on;
|
||||
gzip_min_length 1024;
|
||||
gzip_types text/plain text/css text/xml text/javascript
|
||||
application/javascript application/xml+rss
|
||||
application/json;
|
||||
|
||||
# 文件上传大小限制
|
||||
client_max_body_size 100M;
|
||||
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
}
|
||||
149
dockerfiles/python/3.9.13-centos8-dos/Dockerfile
Normal file
149
dockerfiles/python/3.9.13-centos8-dos/Dockerfile
Normal file
@ -0,0 +1,149 @@
|
||||
# 使用CentOS 8作为基础镜像
|
||||
FROM centos:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于CentOS 8的Python 3.9.13运行环境" \
|
||||
python.version="3.9.13"
|
||||
|
||||
# 设置环境变量
|
||||
ENV PYTHON_VERSION=3.9.13 \
|
||||
PYTHON_HOME=/usr/local/python3.9.13 \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 第一步:修复CentOS 8的软件源并安装编译工具
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 由于CentOS 8已停止维护,需要修改软件源
|
||||
sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-* && \
|
||||
sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-* && \
|
||||
\
|
||||
# 更新系统并安装必要的开发工具
|
||||
dnf update -y && \
|
||||
dnf install -y \
|
||||
make \
|
||||
gcc \
|
||||
gcc-c++ \
|
||||
kernel-devel \
|
||||
openssl-devel \
|
||||
bzip2-devel \
|
||||
libffi-devel \
|
||||
zlib-devel \
|
||||
readline-devel \
|
||||
sqlite-devel \
|
||||
# 系统工具
|
||||
curl \
|
||||
tar \
|
||||
xz \
|
||||
gzip \
|
||||
git \
|
||||
glibc-langpack-en \
|
||||
shadow-utils \
|
||||
which \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
dnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
echo 'LANG="en_US.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="en_US.UTF-8"' >> /etc/locale.conf;
|
||||
|
||||
# 第二步:验证编译器安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查编译器是否安装成功
|
||||
echo "=== 检查编译工具 ==="; \
|
||||
make --version; \
|
||||
gcc --version; \
|
||||
g++ --version;
|
||||
|
||||
# 添加Python安装包(确保Python-3.9.13.tar.xz在构建上下文)
|
||||
ADD Python-3.9.13.tar.xz /tmp/
|
||||
|
||||
# 第三步:编译和安装Python
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 进入解压后的Python目录
|
||||
cd /tmp/Python-3.9.13 && \
|
||||
\
|
||||
# 配置编译选项
|
||||
./configure \
|
||||
--prefix=${PYTHON_HOME} \
|
||||
--enable-optimizations \
|
||||
--enable-shared \
|
||||
--with-system-ffi \
|
||||
--with-ensurepip=install \
|
||||
&& \
|
||||
\
|
||||
# 编译和安装
|
||||
make -j$(nproc) && \
|
||||
make install && \
|
||||
\
|
||||
# 创建软链接
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python3 && \
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python && \
|
||||
ln -sf ${PYTHON_HOME}/bin/pip3 /usr/bin/pip && \
|
||||
\
|
||||
# 配置动态链接库路径
|
||||
echo "${PYTHON_HOME}/lib" > /etc/ld.so.conf.d/python3.conf && \
|
||||
ldconfig && \
|
||||
\
|
||||
# 清理编译文件和源码
|
||||
cd /tmp && \
|
||||
rm -rf /tmp/Python-3.9.13;
|
||||
|
||||
# 设置全局PATH环境变量
|
||||
ENV PATH=${PYTHON_HOME}/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||
|
||||
# 第四步:验证Python安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查Python版本
|
||||
echo "=== Python版本 ==="; \
|
||||
python3 --version; \
|
||||
python --version; \
|
||||
\
|
||||
# 检查pip版本
|
||||
echo "=== Pip版本 ==="; \
|
||||
pip --version;
|
||||
|
||||
# 第五步:升级pip和安装常用工具
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 升级pip
|
||||
pip install --upgrade pip setuptools wheel && \
|
||||
\
|
||||
# 安装常用Python工具
|
||||
pip install virtualenv;
|
||||
|
||||
# 设置工作目录(Python项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Python应用
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi ${PYTHON_HOME};
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD python3 --version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["python3", "--version"]
|
||||
203
dockerfiles/python/3.9.13-centos8-dos/deploy.sh
Normal file
203
dockerfiles/python/3.9.13-centos8-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="python"
|
||||
VERSION="3.9.13-centos8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "Python-3.9.13.tar.xz" ]; then
|
||||
red "错误: Python-3.9.13.tar.xz 不存在"
|
||||
echo "请从Python官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Python版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" python3 --version; then
|
||||
green "✓ 测试通过"
|
||||
else
|
||||
red "✗ 测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} python3 --version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== CentOS 8 Python 3.9.13 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
162
dockerfiles/python/3.9.13-debian12-dos/Dockerfile
Normal file
162
dockerfiles/python/3.9.13-debian12-dos/Dockerfile
Normal file
@ -0,0 +1,162 @@
|
||||
# 使用 Debian 12 (bookworm-slim) 作为基础镜像
|
||||
FROM debian:bookworm-slim
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Debian的Python 3.9.13运行环境" \
|
||||
python.version="3.9.13"
|
||||
|
||||
# 设置环境变量
|
||||
ENV PYTHON_VERSION=3.9.13 \
|
||||
PYTHON_HOME=/usr/local/python3.9.13 \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8 \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 第一步:安装编译工具和系统依赖
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 配置阿里云Debian镜像源
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm main non-free non-free-firmware" > /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-updates main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian/ bookworm-backports main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
echo "deb http://mirrors.aliyun.com/debian-security bookworm-security main non-free non-free-firmware" >> /etc/apt/sources.list; \
|
||||
\
|
||||
# 更新软件包列表并安装必要的开发工具
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
build-essential \
|
||||
libssl-dev \
|
||||
libbz2-dev \
|
||||
libffi-dev \
|
||||
zlib1g-dev \
|
||||
libreadline-dev \
|
||||
libsqlite3-dev \
|
||||
liblzma-dev \
|
||||
libncursesw5-dev \
|
||||
# 系统工具
|
||||
curl \
|
||||
wget \
|
||||
tar \
|
||||
xz-utils \
|
||||
gzip \
|
||||
git \
|
||||
locales \
|
||||
tzdata \
|
||||
make \
|
||||
gcc \
|
||||
g++ \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
echo "en_US.UTF-8 UTF-8" > /etc/locale.gen; \
|
||||
locale-gen; \
|
||||
update-locale LANG=en_US.UTF-8 LC_ALL=en_US.UTF-8;
|
||||
|
||||
# 第二步:验证编译器安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查编译器是否安装成功
|
||||
echo "=== 检查编译工具 ==="; \
|
||||
make --version; \
|
||||
gcc --version; \
|
||||
g++ --version;
|
||||
|
||||
# 添加Python安装包(确保Python-3.9.13.tar.xz在构建上下文)
|
||||
ADD Python-3.9.13.tar.xz /tmp/
|
||||
|
||||
# 第三步:编译和安装Python
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 进入解压后的Python目录
|
||||
cd /tmp/Python-3.9.13 && \
|
||||
\
|
||||
# 配置编译选项
|
||||
./configure \
|
||||
--prefix=${PYTHON_HOME} \
|
||||
--enable-optimizations \
|
||||
--enable-shared \
|
||||
--with-system-ffi \
|
||||
--with-ensurepip=install \
|
||||
--enable-loadable-sqlite-extensions \
|
||||
&& \
|
||||
\
|
||||
# 编译和安装
|
||||
make -j$(nproc) && \
|
||||
make install && \
|
||||
\
|
||||
# 创建软链接
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/local/bin/python3 && \
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/local/bin/python && \
|
||||
ln -sf ${PYTHON_HOME}/bin/pip3 /usr/local/bin/pip && \
|
||||
\
|
||||
# 配置动态链接库路径
|
||||
echo "${PYTHON_HOME}/lib" > /etc/ld.so.conf.d/python3.conf && \
|
||||
ldconfig && \
|
||||
\
|
||||
# 清理编译文件和源码
|
||||
cd /tmp && \
|
||||
rm -rf /tmp/Python-3.9.13;
|
||||
|
||||
# 设置全局PATH环境变量
|
||||
ENV PATH=${PYTHON_HOME}/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||
|
||||
# 第四步:验证Python安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查Python版本
|
||||
echo "=== Python版本 ==="; \
|
||||
python3 --version; \
|
||||
python --version; \
|
||||
\
|
||||
# 检查pip版本
|
||||
echo "=== Pip版本 ==="; \
|
||||
pip --version;
|
||||
|
||||
# 第五步:升级pip和安装常用工具
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 升级pip
|
||||
pip install --upgrade pip setuptools wheel && \
|
||||
\
|
||||
# 安装常用Python工具
|
||||
pip install virtualenv;
|
||||
|
||||
# 设置工作目录(Python项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Python应用
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 安装bash(Debian slim可能不包含)
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends bash && \
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi ${PYTHON_HOME};
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD python3 --version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["python3", "--version"]
|
||||
203
dockerfiles/python/3.9.13-debian12-dos/deploy.sh
Normal file
203
dockerfiles/python/3.9.13-debian12-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="python"
|
||||
VERSION="3.9.13-debian12-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "Python-3.9.13.tar.xz" ]; then
|
||||
red "错误: Python-3.9.13.tar.xz 不存在"
|
||||
echo "请从Python官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Python版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" python3 --version; then
|
||||
green "✓ 测试通过"
|
||||
else
|
||||
red "✗ 测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} python3 --version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Debian 12 Python 3.9.13 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
150
dockerfiles/python/3.9.13-rocky8-dos/Dockerfile
Normal file
150
dockerfiles/python/3.9.13-rocky8-dos/Dockerfile
Normal file
@ -0,0 +1,150 @@
|
||||
# 使用 RockyLinux 8 最小化镜像作为基础
|
||||
FROM rockylinux:8
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于CentOS 8的Python 3.9.13运行环境" \
|
||||
python.version="3.9.13"
|
||||
|
||||
# 设置环境变量
|
||||
ENV PYTHON_VERSION=3.9.13 \
|
||||
PYTHON_HOME=/usr/local/python3.9.13 \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 第一步:修复CentOS 8的软件源并安装编译工具
|
||||
RUN set -eux; \
|
||||
# 配置国内镜像源加速
|
||||
sed -e 's|^mirrorlist=|#mirrorlist=|g' \
|
||||
-e 's|^#baseurl=http://dl.rockylinux.org/$contentdir|baseurl=https://mirrors.aliyun.com/rockylinux|g' \
|
||||
-i.bak \
|
||||
/etc/yum.repos.d/*.repo && \
|
||||
\
|
||||
# 更新系统并安装必要的开发工具
|
||||
dnf update -y && \
|
||||
dnf install -y \
|
||||
make \
|
||||
gcc \
|
||||
gcc-c++ \
|
||||
kernel-devel \
|
||||
openssl-devel \
|
||||
bzip2-devel \
|
||||
libffi-devel \
|
||||
zlib-devel \
|
||||
readline-devel \
|
||||
sqlite-devel \
|
||||
# 系统工具
|
||||
curl \
|
||||
tar \
|
||||
xz \
|
||||
gzip \
|
||||
git \
|
||||
glibc-langpack-en \
|
||||
shadow-utils \
|
||||
which \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
dnf clean all && \
|
||||
rm -rf /var/cache/dnf; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
echo 'LANG="en_US.UTF-8"' > /etc/locale.conf && \
|
||||
echo 'LC_ALL="en_US.UTF-8"' >> /etc/locale.conf;
|
||||
|
||||
# 第二步:验证编译器安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查编译器是否安装成功
|
||||
echo "=== 检查编译工具 ==="; \
|
||||
make --version; \
|
||||
gcc --version; \
|
||||
g++ --version;
|
||||
|
||||
# 添加Python安装包(确保Python-3.9.13.tar.xz在构建上下文)
|
||||
ADD Python-3.9.13.tar.xz /tmp/
|
||||
|
||||
# 第三步:编译和安装Python
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 进入解压后的Python目录
|
||||
cd /tmp/Python-3.9.13 && \
|
||||
\
|
||||
# 配置编译选项
|
||||
./configure \
|
||||
--prefix=${PYTHON_HOME} \
|
||||
--enable-optimizations \
|
||||
--enable-shared \
|
||||
--with-system-ffi \
|
||||
--with-ensurepip=install \
|
||||
&& \
|
||||
\
|
||||
# 编译和安装
|
||||
make -j$(nproc) && \
|
||||
make install && \
|
||||
\
|
||||
# 创建软链接
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python3 && \
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python && \
|
||||
ln -sf ${PYTHON_HOME}/bin/pip3 /usr/bin/pip && \
|
||||
\
|
||||
# 配置动态链接库路径
|
||||
echo "${PYTHON_HOME}/lib" > /etc/ld.so.conf.d/python3.conf && \
|
||||
ldconfig && \
|
||||
\
|
||||
# 清理编译文件和源码
|
||||
cd /tmp && \
|
||||
rm -rf /tmp/Python-3.9.13;
|
||||
|
||||
# 设置全局PATH环境变量
|
||||
ENV PATH=${PYTHON_HOME}/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||
|
||||
# 第四步:验证Python安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查Python版本
|
||||
echo "=== Python版本 ==="; \
|
||||
python3 --version; \
|
||||
python --version; \
|
||||
\
|
||||
# 检查pip版本
|
||||
echo "=== Pip版本 ==="; \
|
||||
pip --version;
|
||||
|
||||
# 第五步:升级pip和安装常用工具
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 升级pip
|
||||
pip install --upgrade pip setuptools wheel && \
|
||||
\
|
||||
# 安装常用Python工具
|
||||
pip install virtualenv;
|
||||
|
||||
# 设置工作目录(Python项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Python应用
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi ${PYTHON_HOME};
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD python3 --version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["python3", "--version"]
|
||||
203
dockerfiles/python/3.9.13-rocky8-dos/deploy.sh
Normal file
203
dockerfiles/python/3.9.13-rocky8-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="python"
|
||||
VERSION="3.9.13-rocky8-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "Python-3.9.13.tar.xz" ]; then
|
||||
red "错误: Python-3.9.13.tar.xz 不存在"
|
||||
echo "请从Python官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Python版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" python3 --version; then
|
||||
green "✓ 测试通过"
|
||||
else
|
||||
red "✗ 测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} python3 --version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== RockyLinux 8 Python 3.9.13 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
143
dockerfiles/python/3.9.13-ubuntu22-dos/Dockerfile
Normal file
143
dockerfiles/python/3.9.13-ubuntu22-dos/Dockerfile
Normal file
@ -0,0 +1,143 @@
|
||||
# 使用 Ubuntu 22.04 作为基础镜像
|
||||
FROM ubuntu:22.04
|
||||
|
||||
# 设置元数据标签
|
||||
LABEL maintainer="小蚂蚁云团队" \
|
||||
version="1.0" \
|
||||
description="基于Ubuntu 22.04的Python 3.9.13运行环境" \
|
||||
python.version="3.9.13"
|
||||
|
||||
# 设置环境变量
|
||||
ENV PYTHON_VERSION=3.9.13 \
|
||||
PYTHON_HOME=/usr/local/python3.9.13 \
|
||||
TZ=Asia/Shanghai \
|
||||
LANG=en_US.UTF-8 \
|
||||
DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /tmp
|
||||
|
||||
# 第一步:安装编译工具和系统依赖
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 更新软件包列表并安装必要的开发工具
|
||||
apt-get update && \
|
||||
apt-get install -y --no-install-recommends \
|
||||
build-essential \
|
||||
libssl-dev \
|
||||
libbz2-dev \
|
||||
libffi-dev \
|
||||
zlib1g-dev \
|
||||
libreadline-dev \
|
||||
libsqlite3-dev \
|
||||
# 系统工具
|
||||
curl \
|
||||
wget \
|
||||
tar \
|
||||
xz-utils \
|
||||
gzip \
|
||||
git \
|
||||
locales \
|
||||
tzdata \
|
||||
&& \
|
||||
\
|
||||
# 清理缓存以减少镜像大小
|
||||
apt-get clean && \
|
||||
rm -rf /var/lib/apt/lists/*; \
|
||||
\
|
||||
# 配置时区
|
||||
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && \
|
||||
echo $TZ > /etc/timezone; \
|
||||
\
|
||||
# 设置语言环境
|
||||
locale-gen en_US.UTF-8 && \
|
||||
update-locale LANG=en_US.UTF-8 LC_ALL=en_US.UTF-8;
|
||||
|
||||
# 第二步:验证编译器安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查编译器是否安装成功
|
||||
echo "=== 检查编译工具 ==="; \
|
||||
make --version; \
|
||||
gcc --version; \
|
||||
g++ --version;
|
||||
|
||||
# 添加Python安装包(确保Python-3.9.13.tar.xz在构建上下文)
|
||||
ADD Python-3.9.13.tar.xz /tmp/
|
||||
|
||||
# 第三步:编译和安装Python
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 进入解压后的Python目录
|
||||
cd /tmp/Python-3.9.13 && \
|
||||
\
|
||||
# 配置编译选项
|
||||
./configure \
|
||||
--prefix=${PYTHON_HOME} \
|
||||
--enable-optimizations \
|
||||
--enable-shared \
|
||||
--with-system-ffi \
|
||||
--with-ensurepip=install \
|
||||
&& \
|
||||
\
|
||||
# 编译和安装
|
||||
make -j$(nproc) && \
|
||||
make install && \
|
||||
\
|
||||
# 创建软链接
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python3 && \
|
||||
ln -sf ${PYTHON_HOME}/bin/python3.9 /usr/bin/python && \
|
||||
ln -sf ${PYTHON_HOME}/bin/pip3 /usr/bin/pip && \
|
||||
\
|
||||
# 配置动态链接库路径
|
||||
echo "${PYTHON_HOME}/lib" > /etc/ld.so.conf.d/python3.conf && \
|
||||
ldconfig && \
|
||||
\
|
||||
# 清理编译文件和源码
|
||||
cd /tmp && \
|
||||
rm -rf /tmp/Python-3.9.13;
|
||||
|
||||
# 设置全局PATH环境变量
|
||||
ENV PATH=${PYTHON_HOME}/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||
|
||||
# 第四步:验证Python安装
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 检查Python版本
|
||||
echo "=== Python版本 ==="; \
|
||||
python3 --version; \
|
||||
python --version; \
|
||||
\
|
||||
# 检查pip版本
|
||||
echo "=== Pip版本 ==="; \
|
||||
pip --version;
|
||||
|
||||
# 第五步:升级pip和安装常用工具
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 升级pip
|
||||
pip install --upgrade pip setuptools wheel && \
|
||||
\
|
||||
# 安装常用Python工具
|
||||
pip install virtualenv;
|
||||
|
||||
# 设置工作目录(Python项目目录)
|
||||
WORKDIR /opt/apps
|
||||
|
||||
# 创建非root用户用于运行Python应用
|
||||
RUN set -eux; \
|
||||
\
|
||||
# 创建用户和组
|
||||
groupadd -r esxi && \
|
||||
useradd -r -g esxi -d /opt/apps -s /bin/bash esxi && \
|
||||
\
|
||||
# 设置目录权限
|
||||
chown -R esxi:esxi /opt/apps && \
|
||||
chown -R esxi:esxi ${PYTHON_HOME};
|
||||
|
||||
# 设置健康检查
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD python3 --version > /dev/null 2>&1 || exit 1
|
||||
|
||||
# 设置默认启动命令
|
||||
CMD ["python3", "--version"]
|
||||
203
dockerfiles/python/3.9.13-ubuntu22-dos/deploy.sh
Normal file
203
dockerfiles/python/3.9.13-ubuntu22-dos/deploy.sh
Normal file
@ -0,0 +1,203 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# 配置参数
|
||||
IMAGE_NAME="python"
|
||||
VERSION="3.9.13-ubuntu22-dos"
|
||||
HARBOR_REGISTRY="192.168.10.102:8001" # 替换为实际的Harbor地址
|
||||
HARBOR_PROJECT="xiaomayi-base" # 替换为实际的Harbor项目名
|
||||
HARBOR_USERNAME="deploy" # 替换为Harbor用户名
|
||||
HARBOR_PASSWORD="Harbor20240330" # 替换为Harbor密码
|
||||
|
||||
# 完整的镜像标签
|
||||
FULL_IMAGE_NAME="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/${IMAGE_NAME}"
|
||||
TAG_VERSION="${VERSION}"
|
||||
TAG_LATEST="latest"
|
||||
|
||||
# 颜色输出函数
|
||||
red() { echo -e "\033[31m$*\033[0m"; }
|
||||
green() { echo -e "\033[32m$*\033[0m"; }
|
||||
yellow() { echo -e "\033[33m$*\033[0m"; }
|
||||
blue() { echo -e "\033[34m$*\033[0m"; }
|
||||
|
||||
# 检查必要文件
|
||||
check_requirements() {
|
||||
blue "检查构建所需文件..."
|
||||
|
||||
if [ ! -f "Python-3.9.13.tar.xz" ]; then
|
||||
red "错误: Python-3.9.13.tar.xz 不存在"
|
||||
echo "请从Python官网下载并放置在当前目录"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
green "✓ 文件检查完成"
|
||||
}
|
||||
|
||||
# 登录Harbor仓库
|
||||
login_to_harbor() {
|
||||
blue "登录Harbor仓库: ${HARBOR_REGISTRY}"
|
||||
|
||||
if echo "${HARBOR_PASSWORD}" | docker login -u "${HARBOR_USERNAME}" --password-stdin "${HARBOR_REGISTRY}"; then
|
||||
green "✓ Harbor登录成功"
|
||||
else
|
||||
red "✗ Harbor登录失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 构建Docker镜像
|
||||
build_image() {
|
||||
blue "开始构建Docker镜像..."
|
||||
|
||||
local build_cmd=(
|
||||
docker build
|
||||
# --pull
|
||||
# --no-cache
|
||||
-t "${FULL_IMAGE_NAME}:${TAG_VERSION}"
|
||||
# -t "${FULL_IMAGE_NAME}:${TAG_LATEST}"
|
||||
.
|
||||
)
|
||||
|
||||
echo "执行命令: ${build_cmd[*]}"
|
||||
|
||||
if "${build_cmd[@]}"; then
|
||||
green "✓ 镜像构建成功"
|
||||
else
|
||||
red "✗ 镜像构建失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示镜像信息
|
||||
show_image_info() {
|
||||
blue "镜像构建信息:"
|
||||
echo "----------------------------------------"
|
||||
docker images "${FULL_IMAGE_NAME}" --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 显示详细大小信息
|
||||
local image_size=$(docker image inspect "${FULL_IMAGE_NAME}:${TAG_VERSION}" --format='{{.Size}}' | awk '{printf "%.2f MB", $1/1024/1024}')
|
||||
green "镜像大小: ${image_size}"
|
||||
}
|
||||
|
||||
# 测试镜像功能
|
||||
test_image() {
|
||||
blue "测试镜像功能..."
|
||||
|
||||
echo "1. 测试Python版本:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" python3 --version; then
|
||||
green "✓ 测试通过"
|
||||
else
|
||||
red "✗ 测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "2. 测试区域设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" locale; then
|
||||
green "✓ 区域设置测试通过"
|
||||
else
|
||||
red "✗ 区域设置测试失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "3. 测试时区设置:"
|
||||
if docker run --rm "${FULL_IMAGE_NAME}:${TAG_VERSION}" date; then
|
||||
green "✓ 时区测试通过"
|
||||
else
|
||||
red "✗ 时区测试失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 推送镜像到Harbor
|
||||
push_to_harbor() {
|
||||
blue "推送镜像到Harbor仓库..."
|
||||
|
||||
# 推送版本标签
|
||||
if docker push "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 版本标签推送成功: ${TAG_VERSION}"
|
||||
else
|
||||
red "✗ 版本标签推送失败"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# # 推送latest标签
|
||||
# if docker push "${FULL_IMAGE_NAME}:${TAG_LATEST}"; then
|
||||
# green "✓ latest标签推送成功"
|
||||
# else
|
||||
# red "✗ latest标签推送失败"
|
||||
# exit 1
|
||||
# fi
|
||||
}
|
||||
|
||||
# 清理本地镜像
|
||||
cleanup_local() {
|
||||
blue "清理本地镜像..."
|
||||
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" "${FULL_IMAGE_NAME}:${TAG_LATEST}" 2>/dev/null || true
|
||||
green "✓ 本地镜像清理完成"
|
||||
}
|
||||
|
||||
# 验证远程镜像
|
||||
verify_remote_image() {
|
||||
blue "验证远程镜像..."
|
||||
|
||||
# 尝试拉取验证
|
||||
if docker pull "${FULL_IMAGE_NAME}:${TAG_VERSION}"; then
|
||||
green "✓ 远程镜像验证成功"
|
||||
docker rmi "${FULL_IMAGE_NAME}:${TAG_VERSION}" 2>/dev/null || true
|
||||
else
|
||||
red "✗ 远程镜像验证失败"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成使用说明
|
||||
generate_usage() {
|
||||
cat << EOF
|
||||
|
||||
$(green "=== 镜像构建和推送完成 ===")
|
||||
$(blue "镜像名称:") ${FULL_IMAGE_NAME}
|
||||
$(blue "可用标签:") ${TAG_VERSION}, ${TAG_LATEST}
|
||||
|
||||
$(yellow "使用方法:")
|
||||
1. 拉取镜像:
|
||||
docker pull ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
2. 运行测试:
|
||||
docker run --rm ${FULL_IMAGE_NAME}:${TAG_VERSION} python3 --version
|
||||
|
||||
3. 作为基础镜像使用:
|
||||
FROM ${FULL_IMAGE_NAME}:${TAG_VERSION}
|
||||
|
||||
$(green "镜像已成功推送到Harbor仓库!")
|
||||
EOF
|
||||
}
|
||||
|
||||
# 主函数
|
||||
main() {
|
||||
echo "$(blue '=== Ubuntu 22.04 Python 3.9.13 基础镜像构建脚本 ===')"
|
||||
echo "$(blue "目标仓库: ${HARBOR_REGISTRY}")"
|
||||
echo "$(blue "镜像名称: ${IMAGE_NAME}")"
|
||||
echo "$(blue "版本标签: ${VERSION}")"
|
||||
echo "----------------------------------------"
|
||||
|
||||
# 执行步骤
|
||||
check_requirements
|
||||
login_to_harbor
|
||||
build_image
|
||||
show_image_info
|
||||
test_image
|
||||
push_to_harbor
|
||||
cleanup_local
|
||||
verify_remote_image
|
||||
generate_usage
|
||||
|
||||
green "✅ 所有步骤完成!"
|
||||
}
|
||||
|
||||
# 异常处理
|
||||
trap 'red "脚本执行被中断"; exit 1' INT TERM
|
||||
|
||||
# 执行主函数
|
||||
main "$@"
|
||||
BIN
resources/Python-3.9.13.tar.xz
Normal file
BIN
resources/Python-3.9.13.tar.xz
Normal file
Binary file not shown.
BIN
resources/fonts/simsun.ttf
Normal file
BIN
resources/fonts/simsun.ttf
Normal file
Binary file not shown.
BIN
resources/go1.25.1.linux-amd64.tar.gz
Normal file
BIN
resources/go1.25.1.linux-amd64.tar.gz
Normal file
Binary file not shown.
BIN
resources/jdk-17.0.16_linux-x64_bin.tar.gz
Normal file
BIN
resources/jdk-17.0.16_linux-x64_bin.tar.gz
Normal file
Binary file not shown.
BIN
resources/jre-8u202-linux-x64.tar.gz
Normal file
BIN
resources/jre-8u202-linux-x64.tar.gz
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user