开发者社区> 寻剑> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

IDEA 下如何修改 Elasticsearch 源码

简介: 使用jdk10在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`,点击后弹出如下

image

如图选择jdk10,点击ok。

开始自动编译java源码,如下图红色框。
image

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

运行源码

直接在idea中运行

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

提示报错

image

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

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

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

在下图中增加jvm参数:
image

-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。

image

然后运行报错:

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/ 得到
image

Debug

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

浏览器访问网页,在idea中可方便的debug
image

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
去了家新公司,技术总监不让用 IntelliJ IDEA!想离职了
最近有个小伙伴微信和我说,新去的一家公司,技术团队全部规定要用的 Eclipse 开发,技术总监不让用 IntelliJ IDEA,付费也不行,说想离职了,问我该怎么办。 首先听到这件事情的时候,我表示十分理解该公司技术总监的决定,虽然我没有做过技术总监,但在这件事情上面,我深有感触,因为我也有类似这样的经历,我也和他说了我的看法,他最后表示理解。 以我的阅历做一个大概的衡量吧,目前的现状是,一些新人基本上大多是清一色的 IntelliJ IDEA,老人大多用的 Eclipse,有的甚至两者皆用。 那么,我站在技术总监的角度思考问题,为什么他们要禁止使用 IntelliJ IDEA 呢?
10 0
IntelliJ IDEA中的神仙插件 写代码必备
IDEA 全称 IntelliJ IDEA,是java编程语言开发的集成环境。IntelliJ在业界被公认为最好的java开发工具,尤其在智能代码助手、代码自动提示、重构、JavaEE支持、各类版本工具(git、svn等)、JUnit、CVS整合、代码分析、 创新的GUI设计等方面的功能可以说是超常的。IDEA是JetBrains公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。它的旗舰版本还支持HTML,CSS,PHP,MySQL,Python等。免费版只支持Java,Kotlin等少数语言。 俗话说:"工欲善其事必先利其器",今天准备和大家一起分享一
26 0
在Linux mint 18上安装IntelliJ IDEA开发环境
一般情况下,使用 Linux mint 的我们都是在用它的图形界面,而安装IntelliJ IDEA传统思维模式是直接打开浏览器,进行下载即可。但就是这么一个简单的流程,就导致了下载文件损坏的问题。下面是我整理的安装步骤,如有问题,欢迎给予指出。
16 0
【IntelliJ IDEA】中文乱码问题 ( 代码乱码 | 编译乱码 | 控制台乱码 )
【IntelliJ IDEA】中文乱码问题 ( 代码乱码 | 编译乱码 | 控制台乱码 )
1651 0
免费获取 IntelliJ IDEA 激活码的 6 种方式!
你还在满世界找 IntelliJ IDEA 激活码?
635 0
Lombok 的作者,成功讨伐 IntelliJ IDEA!
Lombok 的作者,成功讨伐 IntelliJ IDEA!
65 0
Lombok 作者因兼容问题讨伐 IntelliJ IDEA(官方已妥协)
Lombok 作者因兼容问题讨伐 IntelliJ IDEA(官方已妥协)
70 0
(官方正规途径)终于靠开源项目弄到 IntelliJ IDEA 激活码了,真香!
上次,栈长分享了《免费获取 IntelliJ IDEA 激活码的 6 种方式!》,反响热烈,其中有一项是靠开源项目获取免费激活码,栈长也尝试了下,成功靠开源项目获取到了激活码,真香!!
214 0
IntelliJ IDEA 调试 Java 8 Stream,实在太香了!
Java技术栈 www.javastack.cn 关注阅读更多优质文章 前段时间,栈长发布了一篇关于 Java 8 Optional.map 的实用文章,留言区就有的人说 Java 8 的语法糖不方便调试,还要视情况使用。
71 0
IntelliJ IDEA 内存优化最佳实践!
本文作者在和同事的一次讨论中发现,对 IntelliJ IDEA 内存采用不同的设置方案,会对 IDEA 的速度和响应能力产生不同的影响。
524 0
+关注
文章
问答
来源圈子
更多
阿里云存储基于飞天盘古2.0分布式存储系统,产品包括对象存储OSS、块存储Block Storage、共享文件存储NAS、表格存储、日志存储与分析、归档存储及混合云存储等,充分满足用户数据存储和迁移上云需求,连续三年跻身全球云存储魔力象限四强。
+ 订阅
文章排行榜
最热
最新
相关电子书
更多
蚂蚁金服高级开发工程师萧恺:IDEA 插件开发入门教程
立即下载
Became OpenSource Project——Weex开源经验谈
立即下载
基于 Elasticsearch 电商搜索
立即下载