Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8168828
  • 博文数量: 595
  • 博客积分: 13065
  • 博客等级: 上将
  • 技术积分: 10334
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-26 16:44
个人简介

推荐: blog.csdn.net/aquester https://github.com/eyjian https://www.cnblogs.com/aquester http://blog.chinaunix.net/uid/20682147.html

文章分类

全部博文(595)

分类: Java

2015-11-04 09:04:16

1) jdb调试正在运行的进程:
先使用jps先确定进程号,然后让jdb连接上目标进程(23549换成实际的进程号):
jdb -connect sun.jvm.hotspot.jdi.SAPIDAttachingConnector:pid=23549


接着,可以使用thread N切换线程(使用threads命令可以查看有哪些线程),如:thread 1,然后就可以使用where命令查看调用栈了(jdb中的where相当于gdb的bt)。


2) jdb调试未运行的程序:
程序代码:
hadoop@hadoop-137-143:~/hbase> cat Hello.java
public class Hello {
    public static void main(String[] args) {
        System.out.println("Hello World!");
    }
}
编译:
hadoop@hadoop-137-143:~/hbase> javac Hello.java  


运行:
hadoop@hadoop-137-143:~/hbase> java Hello
Error: Could not find or load main class Hello


运行报错,设置CLASSPATH后再运行:
hadoop@hadoop-137-143:~/hbase> export CLASSPATH=.
hadoop@hadoop-137-143:~/hbase> java Hello
Hello World!


运行成功了,如果不想设置CLASSPATH,下面这样也可以运行成功:
hadoop@hadoop-137-143:~/hbase> java -classpath . Hello
Hello World!
也就是利用参数“-classpath”达到同样的效果。


开始调试,执行下面命令进入jdb:
jdb -classpath . Hello


设置断点在main()函数:
> stop in Hello.main
Deferring breakpoint Hello.main.
It will be set after the class is loaded.


运行到断点:
> run
run Hello


运行下一步:
main[1] next
> Hello World!


退出:
main[1] quit


阅读(3947) | 评论(5) | 转发(0) |
给主人留下些什么吧!~~

Aquester2016-11-27 14:17:24

Aquester:开启远程调式端口3456,可设置断点等:
/usr/local/jdk/bin/java -Dproc_thrift2 -Xrunjdwp:transport=dt_socket,server=y,address=3456 -XX:OnOutOfMemoryError=\'kill -9 %p\' -XX:+UseConcMarkSweepGC -Dhbase.log.dir=/data/hbase/bin/../logs -Dhbase.log.file=hbase-zhangsan-thrift2-hadoop-037.log -Dhbase.home.dir=/data/hbase/bin/.. -Dhbase.id.str=zhangsan -Dhbase.root.logger=INFO,RFA -Dhbase.security.logger=INFO,RFAS org.apache.hadoop.hbase.thrift2.ThriftServer --framed --hsha --workers 10 start

jdb -attach 3456

回复 | 举报

Aquester2016-11-27 14:16:06

Aquester:以pid方式时,jdb是只读的,也就不能设置断点等

开启远程调式端口3456,可设置断点等:
/usr/local/jdk/bin/java -Dproc_thrift2 -Xrunjdwp:transport=dt_socket,server=y,address=3456 -XX:OnOutOfMemoryError=\'kill -9 %p\' -XX:+UseConcMarkSweepGC -Dhbase.log.dir=/data/hbase/bin/../logs -Dhbase.log.file=hbase-zhangsan-thrift2-hadoop-037.log -Dhbase.home.dir=/data/hbase/bin/.. -Dhbase.id.str=zhangsan -Dhbase.root.logger=INFO,RFA -Dhbase.security.logger=INFO,RFAS org.apache.hadoop.hbase.thrift2.ThriftServer --framed --hsha --workers 10 start

回复 | 举报

Aquester2016-11-27 13:41:38

Aquester:jdb -connect sun.jvm.hotspot.jdi.SACoreAttachingConnector:\\ javaExecutable=$JAVA_HOME/bin/java,core=core.20441

以pid方式时,jdb是只读的,也就不能设置断点等

回复 | 举报

Aquester2016-11-27 13:39:51

jdb -connect sun.jvm.hotspot.jdi.SACoreAttachingConnector:\\ javaExecutable=$JAVA_HOME/bin/java,core=core.20441

Aquester2016-10-26 18:53:02

/usr/local/jdk/bin/java -Dproc_thrift2 -XX:OnOutOfMemoryError=\'kill -9 %p\' -XX:+UseConcMarkSweepGC -Dhbase.log.dir=/data/hbase/bin/../logs -Dhbase.log.file=hbase-gongyi-thrift2-hadoop-031.log -Dhbase.home.dir=/data/hbase/bin/.. -Dhbase.id.str=gongyi -Dhbase.root.logger=INFO,RFA -Dhbase.security.logger=INFO,RFAS -classpath `find /data/hbase/libX -name \"*.jar\"|awk \'{printf(\"%s:\", $0);}\'` org.apache.hadoop.hbase.thrift2.ThriftServer --infoport 9086 -p 9876