Pinpoint安装使用采集docker中的springboot

前言

在上一篇文章里面介绍了pinpoint的基础安装流程,虽然遇到了一些问题,后续总算完成了安装部署可以在正式环境中使用,也采集到了许多链路信息,对于分布式微服务盛行的今天确实是一个不可多得的利器。讲到了微服务就离不开docker了,docker因其环境无关性、隔离性极大的方便了devops,那么如何使用pinpoint采集docker中的数据就是一个必须要解决的问题了。

docker介绍

首先要对docker有一个基本概念,docker是基于liunx container为基础实现的一个应用容器,java 应用运行在docker中就类似于运行在当前服务器的一个虚拟机上,最主要的就是文件隔离和网络隔离,这个会是我们采集中遇到的最大问题。

pinpoint-agent docker安装

介绍完docker接下来就是如果让java程序运行到docker中,具体操作步骤如下

  1. maven打包的时候使用docker-maven-plugin就可以完成docker镜像的生成
  2. 主要的修改点就在于Dockerfile上,通过打包实现pinpoint agent的安装,同时采集到数据之后可以发送到采集端。
  3. 一般的做法是在dockerfile中使用命令远端下载pinpopint agent,本次使用本地的pinpoint-agent copy到docker容器中使用不进行网络下载。做法是修改pom.xml将pinpoint-agent.tar.gz和initrun.sh copy到target目录中。
  4. 由于docker是独立网络,当需要调用同服务器的采集网络时,需要网关地址增加到docker的hosts文件中
  5. mvn打包命令:
    mvn package -Dmaven.test.skip=true docker:build
  6. docker启动命令:
    docker run -p 7079:7079 -t springboot/demo

相关文件

  • pom.xml build标签

        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                
                    1.8
                    1.8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
            
            
                org.apache.maven.plugins
                maven-antrun-plugin
                1.8
                
                    
                        test
                        
                            run
                        
                        
                            
                                Using env.test.properties
                                
                                    
                                        
                                        
                                    
                                
                            
                        
                    
                
            
            
                com.spotify
                docker-maven-plugin
                1.0.0
                
                    ${docker.image.prefix}/${project.artifactId}
                    src/main/docker
                    
                        
                            /
                            ${project.build.directory}
                            ${project.build.finalName}.jar
                            pinpoint-agent-1.8.0.tar.gz
                            initrun.sh
                        
                    
                
            
        
    
  • initrun.sh
#!/usr/bin/env bash
set -e
set -x

/sbin/ip route|awk '/default/ { print  $3,"\tdockerhost" }' >> /etc/hosts
java -javaagent:/assets/pinpoint-agent/pinpoint-bootstrap-1.8.0.jar -Dpinpoint.agentId=springbootdemo -Dpinpoint.applicationName=springbootdemo -Djava.security.egd=file:/dev/./urandom -jar /app.jar
  • Dockerfile
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD demo-0.0.1-SNAPSHOT.jar app.jar
COPY pinpoint-agent-1.8.0.tar.gz /pp_agent/
ADD initrun.sh initrun.sh
RUN cd /pp_agent \
    && mkdir -p /assets/pinpoint-agent \
    && gunzip pinpoint-agent-1.8.0.tar.gz \
    && tar -xf pinpoint-agent-1.8.0.tar -C /assets/pinpoint-agent \
    && rm pinpoint-agent-1.8.0.tar \
    && sed -i "s/profiler.collector.ip=127.0.0.1/profiler.collector.ip=dockerhost/g" /assets/pinpoint-agent/pinpoint.config
ENTRYPOINT ["sh","/initrun.sh"]

你可能感兴趣的:(Pinpoint安装使用采集docker中的springboot)