hbase远程调试源码的方法和步骤
=============获取hbase-server源码=====================
hbase-regionserver源码调试的前提是有源码
有个比较简单的办法可以弄到hbase对应版本的源码
先随便弄个maven、sprinboot项目,引入下面的依赖
4.0.0 org.springframework.boot spring-boot-starter-parent2.4.0 com.example regionserver1Dome0.0.1-SNAPSHOT regionserver1Dome Demo project for Spring Boot 1.8 2.0.2 org.springframework.boot spring-boot-starterorg.springframework.boot spring-boot-starter-weborg.springframework.boot spring-boot-starter-data-jpajavax.el org.glassfish 3.0.1-b12 org.apache.phoenix phoenix-core5.0.0-HBase-2.0 javax.el org.glassfish hadoop-hdfs org.apache.hadoop hadoop-hdfs-client org.apache.hadoop org.apache.hadoop hadoop-common2.8.4 com.google.guava guava20.0 org.springframework.boot spring-boot-starter-data-rediscom.alibaba fastjson1.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-starterorg.springframework.boot spring-boot-devtoolsruntime true org.springframework.boot spring-boot-configuration-processortrue org.projectlombok lomboktrue org.springframework.boot spring-boot-maven-pluginrepackage org.apache.maven.plugins maven-compiler-plugin3.8.1 true ${java.version} ${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



