xdebug详解及在vscode应用

2024-06-12 15:48
文章标签 应用 详解 vscode xdebug

本文主要是介绍xdebug详解及在vscode应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Xdebug在vscode中的应用

优点:仅仅只需在vscode安装php debug插件,完全零配置,不需要在浏览器端装任何(即不需要担心http会话,浏览器传一些变量参数,设置idekey之类)插件。所需要的只是:打开vscode打断点后,按F5打开调试按钮运行,然后浏览器访问,再进入代码即可。
php.ini仅仅只需要开启以下两项配置,其他皆用默认值就够用了(前提安装好了扩展)

xdebug.remote_enable = 1
xdebug.remote_autostart = 1

如果想做性能分析,溯源,调用流程,请参阅xdebug官网

Xdebug生命周期

  1. IDE(比如vscode客户端)中已经集成了一个遵循BGDpXdebug插件。当要debug的时候,点击一些IDE的某个按钮,启动这个插件。该插件会启动一个9000的端口监听远程服务器发过来的debug信息。

  2. 浏览器向Httpd服务器发送一个带有XDEBUG_SESSION_START参数的请求,Httpd收到这个请求之后交给后端的PHP进行处理(下面就忽略Httpd,直接把Php叫做Server)。

  3. Php看到这个请求是带了XDEBUG_SESSION_START 参数,就告诉XdebugXdebug这时会向来源ip客户端的9000端口(即客户端,也即是IDE)发送一个debug请求,然后客户端的9000端口响应这个请求,那么debug就开始了。

  4. Php知道Xdebug已经准备好了,那么就开始开始一行一行的执行代码,但是每执行一行都会让Xdebug过滤一下。

  5. Xdebug开始过滤代码,Xdebug在过滤每一行代码的时候,都会暂停代码的执行,然后向客户端的9000端口发送该行代码的执行情况,等待客户端的决策(是一句代码还是下一个断点待)。

  6. 相应,客户端(IDE)收到Xdebug发送过来的执行情况,就可以把这些信息展示给开发者看了,包括一些变量的值等。同时向Xdebug发送下一步应该什么。

Xdebug远程调试分析

  1. xdebug配合IDE进行可视化调试的过程被称为“远程调试
  2. 调试时有一个Server(xdebug)和一个Client(IDE),换而言之,xdebug在php.ini配置的主机端口其实是客户端ide信息
  3. xdebug在进行远程调试的时候扮演一个Server的角色,它会在一个指定的端口(默认是9000)等待IDE的连接。
  4. 通讯协议GDB和DBGp
  • DBGp是DBG的取代协议
  • 客户端IDE调试 --> 服务端xdebug执行命令 -> PHP程序运行信息返回给ide
  1. 远程调方式
  • req:在PHP程序开始执行的时候,xdebug与IDE建立连接
  • jit:在PHP程序执行到断点处或者遇到Error的时候,xdebug才与IDE建立连接

启动调试器

这部分内容,通常情况下都由ide或浏览器插件已经实现,只需要安装相应插件即可

  • 三种方式
    • 在命令行中运行脚本,需要设置相应环境变量
    • 在浏览器调试脚本,只需要URL添加 XDEBUG_SESSION_START=session_name参数

替代GET参数也可以设置XDEBUG_SESSTION_START为POST参数,或是COOKIE参数

  • 在浏览器运行PHP并激活调试器需安装调试相关浏览器插件

当这些插件激活,它们会直接设置XDEBUG_SESSION的cookie值,代替XDEBUG_SESSION_START。

HTTP调试会话

Xdebug包含使用cookie对浏览器启动跟踪调试会话功能。该工作类似下面步骤:

  1. 当URL变量XDEBUG_SESSION_START=name附加到URL后,或通过POST传入相同名称值——Xdebug发出一cookie值”XDEBUG_SESSION”而该值为URL参数XDEBUG_SESSION_START值。Cookie值有效期为1小时。DBGp协议也会将相同的值在连接到调试客户端时传到初始数据包内的“idekey”属性。
  2. XDEBUG_SESSION_STARTXDEBUG_SESSION cookie 一旦设置,Xdebug就会尝试连接到调试客户端。
  3. 要停止调试会话(和销毁附带cookie) 只需简单地添加URL参数XDEBUG_SESSION_STOPXdebug然后不再尝试创建连接到高度调试客户端。

Xdebug在php.ini次级配置

//如果开启此,将忽略下面的 xdebug.remote_host 的参数。 
// 设置用于开发服务器共享给多名开发者使用 
xdebug.remote_connect_back = On        
//注意这里是,客户端的ip即IDE的机器的ip
xdebug.remote_host = 192.168.59.104   
xdebug.remote_port = 9900    //  默认端口9000,根据自己本机改                   
xdebug.remote_enable = On		//开启调试器
xdebug.remote_handler = dbgp

这篇关于xdebug详解及在vscode应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1054652

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客