寫程式碼總繞不過需要除錯,除了 UnitTest 外,我們還是需要藉助 Xdebug 進行除錯。
所以今天來說說如何基於本地 Docker 環境下,使用 Xdebug。
這裡的使用,是分別整合到 VS Code 和 PHPStorm 下。
data:image/s3,"s3://crabby-images/2af64/2af645786f98c6f2ef1c9e148fdab590b12c7f2a" alt="推薦程式碼除錯工具 Xdebug"
安裝 Xdebug
還是基於神級武器 —— Laradock。我們先看看 Laradock 官網是怎麼安裝 Xdebug。
Install xDebug#
1 - First install xDebug in the Workspace and the PHP-FPM Containers:
a) open the .env file b) search for the WORKSPACE_INSTALL_XDEBUG argument under the Workspace Container c) set it to true d) search for the PHP_FPM_INSTALL_XDEBUG argument under the PHP-FPM Container e) set it to true
2 - Re-build the containers docker-compose build workspace php-fpm
我們修改對應的地方,然後 build
,如果出現下面的錯誤提示:
data:image/s3,"s3://crabby-images/259ce/259ce5c2a756866c138d77c1deb9b7d14a1324ac" alt="推薦程式碼除錯工具 Xdebug"
嘗試新增國內源試試:
RUN sed -i s@/archive.ubuntu.com/@/mirrors.aliyun.com/@g /etc/apt/sources.list
複製程式碼
重新 docker-compose up -d nginx
後,在 Windows / Mac 下用命令 ./php-fpm/xdebug status
檢視安裝狀態:
data:image/s3,"s3://crabby-images/29f49/29f49fdd92b69986a508d60d671ec5b9fd3256cb" alt="mark"
配置 Xdebug
目前開發使用 IDE,個人覺得普遍用的最多的就是 VS Code 和 PHPStorm。所以下面就利用這兩個 IDE,分別說說如何使用 Xdebug 的。
VS Code
在 VS Code 下,如果沒安裝 Xdebug 外掛,直接搜尋安裝即可:
data:image/s3,"s3://crabby-images/f5eee/f5eee49c068838c7eed349ce207c0c82274943a6" alt="mark"
安裝後,增加 Xdebug 環境配置:
data:image/s3,"s3://crabby-images/290d3/290d308beae2f52619bedf805e11932c14226542" alt="mark"
這樣就會專案的 .vscode
資料夾下多了一個 Xdebug 配置檔案 launch.json
,我們配置埠號與 php-fpm
下的 Xdebug
一致,我們再配置 pathMappings
讓 docker
下的專案路徑與本地專案路徑關聯。具體如下:
{
"version": "0.2.0",
"configurations": [
{
"name": "XDebug listening to Laradock",
"log": true,
"type": "php",
"request": "launch",
"port": 9000,
"pathMappings": {
"/var/www/myrss": "${workspaceFolder}",
}
},
{
"name": "Launch currently open script",
"type": "php",
"request": "launch",
"program": "${file}",
"cwd": "${fileDirname}",
"port": 9000
}
]
}
複製程式碼
好了,我們啟動 XDebug
,列印出如下內容,即表示等待請求:
data:image/s3,"s3://crabby-images/866b8/866b832120a2edb95e84c595896d564dde209318" alt="推薦程式碼除錯工具 Xdebug"
我們寫個 Demo,並設定斷點:
Artisan::command('hello', function () {
$i = 0;
$i++;
return "hello".$i;
});
複製程式碼
data:image/s3,"s3://crabby-images/aade8/aade8d8848e4005ec19f01eda4d072c726d42e44" alt="推薦程式碼除錯工具 Xdebug"
然後啟動 Xdebug
,並執行命令:
php artisan hello
複製程式碼
我們可以看到很多輸入、輸出、斷點等資訊:
data:image/s3,"s3://crabby-images/5932c/5932c79223d865cec85ffc00e8e09a11a51a228f" alt="推薦程式碼除錯工具 Xdebug"
其中我們也能看到此時的變數 $i
處於未初始狀態:
data:image/s3,"s3://crabby-images/2e7a2/2e7a2d2676f695e0112a113ce554baea02e185e4" alt="推薦程式碼除錯工具 Xdebug"
我們在這斷點繼續往下執行:
data:image/s3,"s3://crabby-images/8d9a5/8d9a5c5f765bc9cc209e3e7cc232018346c3948a" alt="推薦程式碼除錯工具 Xdebug"
data:image/s3,"s3://crabby-images/2318e/2318e1fde8e32b1c0363588fbd746b6ef129ce97" alt="推薦程式碼除錯工具 Xdebug"
PHPStorm
在 Mac 或者 Windows 10 下 Docker 的預設 ip 為:10.0.75.1,
我們先增加一個 Server,其中:
- Name:laradock
- Host: 10.0.75.1
- mappings,等同於上文 VS Code 配置的 pathMappings
data:image/s3,"s3://crabby-images/40f4c/40f4c4f2ed313cb7631bbcb27e05521151782427" alt="推薦程式碼除錯工具 Xdebug"
然後,可以新建 PHP Remote Debug,其中:
- Server:關聯到我們上面建的 laradock
- IDE key:和 Laradock‘s php-fpm 中配置的保持一致即可
data:image/s3,"s3://crabby-images/d0d40/d0d403bef91b5ab77469ca802bd03cf6da02f980" alt="推薦程式碼除錯工具 Xdebug"
好了,我們可以使用 demo,建立斷點,執行 Debug 等待請求::
data:image/s3,"s3://crabby-images/68bd8/68bd83940c534663c3a13e6559ffe8e5eae58388" alt="推薦程式碼除錯工具 Xdebug"
一樣的,執行命令:php artisan hello
:
data:image/s3,"s3://crabby-images/6eb4e/6eb4ef90654028d85e867428789385e2c17edac7" alt="推薦程式碼除錯工具 Xdebug"
我們繼續往下走:
data:image/s3,"s3://crabby-images/32dd8/32dd8d5cd6e8e36b6a1b396abdb0e69a44bb93e1" alt="推薦程式碼除錯工具 Xdebug"
總結
用好 Xdebug,更加直觀的瞭解方法中每個變數的動態變化,能提高我們跟蹤和排查程式碼的問題所在。至於下一步如何更好的使用 Xdebug,就看各自的實際專案和開發需要了。
參考
Setting up xDebug with PHPUnit using Docker for Mac and PHPStorm intellij-support.jetbrains.com/hc/en-us/co…
Laradock + XDebug + MS Code? No problem medium.com/full-stack-…
Laradock的xdebug在vscode上使用的配置 www.itread01.com/content/152…
如何設定VSCode XDebug在laradock環境上 blog.scottchayaa.com/post/2018/1…