写点什么

把 pinpoint 编译环境做成 Docker 镜像文件

作者:程序员欣宸
  • 2022 年 4 月 27 日
  • 本文字数:1993 字

    阅读完需:约 7 分钟

把pinpoint编译环境做成Docker镜像文件

欢迎访问我的 GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos


  • 在上一章《Docker下,极速体验编译pinpoint1.6.x分支》我们以最快的速度对 pinpoint1.6.x 分支进行编译构建,由于镜像文件 bolingcavalry/jdk7-mvn339-pinpoint16x-compile:0.0.1 中把 pinpoint 源码、jdk、maven 这些东西都准备好了,甚至编译中所依赖的所有 jar 包都放进了本地仓库(450 兆),使我们可以高效完成编译实战;

  • 今天我们就来回顾一下这个镜像是怎么做的;

编译环境简述

  • 先抛开 Docker 不谈,我们梳理一下编译构建 pinpoint 需要准备哪些东西:


  1. linux 环境,比如:CentOS release 6.7;

  2. 提供 ssh 服务,以便上传下载文件;

  3. jdk1.7;

  4. maven3,例如 maven3.3.9 版本;

  5. pinpoint 源码,git 地址是:https://github.com/naver/pinpoint.git;

  6. pinpoint 源码的 master 目前提交比较活跃,所以建议使用 1.6.x 分支;

  7. 编译前,设置所需的环境变量,如:JAVA_HOME、JAVA_6_HOME、JAVA_7_HOME、JAVA_8_HOME 等;

比较耗时的操作

  • 以下这些步骤相对比较耗时:


  1. git 下载 pinpoint 源码;

  2. 编译过程中,下载依赖的 jar;

镜像规划

  • 我们的镜像主要功能是把前面所说的编译环境搭建好,另外把那两个耗时的操作也做了,所以要把以下材料先准备好:


  1. 基础镜像,用 kinogmt/centos-ssh:6.7,集成了 ssh 服务;

  2. 准备好 jdk1.7 的安装包,构建镜像的时候本地安装;

  3. 提前把 maven3.3.9 安装包下载好,修改 setting 配置,加入阿里云的镜像服务器,构建镜像的时候直接复制到镜像中就行了;

  4. 提前下载好 pinpoint 源码,构建镜像的时候直接复制;

  5. 编译过程中会下载大量 jar 包,如果不提前准备好,编译时会耗费我们大量时间,我的做法是做个在一个干净的容器中做一次编译,这样依赖的 jar 包就保存到该容器的/root/.m2/目录下了,再把这个目录复制出来,制作镜像的时候复制到镜像就好;(不做这一步的话编译要四十多分钟,有了本地 jar 包编译时间缩短在十分钟之内);

  6. 配置好环境变量,这样容器启动后就不用自己手动配置了;

可以在我的 git 下载上述材料

  • 上述材料我已经上传到 git 上,地址是:git@github.com:zq2599/jdk7-mvn339-pinpoint16x-compile.git,如下图:


Dockerfile

  • 接下来可以开始制作 Dockerfile 了,详细内容如下,每行都加了注释,就不多说了:


# Docker image of compile and build pinpoint 1.6.x# VERSION 0.0.1# Author: bolingcavalry
#基础镜像使用kinogmt/centos-ssh:6.7,支持ssh登录FROM kinogmt/centos-ssh:6.7
#作者MAINTAINER BolingCavalry <zq2599@gmail.com>
#定义工作目录ENV WORK_PATH /usr/local/work
#定义jdk1.7的文件名ENV JDK_RPM_FILE jdk-7u71-linux-x64.rpm
#定义JAVA_HOMEENV JAVA_HOME /usr/java/jdk1.7.0_71
#定义编译pinpoint所需的环境变量ENV JAVA_6_HOME $JAVA_HOME
#定义编译pinpoint所需的环境变量ENV JAVA_7_HOME $JAVA_HOME
#定义编译pinpoint所需的环境变量ENV JAVA_8_HOME $JAVA_HOME
#定义maven文件夹名称ENV MAVEN_PACKAGE_NAME apache-maven-3.3.9
#把maven的bin加入PATHENV PATH $PATH:$WORK_PATH/$MAVEN_PACKAGE_NAME/bin
#定义pinpoint文件夹名称ENV PINPOINT_PACKAGE_NAME pinpoint-1.6.x
#定义maven本地仓库路径ENV MAVEN_REPOSITORY_PATH /root/.m2
#定义maven本地仓库文件夹名称ENV MAVEN_REPOSITORY_PACKAGE_NAME repository

#创建工作目录RUN mkdir -p $WORK_PATH
#yum更新#RUN yum -y update
#把分割过的jdk1.7安装文件复制到工作目录COPY ./jdkrpm-* $WORK_PATH/
#用本地分割过的文件恢复原有的jdk1.7的安装文件RUN cat $WORK_PATH/jdkrpm-* > $WORK_PATH/$JDK_RPM_FILE
#本地安装jdk1.7,如果不加后面的yum clean all,就会报错:Rpmdb checksum is invalidRUN yum -y localinstall $WORK_PATH/$JDK_RPM_FILE; yum clean all
#把maven文件夹复制到工作目录COPY ./$MAVEN_PACKAGE_NAME $WORK_PATH/$MAVEN_PACKAGE_NAME
#把pinpoint文件夹复制到工作目录COPY ./$PINPOINT_PACKAGE_NAME $WORK_PATH/$PINPOINT_PACKAGE_NAME
#创建maven仓库的目录RUN mkdir -p $MAVEN_REPOSITORY_PATH
#把maven仓库文件夹复制到本地仓库COPY ./$MAVEN_REPOSITORY_PACKAGE_NAME $MAVEN_REPOSITORY_PATH/$MAVEN_REPOSITORY_PACKAGE_NAME
#删除分割文件RUN rm $WORK_PATH/jdkrpm-*
#删除jdk安装包文件RUN rm $WORK_PATH/$JDK_RPM_FILE
复制代码

制作镜像

  • 在 Dockerfile 文件所在目录下,执行以下命令制作镜像:

docker build -t bolingcavalry/jdk7-mvn339-pinpoint16x-compile:0.0.1 .
复制代码
  • 构建完成后,执行 docker images 命令可以看到刚刚做好的镜像文件,如下图:


  • 上就是 Docker 下 pinpoint 编译环境的制作过程,如果您有 hub.docker.com 的账号,还能用 docker push 命令将这个镜像上传到 hub.docker.com 网站上,方便自己和他人使用;

欢迎关注 InfoQ:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...

发布于: 2022 年 04 月 27 日阅读数: 28
用户头像

搜索"程序员欣宸",一起畅游Java宇宙 2018.04.19 加入

前腾讯、前阿里员工,从事Java后台工作,对Docker和Kubernetes充满热爱,所有文章均为作者原创,个人Github:https://github.com/zq2599/blog_demos

评论

发布
暂无评论
把pinpoint编译环境做成Docker镜像文件_4月月更_程序员欣宸_InfoQ写作社区