hbase远程调试源码的方法和步骤

hbase远程调试源码的方法和步骤,第1张

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}
                    ${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

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/886462.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-14
下一篇 2022-05-14

发表评论

登录后才能评论

评论列表(0条)

保存