关闭

Docker下,pinpoint环境搭建

标签: dockerpinpoint
481人阅读 评论(0) 收藏 举报
分类:

原文地址:http://blog.csdn.net/boling_cavalry/article/details/78448564
在上一章《Docker下,极速体验pinpoint1.6.3》中,我们快速体验了pinpoint的监控和调用链跟踪的服务,本章我们一起来了解pinpoint环境的搭建过程,实战制作pinpoint服务端和客户端的镜像,让今后的部署过程更简单快捷。

pinpoint-server,材料列表

要搭建pinpoint-server,下面这些材料要准备好:
1. linux操作系统,推荐centos6.7;
2. ssh服务,方便后期登录操作;
3. jdk1.8,例如:jdk1.8.0_144;
4. hbase,推荐1.2.6;
5. tomcat,推荐8.0.36,里面的ROOT目录放置了pinpoint-collector包;
6. tomcat,推荐8.0.36,里面的ROOT目录放置了pinpoint-web包;
7. hbase初始化脚本;

开始准备pinpoint-server的材料

制作pinpoint-server所需的材料我已经全部上传到git上,欢迎大家下载,地址是:git@github.com:zq2599/pinpoint163-server.git

下面说一下当初是如何准备这些材料的:

关于1、2,有现成的镜像满足我们的要求:kinogmt/centos-ssh:6.7,系统是centos6.7,集成了ssh服务,root账号的密码是password;
关于3,下载好jdk1.8.0_144安装包,制作镜像文件的时候直接本地安装;
关于4,下载好hbase1.2.6安装包,制作镜像文件的时候复制过来即可;
关于5,把tomcat8.0.36的安装包从官网下载下来,解压后,将pinpoint-collector.war解压开,将里面的内容复制到tomcat的webapps/ROOT目录下,另外记得修改tomcat/conf/server.xml中的端口,例如8080改为18080,8009改为18009;
关于6,修改方法和5的一样,解压的是pinpoint-web.war,并且tomcat的端口不要和5的冲突了,我这边是将8080改为28080;
关于7,从pinpoint源码中找到hbase-create.hbase这个文件,制作镜像的时候直接复制过去就行了;

pinpoint-server镜像的Dockerfile

关于镜像文件的Dockerfile,如下所示,关键位置都加了注释,就不多说了:

# Docker image of pinpoint server
# VERSION 0.0.1
# Author: bolingcavalry

#基础镜像使用kinogmt/centos-ssh:6.7,这里面已经装好了ssh,密码是password
FROM kinogmt/centos-ssh:6.7

#作者
MAINTAINER BolingCavalry <zq2599@gmail.com>

#定义工作目录
ENV WORK_PATH /usr/local/work

#定义jdk1.8的文件夹
ENV JDK_PACKAGE_FILE jdk1.8.0_144

#定义jdk1.8的文件名
ENV JDK_RPM_FILE jdk-8u144-linux-x64.rpm

#定义hbase文件名
ENV HBASE_PACKAGE_NAME hbase-1.2.6

#定义collector文件夹名
ENV COLLECTOR_PACKAGE_NAME tomcat-collector

#定义web文件夹名
ENV WEB_PACKAGE_NAME tomcat-web

#定义pinpoint的hbase初始化数据脚本名称
ENV PINPOINT_HBASE_INIT_DATA_NAME hbase-create.hbase

#yum更新
#RUN yum -y update

#把分割过的jdk1.8安装文件复制到工作目录
COPY ./jdkrpm-* $WORK_PATH/

#用本地分割过的文件恢复原有的jdk1.8的安装文件
RUN cat $WORK_PATH/jdkrpm-* > $WORK_PATH/$JDK_RPM_FILE

#本地安装jdk1.8,如果不加后面的yum clean all,就会报错:Rpmdb checksum is invalid
RUN yum -y localinstall $WORK_PATH/$JDK_RPM_FILE; yum clean all

#把hbase文件夹复制到工作目录
COPY ./$HBASE_PACKAGE_NAME $WORK_PATH/hbase

#把collector文件夹复制到工作目录
COPY ./$COLLECTOR_PACKAGE_NAME $WORK_PATH/$COLLECTOR_PACKAGE_NAME

#把web文件夹复制到工作目录
COPY ./$WEB_PACKAGE_NAME $WORK_PATH/$WEB_PACKAGE_NAME

#把pinpoint的初始化数据文件复制到工作目录
COPY ./$PINPOINT_HBASE_INIT_DATA_NAME $WORK_PATH/

#删除jdk分割文件
RUN rm $WORK_PATH/jdkrpm-*

#删除jdk安装包文件
RUN rm $WORK_PATH/$JDK_RPM_FILE

#赋读权限
RUN chmod a+r $WORK_PATH/hbase/conf/hbase-env.sh

#赋读权限
#RUN chmod a+r $WORK_PATH/hbase/conf/hbase-site.xml

#配置hostname
RUN echo HOSTNAME=master>>/etc/sysconfig/network

#定义环境变量
ENV JAVA_HOME=/usr/java/$JDK_PACKAGE_FILE/
ENV HBASE_HOME=$WORK_PATH/hbase/
ENV PATH=$JAVA_HOME/bin:$HBASE_HOME/bin:$PATH

EXPOSE 60010
EXPOSE 18080
EXPOSE 28080

在Dockerfile所在目录下执行以下命令可以构建本地镜像,上述所有材料也要放在这个目录:

docker build -t bolingcavalry/centos67-hbase126-pinpoint163-server:0.0.1

pinpoint-agent,材料列表

  1. linux操作系统,无特殊要求;
  2. tomcat,例如:7.0.77;
  3. jdk1.8;
  4. 修改tomcat-users.xml的配置,添加账号信息,使tomcat支持在线部署应用;
  5. pinpoint-agent包;
  6. tomcat的catalina.sh修改,添加pinpoint相关参数;

开始准备pinpoint-agent的材料

制作pinpoint-agent所需的材料我已经全部上传到git上,欢迎大家下载,地址是:git@github.com:zq2599/pinpoint163-agent.git

下面说一下当初是如何准备这些材料的:

关于1、2,tomcat的官方镜像就满足我们的要求:tomcat:7.0.77-jre8;
关于3,下载好jdk1.8.0_144安装包,制作镜像文件的时候直接本地安装;
关于4,准备一个修改好的tomcat-user.xml文件,制作镜像的时候用力来覆盖掉原本tomcat/conf目录下的同名文件即可;
关于5,将编译好的pinpoint-agent文件夹准备好,制作镜像的时候复制过去即可,注意pinpoint.config文件的内容要修改,profiler.collector.ip对应的值是pinpoint-server对应的link参数的alias;
关于6,准备一个修改好的catalina.sh文件,制作镜像的时候用力来覆盖掉原本tomcat/bin目录下的同名文件即可,和原有的catalina.sh相比,增加了以下内容:

CATALINA_OPTS="$CATALINA_OPTS -javaagent:/usr/local/work/pinpoint-agent-1.6.3/pinpoint-bootstrap-1.6.3-SNAPSHOT.jar"
CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.agentId=$PINPOINT_AGENT_ID"
CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.applicationName=$PINPOINT_APPLICATION_NAME"

pinpoint-agent镜像的Dockerfile

关于镜像文件的Dockerfile,如下所示,关键位置都加了注释,就不多说了:

# docker image for pinpoint agent
# VERSION 0.0.1
# Author: bolingcavalry

#基础镜像
FROM tomcat:7.0.77-jre8

#作者
MAINTAINER BolingCavalry <zq2599@gmail.com>

#定义工作目录
ENV WORK_PATH /usr/local/tomcat/conf

#定义catalina.sh文件目录
ENV CATALINA_PATH /usr/local/tomcat/bin

#定义agent工作目录
ENV AGENT_WORK_PATH /usr/local/work

#定义agent文件夹名称
ENV AGENT_PACKAGE_NAME pinpoint-agent-1.6.3

#定义要替换的文件名
ENV USER_CONF_FILE_NAME tomcat-users.xml

#定义要替换的server.xml文件名
ENV SERVER_CONF_FILE_NAME server.xml

#定义要替换的catalina.sh文件名
ENV CATALINA_FILE_NAME catalina.sh

#删除原文件tomcat-users.xml
RUN rm $WORK_PATH/$USER_CONF_FILE_NAME

#复制文件tomcat-users.xml
COPY  ./$USER_CONF_FILE_NAME $WORK_PATH/

#删除原文件server.xml
RUN rm $WORK_PATH/$SERVER_CONF_FILE_NAME

#复制文件server.xml
COPY  ./$SERVER_CONF_FILE_NAME $WORK_PATH/

#删除原文件catalina.sh
RUN rm $CATALINA_PATH/$CATALINA_FILE_NAME

#复制文件catalina.sh
COPY  ./$CATALINA_FILE_NAME $CATALINA_PATH/

#创建agent文件所在目录
RUN mkdir $AGENT_WORK_PATH

#把collector文件夹复制到工作目录
COPY ./$AGENT_PACKAGE_NAME $AGENT_WORK_PATH/$AGENT_PACKAGE_NAME

在Dockerfile所在目录下执行以下命令可以构建本地镜像,上述所有材料也要放在这个目录:

docker build -t bolingcavalry/centos67-pinpoint163-agent:0.0.1

以上就是制作pinpoint-sever和pinpoint-agent镜像的过程,用这样的镜像,结合上一章《Docker下,极速体验pinpoint1.6.3》的配置和启动,就能轻松构建一个完整的pinpoint环境;

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

docker构建部署pinpoint

前提: 1.hbase+zookeeper 2.hbase创建pp的表 表文件 ./hbase shell hbase-create.hbase 3.git官网下载1.6的三个包,注意开个la...
  • jinzhencs
  • jinzhencs
  • 2017-01-11 18:20
  • 2125

docker(16):使用 pinpoint 进行微服务数据统计

1,关于pinpointPinpoint 是用 Java 编写的 APM(应用性能管理)工具,用于大规模分布式系统。Pinpoint 提供了一个解决方案,以帮助分析系统的总体结构以及分布式应用程序的组...
  • freewebsys
  • freewebsys
  • 2017-07-19 12:51
  • 1015

pinpoint 安装部署

pinpoint 安装部署 阅读目录 1. 环境配置     1.1 获取需要的依赖包     1.2 配置jdk1.7 2. 安装Hbase     2.1 解压H...
  • u013793732
  • u013793732
  • 2017-03-19 15:15
  • 1564

PinPoint采集器部署、配置Tomcat和Dubbo服务

PinPoint关于采集器的部署,和Tomcat的配置,网上教程很多,这里做一个简单的概述。但是关于Dubbo服务的配置,网上搜到的信息非常少,试了全部的博客,包括终端运行java -javaagen...
  • xiaozhuanddapang
  • xiaozhuanddapang
  • 2017-07-04 00:41
  • 3509

PinPoint使用教程

这篇博客,应该是是目前为止,百度上能搜到的关于PinPoint使用教程中最详细的一份答案了。为什么这样说呢,因为我不想写PinPoint使用教程的,后来百度上搜了好久,搜烦了,一怒之下,自己出了一片最...
  • xiaozhuanddapang
  • xiaozhuanddapang
  • 2017-07-03 23:51
  • 4020

hadoop_Hbase_pinpoint 环境搭建

**hadoop_Hbase_pinpoint 环境搭建一、简介 Pinpoint is an open source APM (Application Performance Management...
  • maxam0128
  • maxam0128
  • 2016-01-12 20:27
  • 2979

基于docker的caffe环境搭建与使用示例

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上。因此,Docker给应用提供了一个从开发到上线均一致的代码环...
  • elaine_bao
  • elaine_bao
  • 2016-11-10 20:18
  • 6446

史上最简单Android源码编译环境搭建方法(基于Docker)

利用Docker镜像确实可以简化编译环境的配置,现在Docker的用处还是挺多的,例如TensorFlow也可以在Docker上玩。有史以来,Android源码编译环境的搭建始终是一件麻烦事儿。网上有...
  • offbye
  • offbye
  • 2017-03-08 22:01
  • 2367

实战docker运行环境搭建

本文从实战的角度介绍了笔者作为一个初学者,如何一步步地搭建起docker运行环境并启动虚拟机镜像,同时说明了如何在启动的虚拟机中安装常用软件。
  • greatfeather
  • greatfeather
  • 2017-01-24 16:13
  • 2241

Docker下dubbo开发,三部曲之二:本地环境搭建

docker下,本地搭建dubbo环境
  • boling_cavalry
  • boling_cavalry
  • 2017-05-18 11:09
  • 2135
    个人资料
    • 访问:85896次
    • 积分:1679
    • 等级:
    • 排名:千里之外
    • 原创:82篇
    • 转载:0篇
    • 译文:0篇
    • 评论:42条
    博客专栏
    最新评论