CN108829591A - 一种基于Web的协同调试***及方法 - Google Patents

一种基于Web的协同调试***及方法 Download PDF

Info

Publication number
CN108829591A
CN108829591A CN201810552504.2A CN201810552504A CN108829591A CN 108829591 A CN108829591 A CN 108829591A CN 201810552504 A CN201810552504 A CN 201810552504A CN 108829591 A CN108829591 A CN 108829591A
Authority
CN
China
Prior art keywords
debugging
module
web
request
synergic
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201810552504.2A
Other languages
English (en)
Other versions
CN108829591B (zh
Inventor
计卫星
石剑君
王拙
王一拙
高玉金
石峰
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Institute of Technology BIT
Original Assignee
Beijing Institute of Technology BIT
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Institute of Technology BIT filed Critical Beijing Institute of Technology BIT
Priority to CN201810552504.2A priority Critical patent/CN108829591B/zh
Publication of CN108829591A publication Critical patent/CN108829591A/zh
Application granted granted Critical
Publication of CN108829591B publication Critical patent/CN108829591B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明涉及一种基于Web的协同调试***及方法,用户可以在浏览器界面上直接操作调试远端程序,不仅具有支持良好的图形化界面,而且能够实时获取调试信息,以更加清晰直观的方式完成调试工作;另一方面,协同调试功能使得调试用户可以不安装配置本地调试环境,只要向远端服务器发出调试请求,一旦获得调试权限,就可以像本地一样进行调试,这样大大降低了调试成本,提高了调试效率;同时该基于Web的协同调试***及方法,可以扩展到除了操作***内核级调试之外的其他调试应用,满足不同调试需求,具有可扩展性强,适用范围广的特点,结合了Web技术和调试技术的优点,为实现Web跨平台、可视化调试提供了较好的解决方案。

Description

一种基于Web的协同调试***及方法
技术领域
本发明涉及互联网技术领域,特别涉及一种基于Web的协同调试***及方法。
背景技术
随着Web 2.0技术的发展,基于Web技术实现***级应用已经成为现代技术的主流。以C/S(客户端/服务器)模式的应用技术已经逐步转变为以B/S(浏览器/服务器)模式为主的低成本、轻量级应用,并在各行各业中得到广泛应用。
J2EE技术是一种基于Java的企业级Web应用开发解决方案,不仅继承了Java平台诸多优点,同时还提供了对EJB(Enterprise JavaBeans)、Java Servlets API、JSP(JavaServer Pages)以及XML技术的全面支持,大大简化了企业级应用开发。另外,作为一个集成开发平台技术,J2EE又具有可用性强、可靠性高、可扩展性好等优点。
调试是现代软件开发中必不可少的环节,而针对操作***内核级调试往往需要专门的调试工具,例如目前比较流行的调试工具GDB,这样一方面开发人员需要配置特定的调试环境,增加了调试成本;另一方面,调试信息往往难以直接理解,增加了普通用户的调试难度。
GDB/MI是GDB提供的除了CLI(Command Line Interface)命令之外的一种更重要的命令接口,它通常用于构建复杂***的调试工具,作为复杂***中的一个调试组件而存在。例如,在Insight中实现的以GDB作为调试工具的GUI debugger就充分利用了GDB/MI。但是,GDB/MI的输出信息格式较为复杂,需要熟悉其格式才能正确理解。
QEMU是在GNU/Linux平台上广泛使用的开源模拟器,具有轻量级、速度快、支持多种平台架构等优点。QEMU支持用户级模式和***级模式两种工作模式,其中,***级工作模式可以使未经修改的内核或者操作***在模拟环境下运行,为***调试和跨平台应用操作提供了良好平台。
现有的用于操作***内核级应用的调试工具通常不具有友好GUI界面,而且调试过程复杂,需要较高的调试成本。
发明内容
鉴于上述问题,本发明提供了一种基于Web的协同调试***及方法,该***基于成熟的Web开发技术和平台,可实现便捷、友好、高效的***调试。
第一方面,本发明实施例提供一种基于Web的协同调试***,包括基于Web的图形化调试平台和***调试框架;
所述基于Web的图形化调试平台包括:
Web客户端浏览器模块,用于向HTTP服务器模块发送调试请求,将GDB服务器调试模块返回的调试信息呈现给用户;
HTTP服务器模块,用于接收所述调试请求,并将GDBWrapper消息转换模块的输出结果返回给用户客户端浏览器;
GDBWrapper消息转换模块,用于接收所述HTTP服务器模块处理的所述调试请求,并将所述调试请求发送给GDB服务器调试模块;以及接收所述GDB服务器调试模块的发送的调试结果,将所述调试结果返回给所述HTTP服务器模块;
GDB服务器调试模块,用于调试所述调试请求相对应的目标***和应用程序,将调试结果返回给GDBWrapper消息转换模块。
所述协同调试框架包括:
协同调试用户管理模块,用于将所有调试用户分为多个调试组进行管理,并根据用户请求为用户创建一个新的调试组或将用户加入到现有的调试组;每个调试组具有唯一表示ID,同一所述调试组的用户所接收到的调试信息相同;
协同调试权限管理模块,用于确定每个调试组的待调试用户是否拥有唯一Token;所述每个调试组Session维护一个唯一Token,当拥有Token的用户有权限发送调试命令;
协同调试消息管理模块,用于对所述调试请求和调试结果采用统一管理机制,将每一个调试请求和调试结果返回给相对应调试组的所有调试成员,通过采用数据库缓存机制保证调试信息的一致性。
在一个实施例中,所述调试请求包括以下一种或多种命令:
暂停Pause、运行Run、Step单步、设置断点Set Breakpoint、删除断点RemoveBreakpoint、设置观察点Set Watchpoint、删除观察点Remove Watchpoint、查看指定内存信息Memory、查看寄存器信息Register和退出Quit。
在一个实施例中,所述调试信息包括以下一种或多种信息:
***运行时线程堆栈信息、命令执行返回的GDB调试信息、断点列表信息、观察点列表信息、指定内存数据信息和寄存器数据信息。
在一个实施例中,所述GDBWrapper消息转换模块,具体用于将所述Web客户端浏览器模块发送的JSON格式数据转换为GDB服务器可执行的调试命令,以及将所述GDB服务器调试模块返回的调试结果转换为所述Web客户端浏览器模块显示的HTML格式数据。
在一个实施例中,所述JSON格式数据的调试命令,具体格式为:
[GID][COMMAND]:[调试事件]。
在一个实施例中,所述的调试结果的格式为:
[GID][COMMAND]:[调试事件][线程堆栈][断点列表][内存信息][寄存器信息]。
第二方面,本发明实施例提供一种基于Web的协同调试方法,所述方法包括:基于Web的图形化调试平台预处理操作、协同调试预处理操作、断点调试操作和协同调试操作;
所述基于Web的图形化调试平台预处理操作,包括以下步骤:
(11)所述基于Web的图形化调试平台根据预先配置的调试端口启动一个HTTP服务器模块,并记录服务器地址URL;
(12)所述Web客户端浏览器模块输入服务器地址URL,向HTTP服务器模块发送HTTP请求;
(13)所述GDBWrapper消息转换模块和GDB服务器调试模块进行初始化操作;
所述协同调试预处理操作,包括以下步骤:
(21)调试用户通过相应权限登录调试***;
(22)所述协同调试用户管理模块根据用户请求为用户创建一个新的调试组或者加入到一个已有的调试组;
所述断点调试操作,包括以下步骤:
(31)所述基于Web的图形化调试平台根据用户请求搜索相关函数或者全局变量,在Web客户端浏览器模块中选择需要设置断点的相关函数或者全局变量;
(32)所述Web客户端浏览器模块发出设置断点请求,将所述设置断点请求和相关函数或者全局变量发送给HTTP服务器模块;
(33)所述HTTP服务器模块将所述断点请求发送给GDBWrapper消息转换模块进行消息转换,并将所述设置断点请求和相关函数或者全局变量相对应的调试请求发送给GDB服务器调试模块,执行调试命令;
(34)所述GDB服务器调试模块将返回的断点列表信息、线程信息和控制台信息返回GDBWrapper消息转换模块进行消息转换,并将转换后的调试结果返回给HTTP服务器模块;
协同调试操作,包括以下步骤:
(41)所述协同调试用户管理模块为第一个调试用户创建一个调试实例,所述调试实例维护一个调试组信息和一个调试Token;
(42)新加入调试组的调试用户,向所述协同调试权限管理模块发出获取Token请求;请求得到确认后,获得调试权限;
(43)所述协同调试消息管理模块在每次调试信息返回时,为所述调试组的所有调试成员返回相同的调试信息。
在一个实施例中,所述GDBWrapper消息转换模块和GDB服务器调试模块进行初始化操作,包括以下步骤:
(131)所述GDB服务器调试模块通过与QEMU中运行的操作***或者应用程序建立TCP连接,对所述操作***或者应用程序进行调试;
(132)所述GDBWrapper消息转换模块,与所述GDB服务器调试模块建立TCP连接进行通信,且与HTTP服务器模块通过Web Socket建立连接通信。
在一个实施例中,将所述设置断点请求和相关函数或者全局变量相对应的调试请求发送给GDB服务器调试模块,执行调试命令,包括以下步骤:
(331)所述HTTP服务器模块解析Web客户端浏览器模块发送的调试请求,执行相应的操作,主要包括以下步骤:
(a)当接收到的所述调试请求为Quit退出命令,则发出一个中断GDB服务器的命令;
(b)当接收到的所述调试请求为Set/Remove Breakpoint或者Set/RemoveWatchpoint,则向GDB服务器调试模块发出设置或者删除断点/观察点的命令;
(c)当接收的所述调试请求为Memory查看内存信息或者Register查看寄存器信息,则向GDB服务器调试模块发出查看内存信息或者寄存器信息相关格式的命令;
(d)当接收的所述调试请求为Pause暂停或者Run继续执行命令,则向GDB服务器调试模块发出中断执行或者继续执行命令;
(e)当接收的所述调试请求为Step单步执行命令,则向GDB服务器调试模块发出单步调试命令,以函数为基本调试单位单步执行。
(332)所述HTTP服务器模块将解析后的调试请求发送给所述GDBWrapper消息转换模块,所述GDBWrapper消息转换模块将调试请求转换为GDB服务器调试模块可执行的GDB/MI命令,并接收所述GDB服务器调试模块返回的调试结果,将所述调试结果转换为相应的数据格式返回给HTTP服务器模块。
本发明实施例提供的上述技术方案的有益效果至少包括:
本发明实施例提供的一种基于Web的协同调试***,用户可以在浏览器界面上直接操作调试远端程序,不仅具有支持良好的图形化界面,而且能够实时获取调试信息,以更加清晰直观的方式完成调试工作;另一方面,协同调试功能使得调试用户可以不安装配置本地调试环境,只要向远端服务器发出调试请求,一旦获得调试权限,就可以像本地一样进行调试,这样大大降低了调试成本,提高了调试效率;同时该基于Web的协同调试***及方法,可以扩展到除了操作***内核级调试之外的其他调试应用,满足不同调试需求,具有可扩展性强,适用范围广的特点,结合了Web技术和调试技术的优点,为实现Web跨平台、可视化调试提供了较好的解决方案。
本发明的其它特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。本发明的目的和其他优点可通过在所写的说明书、权利要求书、以及附图中所特别指出的结构来实现和获得。
下面通过附图和实施例,对本发明的技术方案做进一步的详细描述。
附图说明
附图用来提供对本发明的进一步理解,并且构成说明书的一部分,与本发明的实施例一起用于解释本发明,并不构成对本发明的限制。在附图中:
图1为本发明实施例提供的基于Web的协同调试***的模块示意图;
图2为本发明实施例提供的基于Web的协同调试***架构整体示意图;
图3为本发明实施例提供的基于Web的协同调试***的调试界面示意图;
图4为本发明实施例提供的基于Web的协同调试方法的流程图;
图5为本发明实施例提供的步骤S1的流程图;
图6为本发明实施例提供的步骤S13的流程图;
图7为本发明实施例提供的步骤S2的流程图;
图8为本发明实施例提供的步骤S3的流程图;
图9为本发明实施例提供的步骤S33的流程图;
图10为本发明实施例提供的步骤S4的流程图;
图11为本发明实施例提供的步骤S1的流程图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
参照图1所示,本发明实施例提供的基于Web的协同调试***,基于成熟的Web开发技术和平台,可实现便捷、友好、高效的***调试;该***包括:基于Web的图形化调试平台和***调试框架;
其中:
Web的图形化调试平台包括:
Web客户端浏览器模块11,通过HTML、CSS、Javascript技术以图形化界面形式,可以清晰地展现***调试功能,并向HTTP服务器模块发送调试请求,将GDB服务器调试模块返回的调试信息呈现给用户;
HTTP服务器模块12,接收Web客户端浏览器模块11即用户浏览器调试请求,并将GDBWrapper消息转换模块的输出结果返回给用户客户端浏览器;
GDBWrapper消息转换模块13,以Web Socket形式连接HTTP服务器模块,同时实现了基于Java的GDB MI调试接口连接GDB服务器调试模块,通过接收HTTP服务器模块处理的用户浏览器调试请求,发送给GDB服务器调试模块,并将GDB服务器调试结果返回给HTTP服务器模块;
GDB服务器调试模块14,通过TCP连接到QEMU模拟器,调试目标***和应用程序,并将调试结果信息返回给GDBWrapper消息转换模块,通过HTTP服务器模块,最终返回给用户浏览器。
上述的协同调试框架包括:
协同调试用户管理模块21,对所有调试用户以分组形式进行按组进行管理,每个调试组具有一个唯一表示ID,同一调试组用户所接收到的调试信息相同,用户可以加入已存在的某一调试组,也可以自己创建调试组;
协同调试权限管理模块22,每个调试组Session都维护一个唯一Token,只有拥有Token的用户可以向服务器发送调试命令,希望调试的用户可以向服务器发送Token请求,一旦获得Token即可向服务器发送调试命令,进行调试;
协同调试消息管理模块23,调试请求和调试结果信息采用统一管理机制,每一个调试请求和调试结果信息将返回给该调试组的所有调试成员,通过采用数据库缓存机制保证调试信息的一致性。
在实际使用当中,基于Web的协同调试***中的各个模块和组件是紧密结合,协调工作的,其中图形化调试平台和协同调试框架模块相互协调使用,图形化调试平台主要完成调试工作的预处理、调试和控制调试过程等任务,***调试模块则在调试过程中完成调试用户管理、调试权限协调和调试信息返回等任务,保证整个调试过程是一个有机的统一整体。
本实施例中,用户可以在浏览器界面上直接操作调试远端程序,不仅具有支持良好的图形化界面,而且能够实时获取调试信息,以更加清晰直观的方式完成调试工作;另一方面,协同调试功能使得调试用户可以不安装配置本地调试环境,只要向远端服务器发出调试请求,一旦获得调试权限,就可以像本地一样进行调试,这样大大降低了调试成本,提高了调试效率;同时该基于Web的协同调试***及方法,可以扩展到除了操作***内核级调试之外的其他调试应用,满足不同调试需求,具有可扩展性强,适用范围广的特点,结合了Web技术和调试技术的优点,为实现Web跨平台、可视化调试提供了较好的解决方案。
参照图2所示,表示该基于Web的协同调试***的调试平台架构整体示意图,图中以调试Linux内核为例进行说明,该基于Web的图形化调试平台包括:
Web客户端浏览器,以图形化界面向用户展现调试功能,并通过网络与HTTP服务器交互,完成调试功能;
HTTP服务器,通过Web Socket连接GDBWrapper发出调试命令请求,向客户端浏览器返回调试信息;
GDBWrapper消息转换模块,一方面通过Web Socket连接获取HTTP服务器端的调试请求,另一方面将GDB服务器调试结果返回给HTTP服务器;
GDB服务器,一方面通过TCP连接到QEMU模拟器,调试Linux内核,另一方面讲调试信息返回给GDBWrapper消息转换模块;
其中包括7个步骤:
①用户通过Web浏览器发出调试命令;
②HTTP服务器将接收到的调试命令转发给GDB Wrapper所在的计算机;
③GDBWrapper对上述调试命令进行转换后发给GDB服务器;
④GDB服务器与QEMU通信进行***调试操作;
⑤GDB Wrapper收集QEMU输出的调试信息;
⑥GDB Wrapper将调试返回信息发送给HTTP服务器;
⑦HTTP服务器将调试返回信息进行可视化处理后返回给客户端浏览器显示。
参照图3所示,表示该基于Web的协同调试***的Web客户端浏览器模块11展示的调试界面示意图。
其中,QEMU模拟器和Linux内核,作为调试目标平台和应用,只是本发明选择的一个实例,QEMU模拟器上也可以支持其他操作***内符合和应用程序的调试;本发明实施例对此不做限定。
数据库服务器,将HTTP服务器收集的调试信息保存起来,以便以后进行trace的分析和回放。
在一个实施例中,上述的调试请求可以包括以下一种或多种命令:
暂停Pause、运行Run、Step单步、设置断点Set Breakpoint、删除断点RemoveBreakpoint、设置观察点Set Watchpoint、删除观察点Remove Watchpoint、查看指定内存信息Memory、查看寄存器信息Register和退出Quit。
上述的调试信息也可以包括以下一种或多种信息:
***运行时线程堆栈信息、命令执行返回的GDB调试信息、断点列表信息、观察点列表信息、指定内存数据信息和寄存器数据信息。
在一个实施例中,上述GDBWrapper消息转换模块13,具体用于将Web客户端浏览器模块11发送的JSON格式数据转换为GDB服务器可执行的调试命令,以及将所述GDB服务器调试模块14返回的调试结果转换为Web客户端浏览器模块11显示的HTML格式数据。
其中:上述JSON格式数据的调试命令,具体格式比如为:
[GID][COMMAND]:[调试事件]。
上述的调试结果的格式比如为:
[GID][COMMAND]:[调试事件][线程堆栈][断点列表][内存信息][寄存器信息]。
基于同一发明构思,本发明实施例还提供了一种基于Web的协同调试方法,由于该方法所解决问题的原理与前述基于Web的协同调试***相似,因此该方法的实施可以参见前述***的实施,重复之处不再赘述。
本发明实施例还提供了一种基于Web的协同调试方法,基于上述任一项实施例所提供的基于Web的协同调试***,该方法参照图4所示,包括:
S1、Web的图形化调试平台预处理操作;
S2、协同调试预处理操作;
S3、断点调试操作;
S4、协同调试操作;
其中:步骤S1基于Web的图形化调试平台预处理操作,参照图5包括:
S11、所述基于Web的图形化调试平台根据预先配置的调试端口启动一个HTTP服务器模块,并记录服务器地址URL;该服务器地址URL格式比如可以为:http://[服务器地址]:[端口]/[路径名]。
S12、所述Web客户端浏览器模块输入服务器地址URL,向HTTP服务器模块发送HTTP请求;
S13、所述GDBWrapper消息转换模块和GDB服务器调试模块进行初始化操作;
进一步地,参照图6所示,上述步骤S13包括:
S131、所述GDB服务器调试模块通过与QEMU中运行的操作***或者应用程序建立TCP连接,对所述操作***或者应用程序进行调试;
S132、所述GDBWrapper消息转换模块,与所述GDB服务器调试模块建立TCP连接进行通信,且与HTTP服务器模块通过Web Socket建立连接通信。
GDBWrapper消息转换模块与HTTP服务器模块建立Web Socket连接格式为:[服务器地址]:[调试端口]。
GDBWrapper消息转换模块与GDB服务器调试模块建立TCP连接格式为:[127.0.0.1]:[端口]。
步骤S2所述协同调试预处理操作,参照图7所示,包括以下步骤:
S21、调试用户通过相应权限登录调试***;
S22、所述协同调试用户管理模块根据用户请求为用户创建一个新的调试组或者加入到一个已有的调试组;
步骤S3所述断点调试操作,参照图8所示,包括以下步骤:
S31、所述基于Web的图形化调试平台根据用户请求搜索相关函数或者全局变量,在Web客户端浏览器模块中选择需要设置断点的相关函数或者全局变量;
S32、所述Web客户端浏览器模块发出设置断点请求,将所述设置断点请求和相关函数或者全局变量发送给HTTP服务器模块;
S33、所述HTTP服务器模块将所述断点请求发送给GDBWrapper消息转换模块进行消息转换,并将所述设置断点请求和相关函数或者全局变量相对应的调试请求发送给GDB服务器调试模块,执行调试命令;
具体地,参照图9所示,步骤S33包括:
S331、所述HTTP服务器模块解析Web客户端浏览器模块发送的调试请求,执行相应的操作,主要包括以下步骤:
(a)当接收到的所述调试请求为Quit退出命令,则发出一个中断GDB服务器的命令;
(b)当接收到的所述调试请求为Set/Remove Breakpoint或者Set/RemoveWatchpoint,则向GDB服务器调试模块发出设置或者删除断点/观察点的命令;
(c)当接收的所述调试请求为Memory查看内存信息或者Register查看寄存器信息,则向GDB服务器调试模块发出查看内存信息或者寄存器信息相关格式的命令;
(d)当接收的所述调试请求为Pause暂停或者Run继续执行命令,则向GDB服务器调试模块发出中断执行或者继续执行命令;
(e)当接收的所述调试请求为Step单步执行命令,则向GDB服务器调试模块发出单步调试命令,以函数为基本调试单位单步执行。
S332、所述HTTP服务器模块将解析后的调试请求发送给所述GDBWrapper消息转换模块,所述GDBWrapper消息转换模块将调试请求转换为GDB服务器调试模块可执行的GDB/MI命令,并接收所述GDB服务器调试模块返回的调试结果,将所述调试结果转换为相应的数据格式返回给HTTP服务器模块。
S34、所述GDB服务器调试模块将返回的断点列表信息、线程信息和控制台信息返回GDBWrapper消息转换模块进行消息转换,并将转换后的调试结果返回给HTTP服务器模块;
步骤S4协同调试操作,参照图10所示,包括以下步骤:
S41、所述协同调试用户管理模块为第一个调试用户创建一个调试实例,所述调试实例维护一个调试组信息和一个调试Token;
S42、新加入调试组的调试用户,向所述协同调试权限管理模块发出获取Token请求;请求得到确认后,获得调试权限;
S43、所述协同调试消息管理模块在每次调试信息返回时,为所述调试组的所有调试成员返回相同的调试信息。
参阅图11所示,表示该基于Web的协同调试方法的协同调试过程流程图,其协同调试过程包括以下步骤:
步骤111、开始;
步骤112、启动HTTP服务器模块;基于Web的图形化调试平台根据预先配置的调试端口启动一个HTTP服务器模块,并记录服务器地址URL
步骤113、打开Web客户端浏览器,输入HTTP服务器URL地址;Web客户端浏览器模块打开浏览器,输入服务器地址URL,向HTTP服务器模块发送HTTP请求
步骤114、GDBWrapper消息转换模块和GDB服务器调试模块初始化;
步骤115、调试用户输入用户名和密码登录调试***;
步骤116、判断登录成功;否则执行步骤115,是则执行步骤117;
步骤117、用户选择是否创建调试组;是则执行步骤118,否则执行步骤124;协同调试用户管理模块根据用户请求为用户创建一个新的调试组或者加入到一个已有的调试组;当选择加入一个已有的调试组后,可以直接从HTTP服务器端直接获取同一组内的协同调试信息。
步骤118、获取调试权限,启动调试;
步骤119、设置调试断点;基于Web的图形化调试平台根据用户请求搜索相关函数或者全局变量,在Web客户端浏览器选中需要设置断点的函数或者全局变量;
步骤120、向HTTP服务器发送调试命令;获得调试权限的Web客户端浏览器发出设置断点请求,将设置断点请求和相关函数或者全局变量一起发送给HTTP服务器;
步骤121、GDBWrapper进行消息转换,向GDB服务器发送调试命令;HTTP服务器将断点和请求发送给GDBWrapper进行消息转换,并将调试请求命令发送给GDB服务器,执行调试命令;
步骤122、GDB服务器执行调试命令,并返回调试结果;GDB服务器将返回的断点列表信息、线程信息和控制台信息返回GDBWrapper进行消息转换,并将处理后调试信息返回给HTTP服务器,最终以HTML形式返回给客户端浏览器。
步骤123、调试命令和返回的调试结果保存至数据库服务器;
步骤124、从HTTP服务器端直接获取同一组内的协同调试信息;
步骤125、结束。
本领域内的技术人员应明白,本发明的实施例可提供为方法、***、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器和光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(***)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。

Claims (9)

1.一种基于Web的协同调试***,其特征在于,包括基于Web的图形化调试平台和***调试框架;
所述基于Web的图形化调试平台包括:
Web客户端浏览器模块,用于向HTTP服务器模块发送调试请求,将GDB服务器调试模块返回的调试信息呈现给用户;
HTTP服务器模块,用于接收所述调试请求,并将GDBWrapper消息转换模块的输出结果返回给用户客户端浏览器;
GDBWrapper消息转换模块,用于接收所述HTTP服务器模块处理的所述调试请求,并将所述调试请求发送给GDB服务器调试模块;以及接收所述GDB服务器调试模块的发送的调试结果,将所述调试结果返回给所述HTTP服务器模块;
GDB服务器调试模块,用于调试所述调试请求相对应的目标***和应用程序,将调试结果返回给GDBWrapper消息转换模块。
所述协同调试框架包括:
协同调试用户管理模块,用于将所有调试用户分为多个调试组进行管理,并根据用户请求为用户创建一个新的调试组或将用户加入到现有的调试组;每个调试组具有唯一表示ID,同一所述调试组的用户所接收到的调试信息相同;
协同调试权限管理模块,用于确定每个调试组的待调试用户是否拥有唯一Token;所述每个调试组Session维护一个唯一Token,当拥有Token的用户有权限发送调试命令;
协同调试消息管理模块,用于对所述调试请求和调试结果采用统一管理机制,将每一个调试请求和调试结果返回给相对应调试组的所有调试成员,通过采用数据库缓存机制保证调试信息的一致性。
2.如权利要求1所述的一种基于Web的协同调试***,其特征在于,所述调试请求包括以下一种或多种命令:
暂停Pause、运行Run、Step单步、设置断点Set Breakpoint、删除断点RemoveBreakpoint、设置观察点Set Watchpoint、删除观察点Remove Watchpoint、查看指定内存信息Memory、查看寄存器信息Register和退出Quit。
3.如权利要求1所述的一种基于Web的协同调试***,其特征在于,所述调试信息包括以下一种或多种信息:
***运行时线程堆栈信息、命令执行返回的GDB调试信息、断点列表信息、观察点列表信息、指定内存数据信息和寄存器数据信息。
4.如权利要求1所述的一种基于Web的协同调试***,其特征在于,所述GDBWrapper消息转换模块,具体用于将所述Web客户端浏览器模块发送的JSON格式数据转换为GDB服务器可执行的调试命令,以及将所述GDB服务器调试模块返回的调试结果转换为所述Web客户端浏览器模块显示的HTML格式数据。
5.如权利要求4所述的一种基于Web的协同调试***,其特征在于,所述JSON格式数据的调试命令,具体格式为:
[GID][COMMAND]:[调试事件]。
6.如权利要求4所述的一种基于Web的协同调试***,其特征在于,所述的调试结果的格式为:
[GID][COMMAND]:[调试事件][线程堆栈][断点列表][内存信息][寄存器信息]。
7.一种基于Web的协同调试方法,其特征在于,所述方法包括:基于Web的图形化调试平台预处理操作、协同调试预处理操作、断点调试操作和协同调试操作;
所述基于Web的图形化调试平台预处理操作,包括以下步骤:
(11)所述基于Web的图形化调试平台根据预先配置的调试端口启动一个HTTP服务器模块,并记录服务器地址URL;
(12)所述Web客户端浏览器模块输入服务器地址URL,向HTTP服务器模块发送HTTP请求;
(13)所述GDBWrapper消息转换模块和GDB服务器调试模块进行初始化操作;
所述协同调试预处理操作,包括以下步骤:
(21)调试用户通过相应权限登录调试***;
(22)所述协同调试用户管理模块根据用户请求为用户创建一个新的调试组或者加入到一个已有的调试组;
所述断点调试操作,包括以下步骤:
(31)所述基于Web的图形化调试平台根据用户请求搜索相关函数或者全局变量,在Web客户端浏览器模块中选择需要设置断点的相关函数或者全局变量;
(32)所述Web客户端浏览器模块发出设置断点请求,将所述设置断点请求和相关函数或者全局变量发送给HTTP服务器模块;
(33)所述HTTP服务器模块将所述断点请求发送给GDBWrapper消息转换模块进行消息转换,并将所述设置断点请求和相关函数或者全局变量相对应的调试请求发送给GDB服务器调试模块,执行调试命令;
(34)所述GDB服务器调试模块将返回的断点列表信息、线程信息和控制台信息返回GDBWrapper消息转换模块进行消息转换,并将转换后的调试结果返回给HTTP服务器模块;
协同调试操作,包括以下步骤:
(41)所述协同调试用户管理模块为第一个调试用户创建一个调试实例,所述调试实例维护一个调试组信息和一个调试Token;
(42)新加入调试组的调试用户,向所述协同调试权限管理模块发出获取Token请求;请求得到确认后,获得调试权限;
(43)所述协同调试消息管理模块在每次调试信息返回时,为所述调试组的所有调试成员返回相同的调试信息。
8.如权利要求7所述的一种基于Web的协同调试方法,其特征在于,所述GDBWrapper消息转换模块和GDB服务器调试模块进行初始化操作,包括以下步骤:
(131)所述GDB服务器调试模块通过与QEMU中运行的操作***或者应用程序建立TCP连接,对所述操作***或者应用程序进行调试;
(132)所述GDBWrapper消息转换模块,与所述GDB服务器调试模块建立TCP连接进行通信,且与HTTP服务器模块通过Web Socket建立连接通信。
9.如权利要求7所述的一种基于Web的协同调试方法,其特征在于,将所述设置断点请求和相关函数或者全局变量相对应的调试请求发送给GDB服务器调试模块,执行调试命令,包括以下步骤:
(331)所述HTTP服务器模块解析Web客户端浏览器模块发送的调试请求,执行相应的操作,主要包括以下步骤:
(a)当接收到的所述调试请求为Quit退出命令,则发出一个中断GDB服务器的命令;
(b)当接收到的所述调试请求为Set/Remove Breakpoint或者Set/RemoveWatchpoint,则向GDB服务器调试模块发出设置或者删除断点/观察点的命令;
(c)当接收的所述调试请求为Memory查看内存信息或者Register查看寄存器信息,则向GDB服务器调试模块发出查看内存信息或者寄存器信息相关格式的命令;
(d)当接收的所述调试请求为Pause暂停或者Run继续执行命令,则向GDB服务器调试模块发出中断执行或者继续执行命令;
(e)当接收的所述调试请求为Step单步执行命令,则向GDB服务器调试模块发出单步调试命令,以函数为基本调试单位单步执行。
(332)所述HTTP服务器模块将解析后的调试请求发送给所述GDBWrapper消息转换模块,所述GDBWrapper消息转换模块将调试请求转换为GDB服务器调试模块可执行的GDB/MI命令,并接收所述GDB服务器调试模块返回的调试结果,将所述调试结果转换为相应的数据格式返回给HTTP服务器模块。
CN201810552504.2A 2018-05-31 2018-05-31 一种基于Web的协同调试***及方法 Active CN108829591B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810552504.2A CN108829591B (zh) 2018-05-31 2018-05-31 一种基于Web的协同调试***及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810552504.2A CN108829591B (zh) 2018-05-31 2018-05-31 一种基于Web的协同调试***及方法

Publications (2)

Publication Number Publication Date
CN108829591A true CN108829591A (zh) 2018-11-16
CN108829591B CN108829591B (zh) 2021-05-04

Family

ID=64147021

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810552504.2A Active CN108829591B (zh) 2018-05-31 2018-05-31 一种基于Web的协同调试***及方法

Country Status (1)

Country Link
CN (1) CN108829591B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110727577A (zh) * 2019-08-29 2020-01-24 华东计算技术研究所(中国电子科技集团公司第三十二研究所) 嵌入式***软件中概率复现问题的调试方法、***及介质
CN113760688A (zh) * 2020-06-05 2021-12-07 腾讯科技(深圳)有限公司 一种远程调试方法、***、网页服务器、设备及存储介质
WO2022143108A1 (zh) * 2020-12-30 2022-07-07 华为技术有限公司 一种软件调试方法、电子设备及调试***
CN114968751A (zh) * 2021-02-24 2022-08-30 中国联合网络通信集团有限公司 一种无代码开发平台的程序调试方法和程序调试装置

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6216237B1 (en) * 1998-06-19 2001-04-10 Lucent Technologies Inc. Distributed indirect software instrumentation
CN1564136A (zh) * 2004-04-02 2005-01-12 清华大学 基于目标机上的ejtag部件的交叉调试器实现方法
US20080095143A1 (en) * 2006-10-19 2008-04-24 Research In Motion Limited System and method for providing debug information in session initiation protocol sessions
CN201491026U (zh) * 2009-07-31 2010-05-26 福建升腾资讯有限公司 基于万维网的调试***
CN101719093A (zh) * 2009-12-09 2010-06-02 上海普元信息技术有限责任公司 企业Web应用***中实现跨浏览器Javascript调试的***及其方法
CN104683378A (zh) * 2013-11-27 2015-06-03 上海墨芋电子科技有限公司 新技术的一种新型云计算服务平台的计算调试***

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6216237B1 (en) * 1998-06-19 2001-04-10 Lucent Technologies Inc. Distributed indirect software instrumentation
CN1564136A (zh) * 2004-04-02 2005-01-12 清华大学 基于目标机上的ejtag部件的交叉调试器实现方法
US20080095143A1 (en) * 2006-10-19 2008-04-24 Research In Motion Limited System and method for providing debug information in session initiation protocol sessions
CN201491026U (zh) * 2009-07-31 2010-05-26 福建升腾资讯有限公司 基于万维网的调试***
CN101719093A (zh) * 2009-12-09 2010-06-02 上海普元信息技术有限责任公司 企业Web应用***中实现跨浏览器Javascript调试的***及其方法
CN104683378A (zh) * 2013-11-27 2015-06-03 上海墨芋电子科技有限公司 新技术的一种新型云计算服务平台的计算调试***

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
AVI ROZEN: "Remote cross-target debugging with GDB andGDBserver", 《HTTPS://WWW.LINUX.COM/NEWS/REMOTE-CROSS-TARGET-DEBUGGING-GDB-AND-GDBSERVER/》 *
张津伟: "嵌入式协同调试环境研究与设计", 《中国优秀硕士学位论文全文数据库信息科技辑》 *
王伟杰: "嵌入式可视化协同调试技术的研究与应用", 《中国优秀硕士学位论文全文数据库信息科技辑》 *

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110727577A (zh) * 2019-08-29 2020-01-24 华东计算技术研究所(中国电子科技集团公司第三十二研究所) 嵌入式***软件中概率复现问题的调试方法、***及介质
CN110727577B (zh) * 2019-08-29 2023-06-09 华东计算技术研究所(中国电子科技集团公司第三十二研究所) 嵌入式***软件中概率复现问题的调试方法、***及介质
CN113760688A (zh) * 2020-06-05 2021-12-07 腾讯科技(深圳)有限公司 一种远程调试方法、***、网页服务器、设备及存储介质
WO2022143108A1 (zh) * 2020-12-30 2022-07-07 华为技术有限公司 一种软件调试方法、电子设备及调试***
CN114968751A (zh) * 2021-02-24 2022-08-30 中国联合网络通信集团有限公司 一种无代码开发平台的程序调试方法和程序调试装置

Also Published As

Publication number Publication date
CN108829591B (zh) 2021-05-04

Similar Documents

Publication Publication Date Title
CN108829591A (zh) 一种基于Web的协同调试***及方法
US8239839B2 (en) Asynchrony debugging using web services interface
US8490050B2 (en) Automatic generation of user interfaces
US8584079B2 (en) Quality on submit process
US7665064B2 (en) Systems and methods for web service function, definition, implementation, and/or execution
US20050071243A1 (en) Non-disruptive business process debugging and analysis
US6868454B1 (en) Distributed-object development system and computer-readable recording medium recorded with program for making computer execute distributed-object development
US8769502B2 (en) Template based asynchrony debugging configuration
US20190146898A1 (en) Assistive, language-agnostic debugging with multi-collaborator control
US20160217159A1 (en) Database virtualization
US20100145978A1 (en) Techniques to provide unified logging services
US20200133829A1 (en) Methods and systems for performance testing
CN105739987A (zh) 面向SOA的快速构建JavaWeb应用的***框架
US20160125052A1 (en) Database virtualization
EP2307962A1 (en) Systems and methods for visual test authoring and automation
US20120278790A1 (en) Collaborative Software Debugging In A Distributed System With Real-Time Variable Modification Indicators
CN110377283B (zh) Web前后端分离开发时前端有效数据的实现及同步方法
US20080244062A1 (en) Scenario based performance testing
CN103544100A (zh) 便携数据处理设备应用程序的测试方法、***和客户端
Zyrianov et al. Automated recording and semantics-aware replaying of high-speed eye tracking and interaction data to support cognitive studies of software engineering tasks
Vera et al. Event-based execution architectures for dynamic software systems
US20060253854A1 (en) Extensible infrastructure for task display and launch
US9298428B2 (en) Graphical user interface editor that displays live data during editing
Zyrianov et al. Deja Vu: semantics-aware recording and replay of high-speed eye tracking and interaction data to support cognitive studies of software engineering tasks—methodology and analyses
WO2022240310A1 (ru) Система управления тестированием программного обеспечения

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant