java远程调试
来源:互联网 发布:软件专利怎么写 编辑:程序博客网 时间:2024/06/06 20:22
jdwp远程调试简介
Java远程调试的原理是两个VM之间通过debug协议进行通信,然后以达到远程调试的目的。两者之间可以通过socket进行通信。这对于一些分布式框架(如hadoop集群、storm集群等)的远程调试非常有用!
首先被debug程序的虚拟机在启动时要开启debug模式,启动debug监听程序。jdwp是Java Debug Wire Protocol的缩写。
jdk1.7版本之前的方法:
java -Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=8000,suspend=n xxx
jdk1.7版本之后的方法:
java -agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=y -jar xxx.jar
xxx是main程序;server=y表示是监听其他debugclient端的请求;address=8000表示端口是8000;suspend表示是否在调试客户端建立连接之后启动 VM,如果为y,那么当前的VM就是suspend直到有debug client连接进来才开始执行程序,如果你的程序不是服务器监听模式并且很快就执行完毕的,那么可以选择在y来阻塞它的启动。
然后用一个debug客户端去debug远程的程序了,比如用Eclipse自带的debug客户端,填写运行被debug程序的虚拟机监听的端口号和地址,选择connect方式为attach。
OK,现在就可以开始远程调试!
简单测试
1、在开发客户端创建一个简单的应用程序(hadoop-debugdemo),将其打包部署到远程服务器(nimbusz)的某个目录下
2、在远程nimbusz机器启动待调试的应用程序
3、在开发客户端(如eclipse)调试远程的应用程序
可以看到每次开发客户端向下执行一步,都能在远程看到执行的效果。测试成功!
阅读全文
0 0
- java 远程调试 Tomcat配置远程调试
- java 的远程调试
- java应用远程调试
- java远程调试参数
- 远程调试java程序
- 远程调试java程序
- java 远程调试备忘
- java远程调试
- Java程序远程调试
- Eclipse远程调试Java
- Java应用远程调试
- java 远程调试butterfly
- Java远程调试
- 远程调试 Java 程序
- Eclipse远程调试Java
- java远程调试
- java/scala远程调试
- Java远程调试-JPDA
- eslint在项目中的使用
- oracle数据库_实例_用户_表空间之间的关系
- 【UGUI】技能冷却
- 第一周 枚举 例题2.完美立方
- 集成Glide4.3.1出错!AbstractMethodError: abstract method "void com.bumptech.glide.module
- java远程调试
- jsp和asp区别
- 多表查询 基础
- 机器学习里数据预处理及特征工程总结
- HTML标签学习4
- JavaDay01--Notes(JDK的安装和搭建+编译运行Java+转换数据类型+易混与难懂运算符)
- JAVA | 36
- python读取xls文件
- Error:Failed to open zip file. Gradle's dependency cache may be corrupt (this sometimes occurs after