该应用程序在 docker 容器上运行:nginx 和 php-fpm。 Xdebug 使用 PhpStorm 配置。该应用程序一直正常工作,直到 Xdebug 突然开始捕获所有连接,即使我没有启用调试。我什至没有更改配置中的任何内容 - 它只是开始执行此操作(有点神奇,但当然应该有一些东西)。
为什么是 Xdebug:如果我从 Dockerfile 中删除 Xdebug 设置,一切都会开始工作。此外,请求会挂起,就像我调试它们时发生的那样,即它们在等待几分钟后死亡,并出现
504 Gateway Time-out
错误。
PhpStorm 不会启动调试会话,因此它会默默地发生。关闭 PhpStorm 没有帮助。重新启动容器、docker 守护进程本身甚至操作系统也没有帮助。在不同的浏览器中没有任何变化。
php-fpm/Dockerfile
:
FROM php:7.3.18-fpm-alpine
RUN apk add --no-cache $PHPIZE_DEPS \
&& pecl install xdebug-2.9.8 \
&& docker-php-ext-enable xdebug
#...there are more lines, but even when I remove them, the issue remains
#When I comment this line and do `docker-compose build && docker-compose down && docker-compose up -d`,
# the app returns to life.
COPY xdebug.ini /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini
php-fpm/xdebug.ini
:
zend_extension=xdebug.so
xdebug.remote_enable=1
xdebug.remote_connect_back=off
xdebug.remote_host=docker.for.mac.localhost
xdebug.remote_port=10000
xdebug.idekey=PHPSTORM
xdebug.remote_autostart=true
xdebug.var_display_max_depth = 16
xdebug.var_display_max_children = 256
xdebug.var_display_max_data = -1
docker-compose.yml
:
version: '3.7'
services:
nginx:
image: nginx:stable
volumes:
- ./docker/nginx/vhost.conf.template:/tmp/vhost.conf.template
- ./docker/nginx/logs:/logs
- ./:/app
depends_on:
- php-fpm
php-fpm:
build: docker/php-fpm
environment:
PHP_IDE_CONFIG: serverName=app.local
volumes:
- ./:/app
nginx/vhost.conf
:
server {
charset utf-8;
client_max_body_size 250M;
listen 80;
server_name app.local;
root /app/public;
index index.php;
access_log /logs/nginx.app.access.log;
error_log /logs/nginx.app.error.log;
location / {
try_files $uri $uri/ /index.php$is_args$args;
}
location ~ \.php$ {
try_files $uri =404;
fastcgi_pass fpm:9000;
include /etc/nginx/fastcgi_params;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $request_filename;
}
location ~* "/\." {
deny all;
return 404;
}
}
它是 MacOS 10.14.6 上的 Docker Desktop 2.5.0。
可能是什么?
为什么是 Xdebug:如果我从 Dockerfile 中删除 Xdebug 设置,一切都会开始工作。此外,请求会挂起,就像我调试它们时发生的那样,即它们在等待几分钟后死亡,并出现
错误。504 Gateway Time-out
启用 Xdebug 日志以确认调试会话已建立并检查正在进行的通信(如果有)。这应该会给您一些关于可能是什么的线索。
无论如何,看起来你已经在 TCP 10000 端口上(在你的主机操作系统(Mac)上)有一些服务,阻止 PhpStorm 在那里侦听(IDE 可以检测到 Windows 和 Linux 上已占用的端口,但不能在 Mac 上检测到 - WI -29443)。
使用类似
sudo lsof -nP -iTCP -sTCP:LISTEN
的内容并检查该服务可能是什么。然后关闭该应用程序或使用另一个端口(用于该应用程序或用于您的 Xdebug 通信)。
发生在我身上
php:8.1.25-fpm-alpine
和xdebug-3.1.4
。
将
xdebug.client_port
更改为 9999 并没有解决问题。
通过电脑重启修复。