1. 概述
在实际项目中,有时官方提供的相关 docker 镜像不能满足企业对于镜像内部安全的要求;所以大型的企业都会构建属于企业内部的中间件的 docker 镜像。
2. 基于Alpine 制作 jre 镜像
-
alpine Linux 简介
Alpine Linux 是一个轻型 Linux 发行版,它不同于通常的 Linux 发行版,Alpin e采用了musl libc 和 BusyBox 以减少系统的体积和运行时的资源消耗。alpine Linux 优点
-
小巧:基于Musl libc 和 Busybox,和 Busybox 一样小巧,最小的 Docker 镜像只有 5MB;
-
安全:面向安全的轻量发行版;
-
简单:提供 APK 包管理工具,软件的搜索、安装、删除、升级都非常方便;
-
适合容器使用:由于小巧、功能完备,非常适合作为容器的基础镜像;
https://pkgs.alpinelinux.org/packages
下面是一些常见 Linux 的官方镜像的容量对比图
先准备构建镜像所需的jre,下载 jre8
https://www.oracle.com/java/technologies/downloads/
https://www.oracle.com/java/technologies/downloads/#java8
-
创建并编辑 Dockerfile
touch Dockerfile
vi Dockerfile
-
在 Dockerfile 文件中添加以下命令
# 1.指定基础镜像,并且必须是第一条指令
FROM alpine:latest
# 2.指明镜像的作者和电子邮件
MAINTAINER huang "huangjinjin@qq.com"
# 3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建该目录
WORKDIR /servers
# 4.将jre安装包复制到镜像中(ADD与COPY的区别:ADD复制并解压,COPY仅复制)
ADD jre-8u321-linux-x64.tar.gz .
# 5.更改 Alpine 的软件源为阿里云,默认从官方源拉取比较慢
RUN echo http://mirrors.aliyun.com/alpine/v3.10/main/ > /etc/apk/repositories && \
echo http://mirrors.aliyun.com/alpine/v3.10/community/ >> /etc/apk/repositories
# 6.运行指定的命令
## Alpine linux 为了精简本身并没有安装太多的常用软件, apk类似于ubuntu的apt-get,
## 用来安装一些常用软件,其语法如下:apk add bash wget curl git make vim docker
## wget是linux下的ftp/http传输工具,没安装会报错“/bin/sh: wget: not found”
## ca-certificates证书服务,是安装glibc前置依赖
RUN apk update && apk upgrade
RUN apk --no-cache add ca-certificates wget \
&& wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub \
&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-2.29-r0.apk \
&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-bin-2.29-r0.apk \
&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-i18n-2.29-r0.apk \
&& apk add glibc-2.29-r0.apk glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk \
&& rm -rf /var/cache/apk/* glibc-2.29-r0.apk glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk
# 7.配置环境变量
ENV JAVA_HOME=/servers/jre1.8.0_321
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
# 容器启动时需要执行的命令
# CMD ["java", "-version"]
glibc 安装包如果直接从 github 下载可能比较慢,可以提前下载,然后通过以下命令直接复制到镜像中
COPY glibc-2.29-r0.apk /servers
COPY glibc-bin-2.29-r0.apk /servers
COPY glibc-i18n-2.29-r0.apk /servers
-
构建镜像
docker build -t alpine-jre8:v1.0 .
-
创建并启动容器
使用命令docker run -it --name 容器名 镜像的id
,创建并启动容器
docker run -it --name jreV1 74d87e3a31e7
或者
docker create -it alpine-jre8:v2.0
docker start 容器ID
# 进入容器
docker exec -it 容器ID /bin/sh
3. 基于 CentOS 制作 jre镜像
-
创建并编辑 Dockerfile
touch Dockerfile
vi Dockerfile
-
在 Dockerfile 文件中添加以下命令
FROM centos:7
MAINTAINER huangjinjin "huangjinjin@qq.com"
WORKDIR /servers/jdk
ADD jre-8u321-linux-x64.tar.gz /servers/jdk
ENV JAVA_HOME=/servers/jdk/jre1.8.0_321
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
CMD ["java", "-version"]
从 Dockerfile 看,基于 centos 构建镜像 Dockerfile 比较简单
-
构建镜像
docker build -t centos-jre8:v1.0 .
可以看出基于 centos 构建的镜像要大不少
-
创建并启动容器
docker run -it --name jreV2 705360865867