溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHPSTORM中怎么調試Docker項目

發(fā)布時間:2021-06-30 14:58:13 來源:億速云 閱讀:496 作者:Leah 欄目:網絡管理

這篇文章給大家介紹PHPSTORM中怎么調試Docker項目,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

Docker基本用法

首先要知道 Docker 最基本的兩樣東西:imagecontainer

image        鏡像,搭建一個 Docker 環(huán)境最基本的就是 image??梢?strong>簡單理解為這就是創(chuàng)建虛擬機的那個鏡像。

container  容器。即 依據 image,創(chuàng)建出來的虛擬環(huán)境??梢?strong>簡單理解為就是運行著的虛擬機

Docker 的配置文件為 Dockerfile。該文件內容為構建 container 的命令?;久钣校?/p>

FROM     設置 container 運行在哪個 image 上。必須寫在 Dockerfile 的開頭??梢栽?Docker Hub里找適合的 image。

RUN        在 image build時執(zhí)行命令。一般用于安裝環(huán)境

CMD       在 container剛啟動時執(zhí)行命令。一般用于啟動服務

COPY      將宿主機的文件拷貝到 container中

WORKDIR   設置工作目錄。所有命令都會在這個目錄的基礎上進行工作

了解了上面的三個命令后,我們可以來簡單寫一個 Dockerfile了。

#基礎 image 為 php:7.3-apache
FROM php:7.3-apache
#安裝 xdebug 擴展 并開啟
RUN pecl install xdebug && \
docker-php-ext-enable xdebug
#將 宿主機的 phpinfo.php 拷貝到 container /var/www/html/phpinfo.php 中
COPY ./phpinfo.php /var/www/html/phpinfo.php

寫完后在 Dockerfile 的目錄里運行

docker build -t test/testmyphp .

等命令跑完,輸入以下命令即可看到創(chuàng)建好的 image

$ docker image ls
REPOSITORY   TAG   IMAGE ID  ......
test/testmyphp   latest  4931b92274f2 ......

要想讓 container 運行起來,使用如下命令。使用-p來指定映射端口,左邊是宿舍機端口,右邊是 container 端口

docker run -p 81:80 test/testmyphp

查看運行中的 container

$ docker container ls
CONTAINER ID        IMAGE           PORTS            ......
10b8c28b2f69        test/testmyphp     0.0.0.0:81->80/tcp   ......

進入 container 的 shell

$ docker exec -it CONTAINER_ID值 bash
root@10b8c28b2f69:/var/www/html#

至此,基本的 Docker 環(huán)境我們就建好了。接下來研究下如何讓 PHPSTORM 調試 Docker 項目

調試方式一 - Docker掛載調試

這里做測試使用前文的 Dockerfile,需要按照實際情況進行配置添加。

配置Dockerfile

#基礎 image 為 php:7.3-apache
FROM php:7.3-apache
#安裝 xdebug 擴展 并開啟
RUN pecl install xdebug && \
docker-php-ext-enable xdebug
# !!! 使用一個啟動腳本來啟動服務 !!!
COPY ./start.sh /start.sh
RUN chmod +x /start.sh
CMD ["/start.sh"]

start.sh 內容

#配置 Xdebug
echo "xdebug.client_host = host.docker.internal" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.client_port = 9003" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.mode = debug" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.max_nesting_level = 1000" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.discover_client_host = true" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
#重啟 apache ssh
service apache2 restart

重建 image:

#最好先刪掉之前的再重建
docker image rm IMAGE值 -f
docker build -t test/testmyphp .

重建完先不急著跑 container。先定位到我們的項目代碼位置

PHPSTORM中怎么調試Docker項目

使用 Docker 的 Bind mounts 技術。將宿主機的項目目錄映射到 container 的網站目錄下

docker run -p 81:80 --mount type=bind,source=/home/xp/test_docker/test_program,target=/var/www/html test/testmyphp

至此,調試環(huán)境所需要的服務就安裝好了,接下來配置 PHPSTORM。

配置 PHPSTORM

直接使用Open打開項目

配置 目錄映射

進入 File -> Settings -> Languages & Frameworks -> PHP -> Servers。配置目錄映射

注意一定要把 Use path mappings 的勾勾上,才能配置目錄映射

Absolute path on the server 是要手動打上服務器路徑的

PHPSTORM中怎么調試Docker項目

設置Xdebug端口

進入 File -> Settings -> Languages & Frameworks -> PHP -> Debug。設置 Xdebug Debug port 為 9003。和 php 配置一致。

PHPSTORM中怎么調試Docker項目

配置一個 Run/Debug Configuration

點擊 PHPSTORM 右上角的 Add Configuration....。進入配置面,新增一個 PHP Web Page。并進行如下簡單的配置即可(改名字設url 路徑)

PHPSTORM中怎么調試Docker項目

啟動 PHP Debug Listening

直接點擊 PHPSTROM 右上角的 小電話 ,即可開啟監(jiān)聽

PHPSTORM中怎么調試Docker項目

驗證

在 php文件上打上斷點,點擊 右上角 甲殼蟲樣式的 Debug按鈕。即可成功斷點

PHPSTORM中怎么調試Docker項目

調試方式二 - ssh 隧道

這種方式不僅僅可以用在 Docker 環(huán)境上,同樣可以用在 遠程服務器上。缺點就是要在 container 里頭安裝許多額外服務。

配置Dockerfile

  1. 安裝ssh服務。 PHPSTORM需要 ssh 來進行目錄映射,不然無法成功 Debug

  2. 安裝 xdebug。這是調試的基礎擴展組件

  3. 設置 ssh 允許 root 登陸。畢竟只是個 docker 調試環(huán)境,就不弄那么麻煩了。當然如果是線上業(yè)務啥的當然要做好權限分配。

  4. 修改 root密碼。畢竟不知道密碼也無法連接

  5. 啟動 ssh 服務

  6. 重啟 apache 服務

這里做測試使用前文的 Dockerfile,需要按照實際情況進行配置添加。

修改前文的 Dockerfile。

#基礎 image 為 php:7.3-apache
FROM php:7.3-apache

ENV APACHE_DOCUMENT_ROOT /var/www/html
#安裝 ssh 服務
RUN apt-get update && \
apt-get install ssh -y
#安裝 xdebug 擴展 并開啟
RUN pecl install xdebug && \
docker-php-ext-enable xdebug
#將宿主機的 phpinfo.php 拷貝到 container /var/www/html/phpinfo.php 中
COPY ./phpinfo.php /var/www/html/phpinfo.php
# !!! 使用一個啟動腳本來完成流程 3 4 5 的工作 !!!
COPY ./start.sh /start.sh
RUN chmod +x /start.sh
CMD ["/start.sh"]

start.sh 內容

#!/bin/bash
#設置 ssh 允許 root 登錄
echo 'PermitRootLogin yes' >> /etc/ssh/sshd_config
#修改root密碼
echo root:123456 | chpasswd
#配置 Xdebug。Xdebug 3 的配置如下,和 Xdebug 2不太一樣
echo "xdebug.client_host = host.docker.internal" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.client_port = 9003" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.mode = debug" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.max_nesting_level = 1000" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
echo "xdebug.discover_client_host = true" >> /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
#重啟 apache ssh
service apache2 restart
service ssh restart
#要加上這個,不然 container 運行完就停止了。
sleep infinity

重建 image:

#最好先刪掉之前的再重建
docker image rm IMAGE值 -f
docker build -t test/testmyphp .

啟動 container:

docker run -p 81:80 -p 2222:22 test/testmyphp

至此,調試環(huán)境所需要的服務就安裝好了,接下來配置 PHPSTORM。

配置 PHPSTORM

打開 PHPSTORM,新建一個 Project。選擇 New Project from Existing Files

PHPSTORM中怎么調試Docker項目

選擇 Web server is on remote host。

PHPSTORM中怎么調試Docker項目

一路 Next。走到配置 Remote Server

PHPSTORM中怎么調試Docker項目

然后又是一路 Next 即可。

配置完成后,將能看到我們的項目。

PHPSTORM中怎么調試Docker項目

此時是不能直接進行代碼調試的。我們要做以下工作

  1. 配置 CLI Interpreter

  2. 配置目錄映射

  3. 設置Xdebug端口

  4. 配置一個 Run/Debug Configuration

  5. 啟動 PHP Debug Listening

ps:由于有些步驟是一樣的,就直接拉上文的截圖過來了。

配置 CLI Interpreter

進入 File -> Settings -> Languages & Frameworks -> PHP。設置 CLI Interpreter

PHPSTORM中怎么調試Docker項目

新建一個 CLI Interpreter。選擇 From Docker, Vagrant, VM, WSL,Remote....

這里我們可以填 SSH,也可以直接選擇 Docker。我這里用的是 SSH

PHPSTORM中怎么調試Docker項目設置 PHP executable 路徑。不知道可以進入 container 中使用whereis php進行搜索

PHPSTORM中怎么調試Docker項目

配置 目錄映射

進入 File -> Settings -> Languages & Frameworks -> PHP -> Servers。配置目錄映射

注意一定要把 Use path mappings 的勾勾上,才能配置目錄映射

Absolute path on the server 是要手動打上服務器路徑的

PHPSTORM中怎么調試Docker項目

設置Xdebug端口

進入 File -> Settings -> Languages & Frameworks -> PHP -> Debug。設置 Xdebug Debug port 為 9003。和 php 配置一致。

PHPSTORM中怎么調試Docker項目

配置一個 Run/Debug Configuration

點擊 PHPSTORM 右上角的 Add Configuration....。進入配置面,新增一個 PHP Web Page。并進行如下簡單的配置即可(改名字設url 路徑)

PHPSTORM中怎么調試Docker項目

啟動 PHP Debug Listening

直接點擊 PHPSTROM 右上角的 小電話 ,即可開啟監(jiān)聽

PHPSTORM中怎么調試Docker項目

驗證

在 php文件上打上斷點,點擊 右上角 甲殼蟲樣式的 Debug按鈕。即可成功斷點

PHPSTORM中怎么調試Docker項目

擴展 - 遠程服務器調試

這里可以擴展以一下,如果調試目標是遠程服務器而不是本地 Docker,該如何配置?

其實和上面的步驟一樣的,只是 Xdebug 監(jiān)聽的流量我們要做修改下。

簡單說說 Xdebug 監(jiān)聽的原理:

當 php-xdebug 接收到帶有 XDEBUG_SESSION_START 的請求時,將會把當前的 Debug信 息發(fā)送給 xdebug 中配置的 client_host 和 cilent_port。

在我們的 start.sh 啟動文件中,設置如下:

xdebug.client_host = host.docker.internal
xdebug.client_port = 9003

host.docker.internal值在 Xdebug 中是自動將請求端的 ip 設置為 調試端,即自動將 Debug信息 發(fā)送給任何請求IP。

xdebug.client_port的值是 Debug信息 被發(fā)送至的端口。

我們可以想下,在本地,xdebug端是能訪問到到我們請求端的 ip 和 端口 的,因為都是同一局域網。

但若調試的是遠程服務器,由于公網和內網的原因,公網服務器是無法發(fā)送 Debug信息 調試端的(除非調試端也在公網上。。)

所以我們需要將xdebug.client_host設置為127.0.0.1,讓 xdebug 轉發(fā) Debug信息 到本地的 9003 端口中。

接著使用 ssh 隧道進行端口轉發(fā),把調試端監(jiān)聽的 9003 端口映射到 服務端的 9003 上。這樣就能接收到 xdebug 轉發(fā)的 Debug信息了。這一點使用 ssh 隧道是可以做到的。

我們來測試下,首先修改 php.ini。讓xdebug.client_host值為127.0.0.1

PHPSTORM中怎么調試Docker項目

進行 ssh隧道端口轉發(fā)

ssh -N -R 遠程IP:遠程端口:127.0.0.1:9003 root@遠程IP

關于PHPSTORM中怎么調試Docker項目就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI