栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/871807.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号