本文档用于指导开发者,在本地开发环境中编译工程。
因为工程结构和代码依赖会随版本变化,如果读者熟悉travis-ci,则可直接参考.travis.yml
工程使用Git Submodule,所以不建议使用GitHub的tag和release页面的源码下载,来编译工程
- 准备环境: git, jdk8,Maven
git clone https://github.com/apache/incubator-skywalking.git
cd incubator-skywalking/
- 切换到tag
git checkout [tagname]
(可选,当需要编译发行版本时,请是切换到指定分支) git submodule init
git submodule update
- 执行
mvn clean package -DskipTests
- 生成包在
/dist
目录下(.tar.gz是linux环境,.zip是windows环境)
- 准备环境: jdk8,Maven
- 执行
mvn clean package -DskipTests
- 生成包在
/dist
目录下(.tar.gz是linux环境,.zip是windows环境)
上述步骤在命令行中,能够很好的编译工程,但导入到编译器中的工程依然会有一些报错,我们需要进行几步简单的操作。
- 在IntelliJ Terminal中,执行
mvn compile -Dmaven.test.skip=true
进行编译 - 设置gRPC的自动生成代码目录,为源码目录
- apm-protocol/apm-network/target/generated-sources/protobuf目录下的
grpc-java
和java
目录 - apm-collector/apm-collector-remote/apm-remote-grpc-provider/target/generated-sources/protobuf目录下的
grpc-java
和java
目录
为了遵守Apache关于协议(License)的相关要求,不符合Apache相关要求的类库所对应的Plugin不会自动编译。如需编译对应的插件,
需要手动下载驱动或类库,并将文件拷贝到ci-dependencies/
中,运行mvn package
进行编译。
ci-dependencies/
下对应的类库文件名为:
- resin-3.0.9.jar
- resin-4.0.41.jar
- ojdbc14-10.2.0.4.0.jar
如果在编译apm-webapp时碰到下载包失败问题,可以将apm-webapp中pom.xml中npm源地址修改为淘宝的源,在中国的访问速度可以大大提高.
<arguments>install --registry=https://registry.npmjs.org/</arguments>
修改为
<arguments>install --registry=https://registry.npm.taobao.org/</arguments>