前言
在上一篇文章里面介紹了pinpoint的基礎(chǔ)安裝流程徐鹤,雖然遇到了一些問題阎抒,后續(xù)總算完成了安裝部署可以在正式環(huán)境中使用沦辙,也采集到了許多鏈路信息灾炭,對于分布式微服務(wù)盛行的今天確實(shí)是一個(gè)不可多得的利器茎芋。講到了微服務(wù)就離不開docker了,docker因其環(huán)境無關(guān)性蜈出、隔離性極大的方便了devops田弥,那么如何使用pinpoint采集docker中的數(shù)據(jù)就是一個(gè)必須要解決的問題了。
docker介紹
首先要對docker有一個(gè)基本概念铡原,docker是基于liunx container為基礎(chǔ)實(shí)現(xiàn)的一個(gè)應(yīng)用容器偷厦,java 應(yīng)用運(yùn)行在docker中就類似于運(yùn)行在當(dāng)前服務(wù)器的一個(gè)虛擬機(jī)上,最主要的就是文件隔離和網(wǎng)絡(luò)隔離燕刻,這個(gè)會(huì)是我們采集中遇到的最大問題沪哺。
pinpoint-agent docker安裝
介紹完docker接下來就是如果讓java程序運(yùn)行到docker中,具體操作步驟如下
- maven打包的時(shí)候使用docker-maven-plugin就可以完成docker鏡像的生成
- 主要的修改點(diǎn)就在于Dockerfile上酌儒,通過打包實(shí)現(xiàn)pinpoint agent的安裝辜妓,同時(shí)采集到數(shù)據(jù)之后可以發(fā)送到采集端。
- 一般的做法是在dockerfile中使用命令遠(yuǎn)端下載pinpopint agent忌怎,本次使用本地的pinpoint-agent copy到docker容器中使用不進(jìn)行網(wǎng)絡(luò)下載籍滴。做法是修改pom.xml將pinpoint-agent.tar.gz和initrun.sh copy到target目錄中。
- 由于docker是獨(dú)立網(wǎng)絡(luò)榴啸,當(dāng)需要調(diào)用同服務(wù)器的采集網(wǎng)絡(luò)時(shí)孽惰,需要網(wǎng)關(guān)地址增加到docker的hosts文件中
- mvn打包命令:
mvn package -Dmaven.test.skip=true docker:build - docker啟動(dòng)命令:
docker run -p 7079:7079 -t springboot/demo
相關(guān)文件
- pom.xml build標(biāo)簽
<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,"\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"]