操作指南

API 文档

制作容器镜像(openJDK)

最近更新时间:2020-12-02 20:32:47

该任务指导您通过 Spring Cloud 和 Mesh 两种方式制作容器镜像。

如需使用 Tencent KonaJDK 替换 openJDK,请查看 制作容器镜像-KonaJDK 说明。

准备构建材料

Spring Cloud 应用构建材料

1. 简化版本

简化版本的 Dockerfile 不包含文件配置和 JVM 监控功能,仅需要用户替换掉 Dockerfile 中 Spring Cloud 应用 jar 包名称,您也可以先试用 TSF 提供的 Spring Cloud 应用 Demo JAR 包(下载地址)。

注意:

在 Spring Cloud 应用 JAR 包同级目录下编写 Dockerfile。

FROM centos:7
RUN echo "ip_resolve=4" >> /etc/yum.conf
RUN yum update -y && yum install -y java-1.8.0-openjdk
# 设置时区。这对于日志、调用链等功能能否在 TSF 控制台被检索到非常重要。
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo "Asia/Shanghai" > /etc/timezone
ENV workdir /app/
# 下面的 jar 包可替换为您的 Spring Cloud 应用 jar包,注意这个 jar 包要和您的 dockerfile 位于同一级目录
ENV jar provider-demo-0.0.1-SNAPSHOT.jar
COPY ${jar} ${workdir}
WORKDIR ${workdir}
# JAVA_OPTS 环境变量的值为部署组的 JVM 启动参数,在运行时 bash 替换。使用 exec 以使 Java 程序可以接收 SIGTERM 信号。
CMD ["sh", "-ec", "exec java ${JAVA_OPTS} -jar ${jar}"]

2. 使用 JVM 监控功能

如果您希望使用 JVM 监控 功能,则需要在 Dockerfile 中增加 JVM 监控组件 TencentCloudJvmMonitor-1.1.0下载地址),然后在 CMD 命令中启动该组件。

注意:

将 Spring Cloud 应用 JAR 包和 JVM 监控组件放在同级目录下,并在该目录下编写 Dockerfile。

FROM centos:7
RUN echo "ip_resolve=4" >> /etc/yum.conf
RUN yum update -y && yum install -y java-1.8.0-openjdk
# 设置时区。这对于日志、调用链等功能能否在 TSF 控制台被检索到非常重要。
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo "Asia/Shanghai" > /etc/timezone
ENV workdir /app/
# 下面的 jar 包可替换为您的 Spring Cloud 应用 jar 包,注意这个 jar 包要和您的 dockerfile 位于同一级目录
ENV jar provider-demo-0.0.1-SNAPSHOT.jar
COPY ${jar} ${workdir}
WORKDIR ${workdir}
# JVM 监控组件要和您的 Dockerfile 位于同一级目录,并创建 JVM 监控数据采集目录 
ENV agentjar TencentCloudJvmMonitor-1.1.0-RELEASE.jar
COPY ${agentjar} ${workdir}
RUN mkdir -p /data/tsf_apm/monitor/jvm-metrics/
# JAVA_OPTS 环境变量的值为部署组的 JVM 启动参数,在运行时 bash 替换。使用 exec 以使 Java 程序可以接收 SIGTERM 信号。
# 使用 JVM监控功能需要加上 gclog 和 javaagent 的配置, 否则将无法提供 jvm 监控能力
CMD ["sh", "-ec", "exec java -Xloggc:/data/tsf_apm/monitor/jvm-metrics/gclog.log -XX:+PrintGCDateStamps -XX:+PrintGCDetails -verbose:gc -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=8 -XX:GCLogFileSize=50M -javaagent:${workdir}/${agentjar}=hascontroller=true ${JAVA_OPTS} -jar ${jar}"]

3. 使用文件配置

如果您希望使用 TSF 文件配置 功能,则需要在 Dockerfile 中增加文件配置组件 tsf-consul-template-docker.tar.gz下载地址),然后在 CMD 启动命令中启动该组件。

FROM centos:7
RUN echo "ip_resolve=4" >> /etc/yum.conf
RUN yum update -y && yum install -y java-1.8.0-openjdk
# 设置时区。这对于日志、调用链等功能能否在 TSF 控制台被检索到非常重要。
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo "Asia/Shanghai" > /etc/timezone
ENV workdir /app/
# 下面的 jar 包可替换为您的 Spring Cloud 应用 jar包,注意这个 jar 包要和您的 dockerfile 位于同一级目录
ENV jar provider-demo-0.0.1-SNAPSHOT.jar
COPY ${jar} ${workdir}
WORKDIR ${workdir}
# tsf-consul-template-docker 用于文件配置功能,如不需要可注释掉该行
ADD tsf-consul-template-docker.tar.gz /root/
# JAVA_OPTS 环境变量的值为部署组的 JVM 启动参数,在运行时 bash 替换。使用 exec 以使 Java 程序可以接收 SIGTERM 信号。
CMD ["sh", "-ec", "sh /root/tsf-consul-template-docker/script/start.sh; exec java ${JAVA_OPTS} -jar ${jar}"]

私有化版本使用建议:

私有化的 TSF 要支持 stdout 日志,需要在启动命令中将 stdout 及 stderr 重定向到一个文件中。将上文的CMD一行替换成:

RUN mkdir -p /data/tsf_std/stdout/logs
CMD ["sh", "-ec", "exec java ${JAVA_OPTS} -jar ${jar} 2>&1 > /data/tsf_std/stdout/logs/sys_log.log"]

Mesh 应用构建材料

  1. 下载 Mesh 应用 Demo 包:userService.tar.gz
  2. 在该 tar.gz 包同级目录下,编写 Dockerfile 文件:
    FROM centos:7
    RUN mkdir /root/app/
    # 其中 userService.tar.gz 是 Mesh 应用压缩包
    ADD userService.tar.gz /root/app/
    # 设置时区。这对于日志、调用链等功能能否在 TSF 控制台被检索到非常重要。
    RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    RUN echo "Asia/Shanghai" > /etc/timezone
    ENTRYPOINT ["bash","/root/app/userService/start.sh"]

Mesh 应用压缩包解压后的文件目录结构及文件规范参考 Mesh Demo 介绍

使用文件配置功能

如果容器应用需要使用 TSF 文件配置功能,需要修改 Dockerfile,具体使用指引参考 文件配置>前提条件

构建镜像

  1. Dockerfile所在目录执行build命令:
    docker build . -t ccr.ccs.tencentyun.com/tsf_<主账号 ID>/<应用名>:[tag]

其中<主账号 ID>对应用户腾讯云的主账号 ID(注意不是当前登录账号 ID,主账号 ID 可以在腾讯云个人信息页面获取。),<应用名>表示控制台上的应用名。tag为镜像的 tag,用户可自定义。

  1. 命令执行完成后,通过docker image ls查看创建的镜像。
目录