Xdebug 无缘无故地默默捕获连接

问题描述 投票:0回答:2

该应用程序在 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。

可能是什么?

php docker xdebug
2个回答
2
投票

为什么是 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 通信)。


0
投票

发生在我身上

php:8.1.25-fpm-alpine
xdebug-3.1.4

xdebug.client_port
更改为 9999 并没有解决问题。

通过电脑重启修复

© www.soinside.com 2019 - 2024. All rights reserved.