用带glibc的alpine镜像制作 自定义版本的oracle jdk和tomcat

简介: 我只能说, 以下这个dockerfile总结了很久, 当然,目前算是个半成品, 但对我极具参考价值!!! 注释里才是技术亮点。
+关注继续查看


我只能说,

以下这个dockerfile总结了很久,

当然,目前算是个半成品,

但对我极具参考价值!!!

注释里才是技术亮点。



# base image

# alpine的openjdk可以直接运行,但oracle jdk却需要glibc。残念。
From harbor.example.com/base/baseos/alpine-glibc:3.7-glibc2.27

# MAINTAINER
MAINTAINER XXX



#相将以下ENV合成一行,减少层数,但无论用不用等号,加斜杠,都没成功。又残念。  
ENV     JAVA_HOME=/usr/local/jdk1.8.0_73 
ENV 	CLASSPATH=$JAVA_HOME/bin 
ENV 	TOMCAT_VERSION=tomcat-8.0.14 
ENV 	CATALINA_HOME=/usr/local/${TOMCAT_VERSION} 
ENV 	PATH=.:${JAVA_HOME}/bin:${CATALINA_HOME}/bin:$PATH


RUN  mkdir -p /xxx/temp/ \
	# 统一tomcat的日志和软件包及配置目录。
        && mkdir -p /xxx/webconfigs/ \
        && mkdir -p /xxx/webapps/ \
        && mkdir -p /xxx/weblogs/ \
        && adduser x1 -D -S\
        && adduser x2 -D -S\
        && adduser x3 -D -S\
        # 加指定gid和uid的用户,主要是内核不支持user namespace,就行将uid和gid和宿主机一致。
        && addgroup -g 1234 -S x4 \
        && adduser  -u 5678 -D -S x4 -G x4 \
        && chown -R x4.x4 /xxx/ /xxx/ \
        && chmod 755 -R /xxx/ /xxx/ \
        # 想在alpine里su,要得这样,alpine基于busybox的。
	&& chmod 4755 /bin/busybox \
	# 这样可以更改root密码。至于万一得已登陆docker,这样行,k8s的dashboard也行的。
	&& echo -e "xxxxxx\nxxxxxx" | passwd root \
	# 清空瘦身jdk大小,可以COPY到docker以后进行,当然也可以在外面瘦身jdk再COPY进docker。
        # && rm -rf /usr/local/jdk1.8.0_73/*src.zip \
        #   /usr/local/jdk1.8.0_73/lib/missioncontrol \
        #   /usr/local/jdk1.8.0_73/lib/visualvm \
        #   /usr/local/jdk1.8.0_73/lib/*javafx* \
        #   /usr/local/jdk1.8.0_73/jre/lib/plugin.jar \
        #   /usr/local/jdk1.8.0_73/jre/lib/ext/jfxrt.jar \
        #   /usr/local/jdk1.8.0_73/jre/bin/javaws \
        #   /usr/local/jdk1.8.0_73/jre/lib/javaws.jar \
        #   /usr/local/jdk1.8.0_73/jre/lib/desktop \
        #   /usr/local/jdk1.8.0_73/jre/plugin \
        #   /usr/local/jdk1.8.0_73/jre/lib/deploy* \
        #   /usr/local/jdk1.8.0_73/jre/lib/*javafx* \
        #   /usr/local/jdk1.8.0_73/jre/lib/*jfx* \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libdecora_sse.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libprism_*.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libfxplugins.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libglass.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libgstreamer-lite.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libjavafx*.so \
        #   /usr/local/jdk1.8.0_73/jre/lib/amd64/libjfx*.so \
         #   /tmp/* /var/cache/apk/* \
         && echo "finished!!!!"



# 尴尬的是,如果内核不够新,这里想以非root访问,那么,USER x4是最后起作用,
# CP过去的总是root的权限,而chown和chmod都会将docker的images增大150m以上。
# 要是docker的软件版本能新点,COPY命令支持chown参数,就棒棒的了。
COPY tomcat-8.0.14 /home/docker/tomcat-8.0.14
COPY jdk1.8.0_73 /home/docker/jdk1.8.0_73


#如何提前在本地,作了这几个文修的,就不用CP了,还能减少几层
# COPY ["./server.xml", "/usr/local/apache-tomcat-8.0.14/conf/server.xml"]
# COPY ["./logging.properties", "/usr/local/apache-tomcat-8.0.14/conf/logging.properties"]
# COPY ["./setenv.sh", "/usr/local/apache-tomcat-8.0.14/bin/setenv.sh"]

WORKDIR ${CATALINA_HOME}

# 要是内核新点,能支持user namespace,就可以将root里的用户映射为宿主机的普通用户了。
# 而不用费尽心机的将docker的用户id,组id与宿主机里的uid,gid进行匹配。
USER x4

EXPOSE 8080

CMD ["catalina.sh", "run"]


目录
相关文章
|
9天前
|
SQL Oracle 关系型数据库
Polar DB-O (兼容 Oracle 语法版本)和Polar DB PostgreSQL 版本概述(二)
Polar DB-O (兼容 Oracle 语法版本)和Polar DB PostgreSQL 版本概述(二)
21 0
|
1月前
|
SQL 人工智能 Oracle
NineData支持全版本的企业级Oracle客户端,现已发布!
Oracle数据库是一款全球领先的关系型数据库管理系统,NineData发布对Oracle数据库的SQL开发支持。开发者可以使用NineData便捷查询云端、本地、多个版本的Oracle数据库。NineData在近期的迭代中提供了对Oracle数据库的支持。具有可视化工具、AI智能优化、SQL智能提示、企业协同等多种强大能力,并且无需安装,登录即可使用,同时在安全性上也为您提供了相当可靠的保障。
302 0
NineData支持全版本的企业级Oracle客户端,现已发布!
|
4月前
|
JSON Oracle 关系型数据库
Oracle 数据库目前版本和支持策略综述
Oracle 数据库的 Long Term 版本和 Innovation 版本
316 0
|
9月前
|
SQL Oracle 关系型数据库
Oracle各种版本下“示例数据库的创建”的创建
Oracle各种版本下“示例数据库的创建”的创建
224 0
|
9月前
|
SQL Oracle 关系型数据库
常见问题:在 Windows 平台的 Oracle 12.1 数据库版本上的 Oracle Home 用户 (Doc ID 2101982.1、Doc ID 1529702.1)
常见问题:在 Windows 平台的 Oracle 12.1 数据库版本上的 Oracle Home 用户 (Doc ID 2101982.1、Doc ID 1529702.1)
124 0
|
Oracle 关系型数据库 Windows
oracle学习27-ora-12154和客户端版本低
oracle学习27-ora-12154和客户端版本低
81 0
oracle学习27-ora-12154和客户端版本低
|
Oracle 关系型数据库 Windows
oracle学习29-检查操作系统版本和查询表中修改数据
oracle学习29-检查操作系统版本和查询表中修改数据
118 0
|
Oracle 关系型数据库 数据库
oracle学习32-plsql版本低需到配置文件中添加配置
oracle学习32-plsql版本低需到配置文件中添加配置
48 0
oracle学习32-plsql版本低需到配置文件中添加配置
|
Oracle 关系型数据库 Linux
oracle学习82-VMware出现配置文件 .vmx 是由VMware产品创建,但该产品与此版 VMware workstation 不兼容,因此无法使用(VMware版本不兼容问题)
oracle学习82-VMware出现配置文件 .vmx 是由VMware产品创建,但该产品与此版 VMware workstation 不兼容,因此无法使用(VMware版本不兼容问题)
259 0
oracle学习82-VMware出现配置文件 .vmx 是由VMware产品创建,但该产品与此版 VMware workstation 不兼容,因此无法使用(VMware版本不兼容问题)
|
Oracle 关系型数据库 数据库
Oracle RAC集群启动与关闭,涵盖所有版本
Oracle RAC集群启动与关闭,涵盖所有版本
603 0
Oracle RAC集群启动与关闭,涵盖所有版本
推荐文章
更多