IDEA 下如何修改 Elasticsearch 源码

以下所有过程以mac操作系统下(macOS 10.13.6)为例进行。

环境准备

安装jdk10

因为es需要高版本jdk进行开发,所以我们直接安装jdk10。

前往 http://www.oracle.com/technetwork/java/javase/downloads/jdk10-downloads-4416644.html ,直接下载安装mac的dmg版本即可。

jdk8和jdk10并存

如果平时开发用的jdk8,为了不影响之后使用,jdk8和jdk10将会同时存在。如果之前没用过java低版本请忽略。在 .bash_profile 中设置如下:

export JAVA8_HOME=$(/usr/libexec/java_home -v 1.8)
export JAVA10_HOME=$(/usr/libexec/java_home -v 10)
# 默认为jdk8
export JAVA_HOME=$JAVA8_HOME
# 随时切换jdk8 和jdk10
alias jdk8="export JAVA_HOME=$JAVA8_HOME"
alias jdk10="export JAVA_HOME=$JAVA10_HOME"

其他操作系统与mac不同,请自行修改jdk配置。

IDEA开发准备

idea

自行下载宇宙第一IDE,我们这里使用的是IntelliJ IDEA 2018.2 (Ultimate Edition),不同版本应该影响不大。

建议将idea的内存调大,因为es项目有点大。

下载ES源码

我们以es 6.2.4为例,直接在github上下载es源码即可。
https://github.com/elastic/elasticsearch/releases/tag/v6.2.4

解压到随意位置即可。

gradle操作

es 6.2.4 采用了宇宙第一自动化建构工具 gradle,相比maven会好用很多。

1. 修改maven源

首先,我们修改maven仓库源,打开源码根目录下的 build.gradle (相当于maven的pom.xml,但是功能强大,用法简单,如果用maven实现里面的功能会无比复杂):

# 35行(import结束后)增加以下代码
allprojects {
    repositories {
        maven{ url 'http://maven.aliyun.com/nexus/content/groups/public/'}
    }
}
2. 生成idea文件

为了idea能修改编译源码,需要执行 ./gradlew idea (windows下为 gradlew.bat idea),这里会经过漫长的过程,如果不换maven源的话,将几个小时。

idea打开源码

idea中直接open刚操作的es源码文件夹,右下角提示`import gradle
project`,点击后弹出如下

IDEA 下如何修改 Elasticsearch 源码

如图选择jdk10,点击ok。

开始自动编译java源码,如下图红色框。
IDEA 下如何修改 Elasticsearch 源码

首次build,这个过程会比较慢,因为要额外下载jar包等。

运行源码

直接在idea中运行

打开文件工程根目录/server/src/main/org/elasticsearch/bootstrap/Elasticsearch.java,右键 Run Elasticsearch.main(),运行main方法。

提示报错

IDEA 下如何修改 Elasticsearch 源码

首先在项目根目录下创建3个文件夹

  • ./home/conf
  • ./home/plugins
  • ./home/modules

然后前往es官网下载一个binary版本的es6.2.4,将其中的conf全部复制到 ./home/conf,将全部的 modules 复制到./home/modules

在下图中增加jvm参数:
IDEA 下如何修改 Elasticsearch 源码

-Des.path.conf=/Users/xunjian/Desktop/elasticsearch-6.2.4/home/config
-Des.path.home=/Users/xunjian/Desktop/elasticsearch-6.2.4/home
-Dlog4j2.disable.jmx=true

并勾选 包含provide scope的jar。

IDEA 下如何修改 Elasticsearch 源码

然后运行报错:

org.elasticsearch.bootstrap.StartupException: java.security.AccessControlException: access denied ("java.lang.RuntimePermission" "createClassLoader")
    at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:125) ~[main/:?]
    at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:112) ~[main/:?]
    at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86) ~[main/:?]
    at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124) ~[main/:?]
    at org.elasticsearch.cli.Command.main(Command.java:90) ~[main/:?]
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:92) ~[main/:?]
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:85) ~[main/:?]
Caused by: java.security.AccessControlException: access denied ("java.lang.RuntimePermission" "createClassLoader")

解决方法:
home/config 新建 java.policy 文件,填入

grant {
    permission java.lang.RuntimePermission "createClassLoader";
};

之前修改过的jvm参数中再增加一个

-Djava.security.policy=/Users/xunjian/Desktop/elasticsearch-6.2.4/home/config/java.policy

启动:不报错,正常启动。

修改源码

做个小小的例子,在 server/src/main/java/org/elasticsearch/action/main/MainResponse.java 中修改119行左右为

builder.field("tagline", "Hello ! 寻剑的ES  ^_^");

重新再idea中启动主函数,访问 http://localhost:9200/ 得到
IDEA 下如何修改 Elasticsearch 源码

Debug

直接用debug模式启动即可,然后随时添加断点和减少断点。以刚才我们修改的文件为例,增加两个断点:
IDEA 下如何修改 Elasticsearch 源码

浏览器访问网页,在idea中可方便的debug
IDEA 下如何修改 Elasticsearch 源码

上一篇:android学习之volley框架(网络)


下一篇:Tablestore入门手册--表(Table)管理