• Pinpoint安装采集docker的springboot


    原文链接:https://www.jianshu.com/p/70de245af566?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

    前言

    在上一篇文章里面介绍了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标签
    <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <configuration>
                        <source>1.8</source>
                        <target>1.8</target>
                    </configuration>
                </plugin>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-antrun-plugin</artifactId>
                    <version>1.8</version>
                    <executions>
                        <execution>
                            <phase>test</phase>
                            <goals>
                                <goal>run</goal>
                            </goals>
                            <configuration>
                                <tasks>
                                    <echo>Using env.test.properties</echo>
                                    <copy todir="${basedir}/target/">
                                        <fileset dir="${basedir}">
                                            <include name="pinpoint-agent-1.8.0.tar.gz"/>
                                            <include name="initrun.sh"/>
                                        </fileset>
                                    </copy>
                                </tasks>
                            </configuration>
                        </execution>
                    </executions>
                </plugin>
                <plugin>
                    <groupId>com.spotify</groupId>
                    <artifactId>docker-maven-plugin</artifactId>
                    <version>1.0.0</version>
                    <configuration>
                        <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
                        <dockerDirectory>src/main/docker</dockerDirectory>
                        <resources>
                            <resource>
                                <targetPath>/</targetPath>
                                <directory>${project.build.directory}</directory>
                                <include>${project.build.finalName}.jar</include>
                                <include>pinpoint-agent-1.8.0.tar.gz</include>
                                <include>initrun.sh</include>
                            </resource>
                        </resources>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    
    • initrun.sh
    #!/usr/bin/env bash
    set -e
    set -x
    
    /sbin/ip route|awk '/default/ { print  $3,"	dockerhost" }' >> /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"]
  • 相关阅读:
    四则运算————javaweb版
    构建之法阅读笔记02
    十一周学习进度条
    软工概论-课堂练习:添加信息
    梦断代码阅读笔记01
    链接doc命令行的mysql的编码问题
    构建之法阅读笔记01
    第十周学习进度条
    web
    sql初——基础
  • 原文地址:https://www.cnblogs.com/fswhq/p/13749598.html
Copyright © 2020-2023  润新知