自定义镜像上传阿里云
一、简介(思维导图)

-
1.Alpine Linux是一个轻型Linux发行版
2.Alpine Linux提供了自己的包管理工具:apk(注意:ubuntu中是apt-get,centos中式yum)
二、基于alpine构建jdk的镜像
1.下载镜像
docker pull alpine:3.10

2.创建并编辑Dockerfile
看图

编辑内容为:
#1.指定基础镜像,并且必须是第一条指令
#FROM alpine:latest
FROM alpine:3.10
#2.指明该镜像的作者和其电子邮件
MAINTAINER xyz "xyz@qq.com"
#3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
WORKDIR /abc
#4.将一些安装包复制到镜像中,语法:ADD/COPY <src>... <dest>
## ADD与COPY的区别:ADD复制并解压,COPY仅复制
## 注意这里的宿主机上的jdk的包必须跟Dockerfile在同一目录下,所以事先需要把jdk-8u221-linux-x64.tar.gz的包复制到跟Dockerfile的同级的目录中
## 这里将jdk的包复制到镜像的工作目录/abc中的jdk目录下,所以最后配置jdk的环境变量应该为/abc/jdk/jdk1.8.0_221
ADD jdk-8u221-linux-x64.tar.gz /abc/jdk
## glibc安装包如果从网络下载速度实在是太慢了,先提前下载这三个到宿主机的跟Dockerfile同级的目录中,然后再从宿主机中复制到镜像中/zking/alpine目录中
COPY glibc-2.29-r0.apk /abc
COPY glibc-bin-2.29-r0.apk /abc
COPY glibc-i18n-2.29-r0.apk /abc
#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
RUN apk update && apk upgrade
#6.运行指定的命令
## \代表命令没有结束
##1.安装ca-certificates证书服务,和wget。
##ca-certificates证书服务是安装glibc前置依赖。wget在alpine精简版的系统里面是没有的,如果要用wget命令下载则必须先安装wget
##2.下载一段公钥并存放到/etc/apk/keys/目录下。
##wget是linux下的ftp/http传输工具,没安装会报错“/bin/sh: wget: not found”,网上例子少安装wget
##3.安装之前的三个glibc(这三个包其实实在/zking/alpine中的,但是指定了工作目录而且没有切换所以可以不指定完整路径)。
##Alpine linux为了精简本身并没有安装太多的常用软件,apk类似于ubuntu的apt-get,用来安装一些常用软V件,其语法如下:apk add bash wget curl git make vim docker
##4.删除缓存里面的所有东西
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 \
&& 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=/abc/jdk/jdk1.8.0_221
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
上传文件

准备工作就完成了,接下来就是创建镜像了。
3.执行Dockerfile创建镜像
docker build -t jdk8:v2.0 .

4.创建并启动容器
基于这个镜像构建个容器
docker run -itd --name webapp01 jdk8:v2.0 /bin/sh

5.进入容器
docker exec -it 容器名字 /bin/sh

6.测试jdk

三、基于alpine构建jre的镜像
1.将jre的jar包上传至服务器中,然后解压


tar -zxvf jre-8u221-linux-x64.tar.gz


编辑内容
#1.指定基础镜像,并且必须是第一条指令
FROM alpine:3.10
#2.指明该镜像的作者和其电子邮件
MAINTAINER xyz "xyz@qq.com"
#3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
WORKDIR /abc
#4.将一些安装包复制到镜像中,语法:ADD/COPY <src>... <dest>
## ADD与COPY的区别:ADD复制并解压,COPY仅复制
## 注意~~~上传的瘦身后的jre
ADD jre1.8.0_221.tar.gz /abc/jre/
## glibc安装包如果从网络下载速度实在是太慢了,先提前下载复制到镜像中
COPY glibc-2.29-r0.apk /abc
COPY glibc-bin-2.29-r0.apk /abc
COPY glibc-i18n-2.29-r0.apk /abc
#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
RUN apk update && apk upgrade
#6.运行指定的命令
## Alpine linux为了精简本身并没有安装太多的常用软件,apk类似于ubuntu的apt-get,
## 用来安装一些常用软V件,其语法如下:apk add bash wget curl git make vim docker
## wget是linux下的ftp/http传输工具,没安装会报错“/bin/sh: wget: not found”,网上例子少安装wget
## ca-certificates证书服务,是安装glibc前置依赖
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 \
&& 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.配置环境变量
## 注意~~~没有jdk啦,直接指向jre
ENV JAVA_HOME=/abc/jre/jre1.8.0_221
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
2.给jre瘦身
2.1 查看jre大小(瘦身前229M)
cd /mengyuan/alpine/jre

du -sh jre1.8.0_221
2.2 进入jre解压后的目录,并执行瘦身命令
cd jre1.8.0_221

进行瘦身命令
#删除文本文件
rm -rf COPYRIGHT LICENSE README release THIRDPARTYLICENSEREADME-JAVAFX.txtTHIRDPARTYLICENSEREADME.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

2.3 返回上级目录,重新打包jre
压缩进行打包
tar -zcf jre1.8.0_221.tar.gz jre1.8.0_221
3.创建并编辑Dockerfile
vi Dockerfile
#1.指定基础镜像,并且必须是第一条指令
FROM alpine:3.10
#2.指明该镜像的作者和其电子邮件
MAINTAINER xyz "xyz@qq.com"
#3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
WORKDIR /abc
#4.将一些安装包复制到镜像中,语法:ADD/COPY <src>... <dest>
## ADD与COPY的区别:ADD复制并解压,COPY仅复制
## 注意~~~上传的瘦身后的jre
ADD jre1.8.0_221.tar.gz /abc/jre/
## glibc安装包如果从网络下载速度实在是太慢了,先提前下载复制到镜像中
COPY glibc-2.29-r0.apk /abc
COPY glibc-bin-2.29-r0.apk /abc
COPY glibc-i18n-2.29-r0.apk /abc
#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
RUN apk update && apk upgrade
#6.运行指定的命令
## Alpine linux为了精简本身并没有安装太多的常用软件,apk类似于ubuntu的apt-get,
## 用来安装一些常用软V件,其语法如下:apk add bash wget curl git make vim docker
## wget是linux下的ftp/http传输工具,没安装会报错“/bin/sh: wget: not found”,网上例子少安装wget
## ca-certificates证书服务,是安装glibc前置依赖
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 \
&& 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.配置环境变量
## 注意~~~没有jdk啦,直接指向jre
ENV JAVA_HOME=/abc/jre/jre1.8.0_221
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
4.执行Dockerfile创建镜像
docker build -t jre:v1.0 .

查看

5.创建并启动容器
webapp02是自己的创建的名字不是命令
docker run -itd --name webapp02 jre:v1.0 /bin/sh

6.进入容器
docker exec -it 容器ID /bin/sh

7.测试jre
java -version

四、自定义镜像上传阿里云
登录阿里云,搜索容器镜像服务,创建一个命名空间。

创建镜像仓库
自己去绑定GitHub账号


点击对应镜像仓库列表右下角的管理:上传和下载镜像的相关命令都在管理里面有详细说明每个人的都不一样,要自己去创建

push(推)镜像
1.将镜像推送到Registry(阿里云的注册地址)
2.上传的时候需要输入密码:这个密码并不是阿里云的登录密码,而是在【访问凭证】里面设置的密码
3.上传成功后再【镜像版本】里面可以看到上传的镜像,然后也可以下载
以下的步骤命令在镜像仓库的管理里的基本信息里有
登录阿里云
sudo docker login --username=阿里云账号 registry.cn-hangzhou.aliyuncs.com

如果忘记密码了可以访问凭证里重新设置密码

修改镜像的名字,让它符合阿里云的规则
sudo docker tag [ImageId] registry.cn-hangzhou.aliyuncs.com/t243yuan/t243:[镜像版本号]

把镜像上传到阿里云,成功后点击对应的管理,在镜像版本里面可以看到刚刚上传的镜像
sudo docker push registry.cn-hangzhou.aliyuncs.com/t243yuan/t243:[镜像版本号]

网页上查看是否上传结果

pull(拉)镜像
1.把刚刚瘦身后的jre镜像和满足阿里云规则的镜像删除,然后重新重阿里云上下载镜像
2.先删除满足阿里云规则的镜像,在删除jre(因为它们之间存在引用关系),不删除也可以,只是避免干扰视线
3.下载
1.登录阿里云
sudo docker login --username=阿里云账号 registry.cn-hangzhou.aliyuncs.com
2.从阿里云上下载镜像
sudo docker pull registry.cn-hangzhou.aliyuncs.com/t243yuan/t243:[镜像版本号]
四、其他
一次性停止并且删除所有容器命令
docker stop ${docker ps -aq}&&docker rm ${docker ps -aq}

225

被折叠的 条评论
为什么被折叠?



