hbase远程调试源码的方法和步骤
=============获取hbase-server源码=====================
hbase-regionserver源码调试的前提是有源码
有个比较简单的办法可以弄到hbase对应版本的源码
先随便弄个maven、sprinboot项目,引入下面的依赖
4.0.0
org.springframework.boot
spring-boot-starter-parent
2.4.0
com.example
regionserver1Dome
0.0.1-SNAPSHOT
regionserver1Dome
Demo project for Spring Boot
1.8
2.0.2
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-data-jpa
javax.el
org.glassfish
3.0.1-b12
org.apache.phoenix
phoenix-core
5.0.0-HBase-2.0
javax.el
org.glassfish
hadoop-hdfs
org.apache.hadoop
hadoop-hdfs-client
org.apache.hadoop
org.apache.hadoop
hadoop-common
2.8.4
com.google.guava
guava
20.0
org.springframework.boot
spring-boot-starter-data-redis
com.alibaba
fastjson
1.2.62
org.apache.hbase
hbase-server
${hbase.version}
servlet-api
javax.servlet
slf4j-log4j12
org.slf4j
org.apache.hbase
hbase-client
${hbase.version}
servlet-api
javax.servlet
slf4j-log4j12
org.slf4j
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-devtools
runtime
true
org.springframework.boot
spring-boot-configuration-processor
true
org.projectlombok
lombok
true
org.springframework.boot
spring-boot-maven-plugin
repackage
org.apache.maven.plugins
maven-compiler-plugin
3.8.1
true
${java.version}
如果你的hbase版本不是2.0.2,只需要对应改下pom中的版本号就行了。
然后idea中把jar包源码下载下来
接着你就能点进jar包看源码了
=============idea配置====================
host填入你要远程调试的服务器的ip
部分内容我复制出来
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8765
其它内容参考图片
=============linux环境配置====================
远程调试需要打开端口,如果端口都打不开就没办法网络通讯了,需要保证本地和远程是通网的
退出容器查看端口
iptables -n -t nat -L
容器外添加打开的端口
如命令:iptables -t nat -A DOCKER -p tcp --dport ${port1} -j DNAT --to-destination ${ip}:${port1}
比如iptables -t nat -A DOCKER -p tcp --dport 8765 -j DNAT --to-destination 172.17.157.14:8765
=============hbase-server配置====================
在regionserver的配置文件里加上这个jvm参数(小心空格),如果suspend=y,那么idea没启动起来的时候,regionserver也无法启动起来,我一般使用n
-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=8765,server=y,suspend=n
重启regionserver生效
hbase-daemon.sh stop regionserver
hbase-daemon.sh start regionserver
先启动regionserver,然后再启动idea的调试,不然有时候idea的调试启动不起来
有的时候也会出现regionserver启动后卡住,需要idea启动后才能继续运行的情况
在合适的地方加上断点,比如JvmPauseMonitor的run方法,这个方法在hbaseregionserver运行的时候几乎每秒运行一遍,如果你的idea成功在这个断点停下来了,说明你已经成功连接了
其他大佬的文档
https://blog.csdn.net/lo085213/article/details/102922720
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)