`
ayufox
  • 浏览: 276230 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

[Java性能剖析]JPDA 1)总体结构

    博客分类:
  • JVM
阅读更多

      JPDA(Java Platform Debugger Architecture)提供了JVM内部的访问接口,让我们可以方便地了解JVM内部的状态,可以在此基础上构建调试、性能剖析的平台。
      JPDA包括2个接口定义和1个通信协议:

  • JVM TI(JVM Tool Interface):定义了JVM提供给外部可以访问的服务,此接口以C/C++的方式提供。利用JDK5开始提供的java.lang.instrutment包,我们可以使用Java语言实现JVM TI中的字节码增强的功能。
  • JDWP(Java Debug Wire Protocol):定义了调试器和被调试的应用之间通信的协议JDI(Java Debug Interface):定义了调试客户端可以使用的接口,使用Java语言实现。

            Components                         Debugger Interfaces

                /           |--------------|
               /            |     VM              |
 debuggee ----(      |--------------|  <------- JVM TI - Java VM Tool Interface
               \           |   back-end       |
                \          |--------------|
                /                    |
 comm channel -(              |  <--------------- JDWP - Java Debug Wire Protocol
                \                    |
                            |--------------|
                            |    front-end      |
                            |--------------|  <------- JDI - Java Debug Interface
                            |        UI            |
                            |--------------|
         JPDA架构上分成3块:

  • 被调试应用:就是debuggee,被调试的应用在内部嵌入一个back-end,一方面back-end通过JVM TI接口访问到VM的内部信息,另一方面,back-end通过某种Transport(通信方式,譬如Sun JVM提供了socket和shmem的Transport)为外部提供了服务。
  • 通信协议:调试客户端和被调试方通过某种通信方式进行数据的交互,而JDWP定义了交互的数据的格式
  • 调试客户端:调试客户端通过front-end与back-end进行通信,front-end可以理解为JDI接口的实现,调试UI(譬如Eclipse的调试器)通过JDI接口最终访问到服务端的信息

      需要注意的是,如上仅仅是调试上的主要架构,JVM TI层不仅仅提供了调试性的接口,也提供了一些可以用于性能剖析的接口。性能剖析一般很多工具在架构上也类似于如上,在被剖析VM上运行Agent(类似于如上中的back-end),而剖析Client(友好的UI功能)连接到Agent上采集数据,只不过在这个过程当中,通信管道协议不一定会使用JDWP,而客户端也可能会是通过一种工具专有的协议从远程获取到剖析信息。

2
3
分享到:
评论

相关推荐

    深入Java调试体系(JPDA-JDWP)

    JPDA(Java Platform Debugger Architecture)是 Java 平台调试体系结构的缩写,通过 JPDA 提供的 API,开发人员可以方便灵活的搭建 Java 调试应用程序。 JPDA 主要由三个部分组成:Java 虚拟机工具接口(JVMTI),...

    基于JPDA的Java软件性能测试.pdf

    1. JPDA是一种Java平台调试技术,可以对Java程序的性能和稳定性进行检测和分析。 2. JPDA平台可以对程序的前端层次进行简化测试,提高认软件的性能和稳定性。 3. JPDA平台可以对程序的内存消耗情况进行检测和分析,...

    JPDA----java调试体系

    JPDA(Java Platform Debugger Architecture)是 Java 平台调试体系结构的缩写,通过 JPDA 提供的 API,开发人员可以方便灵活的搭建 Java 调试应用程序。JPDA 主要由三个部分组成:Java 虚拟机工具接口(JVMTI),...

    JPDA.rar_JPDA数据关联_jpda_jpda关联_数据关联JPDA_跟踪波门

    标题中的"JPDA.rar"可能是指Java Platform Debugger Architecture(Java平台调试架构)的压缩文件,而"JPDA数据关联_jpda_jpda关联_数据关联JPDA_跟踪波门"这部分描述了与JPDA相关的特定应用或概念,特别是关于数据...

    使用JPDA进行Java程序远程调试

    Java Platform Debugger Architecture (JPDA) 是Java开发工具的一部分,它为开发者提供了强大的远程调试功能,使得可以在一台机器上调试运行在另一台机器上的Java应用程序。本文将详细介绍如何使用JPDA进行Java程序...

    JPDA学习笔记与示例代码

    "数据挖掘及融合技术研究与应用_黄玲.caj"文件看起来是一篇关于数据挖掘和融合技术的研究论文,虽然不是直接关于JPDA,但它可能提供了相关领域的背景知识和应用案例,这对于理解目标跟踪的上下文环境和提高分析能力...

    JPDA_suanfa_jpda_航迹关联_JPDAmatlab仿真_

    1. **理解代码结构:** 分析代码中定义的数据结构、变量和函数,了解算法的整体流程。 2. **运行仿真:** 执行代码,观察结果,理解JPDA如何处理不同场景下的数据关联问题。 3. **调整参数:** 修改参数,比如传感器...

    远程调试jpda.docx

    JPDA是Java平台调试架构,它由Java虚拟机后端和调试平台前端两部分构成,使得调试平台可以通过调试交互协议向Java虚拟机请求服务,从而对运行在虚拟机中的程序进行调试。 具体到本文中,我们的应用服务器是Tomcat ...

    Matlab_JPDA.zip_JPDA matlab仿真_JPDA算法_jpda_jpda tracking_matlab j

    多目标跟踪JPDA算法实现,是学习JPDA算法的经典代码,建议下载下来看看。

    JPDA_jpda_目标跟踪_源码

    1. **Java Debug Wire Protocol (JDWP)**:这是JPDA的核心,定义了调试器和被调试的Java虚拟机之间的通信协议。 2. **Java Debug Interface (JDI)**:这是一个Java API,供调试器使用,以控制被调试的Java应用程序...

    7_目标跟踪_jpda.zip

    标题中的“7_目标跟踪_jpda.zip”表明这是一个关于目标跟踪技术的压缩包,而“jpda”通常指的是Java Platform Debugger Architecture(Java平台调试架构)。这个压缩包可能包含了一系列有关如何使用JPDA进行目标跟踪...

    JPDA算法程序.zip

    在这里,JPDA算法的MATLAB实现提供了直观的代码结构和易于理解的注释,使得研究人员或工程师能够快速地理解和复现该算法。通过运行这些程序,用户可以模拟不同的雷达跟踪场景,调整参数以适应特定的杂波环境,或者...

    数据关联的JPDA算法

    一个良好的JPDA算法实现应该清晰地标明各个步骤,包括数据结构的设计、概率计算的过程以及如何处理数据关联冲突等。 在实际应用中,JPDA算法可能存在计算复杂度高、内存需求大等问题,因此,常常需要采用一些优化...

    JPDA代码利用MATLAB编写的

    在压缩包内的"JPDA"文件夹中,可能会有如下文件结构: - `JPDA.m`: 主函数,调用其他辅助函数执行整个JPDA算法。 - `data_processing.m`: 数据预处理函数。 - `target_state_estimation.m`: 目标状态估计函数,可能...

    Java程序优化与数据竞争检测的研究.pdf

    本文对Java程序优化与数据竞争检测的研究结果表明,Java程序优化是提高Java程序性能的重要手段,而JPDA平台是检测Java程序性能的重要技术。因此,在实际应用中,应充分利用Java程序优化和JPDA平台技术,提高Java程序...

    深入Java调试体系:第1部分,JPDA体系概览

    JPDA(JavaPlatformDebuggerArchitecture)是Java平台调试体系结构的缩写,通过JPDA提供的API,开发人员可以方便灵活的搭建Java调试应用程序。JPDA主要由三个部分组成:Java虚拟机工具接口(JVMTI),Java调试线协议...

    JPDA算法实现

    在MatLab环境中实现JPDA算法,可以利用其强大的数学计算和图形可视化能力,使得算法的调试和结果分析变得更加直观。"Data_JPDAF.m"文件很可能是该算法的主程序,包含了JPDA算法的具体实现代码。通过运行这个文件,...

Global site tag (gtag.js) - Google Analytics