java 远程debug
来源:互联网 发布:网络课舌尖上的植物学 编辑:程序博客网 时间:2024/06/05 19:05
java中的远程debug调试
java -Xdebug -Xnoagent -Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=y
参数 含义
Xdebug 告诉jvm运行在debug模式下
Xnoagent 不清楚
Xrunjdwp transport 指定连接方式(包括socket传输和内存传输两种,其中内存传输只支持windows,而且内存传输不支持远程调试)
address 监听端口,以接收debug客户端发起的TCP连接。
server =y 表示在remote debugging会话中作为服务端
suspend =y 表示在客户端建立连接前,服务端被挂起;=n 则不会被挂起。 专门调试时建议设置成y
客户端设置
(1) 打开eclipse工作台 (笔者用的是eclipse3.2)
(2) 选择“Run->Debug…”菜单项
(3) 选择“Remote Java Application”,在右键弹出菜单中选择“New”
(4) 在Connect标签项中配置连接方式,远程主机的IP和端口(由于在服务端我们设置的是8787,客户端则设置8787)
(5) 在Source标签项中配置好源代码,一般保留默认的就可以。
调试
(1) 在服务端(笔者实验是在10.10.41.182上)运行脚本ex.sh,会显示程序正监听8787端口,由于suspend设置成了=y,所以必须等到客户端连接上了服务端才会继续运行。
(2) 运行客户端,运行刚才建立的RemoteDebugger(1),注意到远程调试项图标下面有个“L”型的折线图标。
在debug Perspective模式下就可以看到阻塞于断点的jvm了
例如Java HotSpot(TM) 64-Bit Server VM[datanode-2:8088]
Thread [main] (Suspended (breakpoint at line 282 in DataNode))
DataNode.startDataNode(Configuration, AbstractList<File>) line: 282
DataNode.<init>(Configuration, AbstractList<File>) line: 232
DataNode.makeInstance(String[], Configuration) line: 1363
DataNode.instantiateDataNode(String[], Configuration) line: 1318
DataNode.createDataNode(String[], Configuration) line: 1326
DataNode.main(String[]) line: 1448
2011.12.08
1. tomcat debug
/usr/java/default/bin/java -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8082 -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/usr/local/tomcat/endorsed -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp org.apache.catalina.startup.Bootstrap start
2011.12.13
1. /usr/java/default/bin/jstat -gcutil pid 500 100
2. strace jps
3. /usr/java/default/bin/jstack -F 9107(pid) 堆栈信息
2012.05.17
1. Eclipse 中打断点, debug时, 提示 "Unable to install breakpoint due to missing line number attributes. Modify compiler options to generate line number attributes" 是因为被debug的jar包,没有行信息, 要在javac里加 debug="true" 参数重新编译jar文件, 再debug就可以了.
java -Xdebug -Xnoagent -Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=y
参数 含义
Xdebug 告诉jvm运行在debug模式下
Xnoagent 不清楚
Xrunjdwp transport 指定连接方式(包括socket传输和内存传输两种,其中内存传输只支持windows,而且内存传输不支持远程调试)
address 监听端口,以接收debug客户端发起的TCP连接。
server =y 表示在remote debugging会话中作为服务端
suspend =y 表示在客户端建立连接前,服务端被挂起;=n 则不会被挂起。 专门调试时建议设置成y
客户端设置
(1) 打开eclipse工作台 (笔者用的是eclipse3.2)
(2) 选择“Run->Debug…”菜单项
(3) 选择“Remote Java Application”,在右键弹出菜单中选择“New”
(4) 在Connect标签项中配置连接方式,远程主机的IP和端口(由于在服务端我们设置的是8787,客户端则设置8787)
(5) 在Source标签项中配置好源代码,一般保留默认的就可以。
调试
(1) 在服务端(笔者实验是在10.10.41.182上)运行脚本ex.sh,会显示程序正监听8787端口,由于suspend设置成了=y,所以必须等到客户端连接上了服务端才会继续运行。
(2) 运行客户端,运行刚才建立的RemoteDebugger(1),注意到远程调试项图标下面有个“L”型的折线图标。
在debug Perspective模式下就可以看到阻塞于断点的jvm了
例如Java HotSpot(TM) 64-Bit Server VM[datanode-2:8088]
Thread [main] (Suspended (breakpoint at line 282 in DataNode))
DataNode.startDataNode(Configuration, AbstractList<File>) line: 282
DataNode.<init>(Configuration, AbstractList<File>) line: 232
DataNode.makeInstance(String[], Configuration) line: 1363
DataNode.instantiateDataNode(String[], Configuration) line: 1318
DataNode.createDataNode(String[], Configuration) line: 1326
DataNode.main(String[]) line: 1448
2011.12.08
1. tomcat debug
/usr/java/default/bin/java -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8082 -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/usr/local/tomcat/endorsed -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp org.apache.catalina.startup.Bootstrap start
2011.12.13
1. /usr/java/default/bin/jstat -gcutil pid 500 100
2. strace jps
3. /usr/java/default/bin/jstack -F 9107(pid) 堆栈信息
2012.05.17
1. Eclipse 中打断点, debug时, 提示 "Unable to install breakpoint due to missing line number attributes. Modify compiler options to generate line number attributes" 是因为被debug的jar包,没有行信息, 要在javac里加 debug="true" 参数重新编译jar文件, 再debug就可以了.
0 0
- java远程debug
- java远程debug
- java 远程debug
- JAVA 远程debug
- java远程debug
- java的远程debug
- java 远程debug
- java远程debug
- 远程debug Java程序
- java程序远程debug
- JAVA远程debug
- Java远程debug调试
- Java远程服务器端Debug调式
- java远程debug(基于eclipse)
- java 远程debug JVM参数
- java远程debug调试tomcat
- java远程Debug Jar包
- 远程调试Java程序,远程Debug
- LTE中语音业务的实现以及相关探讨
- C# MVC框架(3)---如何定义 url route
- Android中Context
- zabbix报警表达式总结
- 《数据结构》实验四:字符串和多维数组 实验
- java 远程debug
- Tcl编程简介-info
- cassandra2.0安装与配置的几个陷阱
- android中可优化的22点
- WordPress修改新用户注册邮件内容--自定义插件
- POJ 2431 Expedition (贪心+优先队列)
- 中国市场对google的吸引
- sql 导出建表语句
- java 内部类、匿名内部类、嵌套类的使用