solr源码通过idea进行本地调试

试验环境:

solr5.3(和线上保持一致,历史功能,所以版本比较旧)

jdk1.8

idea2018版

ant1.9版本

solr源码地址:http://archive.apache.org/dist/lucene/solr/ ,记得下载源码 

solr-5.3.1-src.tgz

因为源码默认结构试验的ant,所以需要先安装ant1.9,http://ant.apache.org/bindownload.cgi

配置ant的环境变量,同java,因为环境比较基础对于开发人员应该比较简单,所以不过多记录了

源码目录结构:

cbfb925ffa4b6302f3f5af068be826b5b11.jpg

第一步:项目转为idea结构

cd 到 solr的根目录,执行以下命令

ant ivy-bootstrap  //安装ivy
cd solr
ant server
cd ..
ant idea

说明:ant类似maven,有时候网络不好会卡住或者失败,重新执行就好了,这一步死活过不去的话,可以百度一下,我是2次成功的

然后idea,打开根目录(删除本分,为其它测试引入,请忽略)

fcc569bda4b1afbc35049c21e60d8be6a08.jpg

第二步:debug模式启动solr(强烈建议,通过  根目录/solr/bin 中的 solr --help 看一下都支持什么)

cd solr/bin

solr -f -a  "-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=18984" -port 8984

说明:address 为debug 调试接口   ,-port 为solr的访问接口

92f0a4f33ecd4f728b3e8fed4496887bbb5.jpg

这时候访问solr,http://localhost:8984/solr,需要添加Core,会的跳过,不会的百度...很简单或者用我下面吐槽的办法

f09be10eea6829f69b823f2427aed229cec.jpg

注意:这里可能会报错,根据错误提示创建文件(从demo里面copy),只是测试的话可以参考吐槽部分

76f568e4f50c4b5ac439e307575d0fd8856.jpg

以下部分纯属吐槽(记录自己的一次测试,和主流程无关),经验丰富,可以跳过

-------------------------------------------------------------------------------------------

上面主流程没有core,需要新建,可能会遇到一些问题,可以根据提示解决,后来为了测试solr的一些命令做了一个小测试

因为我只是做实验所以导入了一份测试数据 通过solr -f -e dih ,会生成一些测试数据

0975d32653122fcffeb50ed96ef67a2e952.jpg

c7c0c3c5ff384eb1c0d92c960d919184790.jpg

这时候可以关闭solr了,因为这次操作是为了生存测试core,这里被坑了一次 -e dih 无法开启调试模式(也许是自己测试问题)

solr stop -p 8984 

这时候测试 core已经有了,再开启debug 模式,这时候会用到上面命令提示的-s 的路径

54dbabea7dbe09191157832a076c2c729a0.jpg

solr -f -a  "-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=18984" -port 8984    -s "E:\idea_workspace\solr-5.3.1\solr\example\example-DIH\solr"

54ec57e88c9d3ecf830c8d43b7e9177a407.jpg

吐槽结束,回归正途

------------------------------------------------------------------------------------

第三步:通过idea 进行remote debug

8ae355ad4bbf0b254f8deda4e5e4a906544.jpg

说明:远程调试,握手失败

Error running Debugger: Unable to open debugger port (localhost:8983):  java.io.IOException "handshake failed - connection prematurally closed"

原因:1.防火墙关闭(没测)  2.检查你的solr 命令中的参数,主要a 后面那部分,有些网上的资料也的不太准确,你记得自己 solr --help 看下例子

成功的截图:

98fe8934f11709235ae160077456a5fc81c.jpg

第四步:前面都成功的话,开始任意的打断点,撸代码吧

9962be89a5fc9b96ae291a6dc6c1486d0cd.jpg

679aa32938a582ffa14de36c3ba1008ede4.jpg

成功进入断点

97b1c03d4546229346f40cd0d88a1e4de6d.jpg

致此完成,还有问题欢迎加群讨论学习

qq群:208779755


附学习:solr 常用命令参数截图

6b15516114896254f18fff2dcd037fc1601.jpg

 

 

 

 

 

转载于:https://my.oschina.net/haitaohu/blog/3077588

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值