0

问题的症结在于我编辑了一个代码文件,而更改直到我重建整个环境后才生效。奇怪的是,到目前为止,我已经几个月没有遇到这个问题了。我刚决定在这周结束这个项目并继续工作,突然间编辑文件不再工作(没有重建)。

我什至不知道从哪里开始尝试解决这个问题。任何建议都会有所帮助,尤其是来自有使用 Lando 和 Docker 经验的人的建议。好吧,因为我不知道是什么原因造成的,所以我将尝试解释我的整个设置并从那里开始:

我正在使用 Lando 运行一个运行 PHP 7.3 的容器。当我 SSH 进入正在运行的容器并执行我的脚本时,php worker.php我的脚本运行没有问题。然后,如果我编辑它,比如添加一个 var_dump('hello world!'),我会得到预期的输出。但是,如果我编辑一个自动加载的类文件,比如 MyClass.php,并在那里添加一个 var_dump,什么也不会发生。事实上,我必须完全重建环境lando rebuild才能让 var_dump 显示出来。很奇怪吧?

好的,这是我尝试过的一些事情:

  • 我试过重启 Docker。
  • 我试过重新启动我的电脑。
  • 我已经尝试过lando destroy重新lando rebuild开始。
  • 我已经尝试通过 SSH 进入容器并运行cat mylib/MyClass.php,我看到了添加的 var_dump 语句!!但是,当我运行php worker.php添加到 MyClass 的 var_dump 时不存在。它如何存在于文件系统中,但在执行期间却不存在?这真的让我陷入了困境。
  • 我尝试将 MyClass.php 重命名为 MyClass2.php ,这一次解决了这个问题。即在它更新之后,我需要在每次有变化时一次又一次地重命名它。这显然不是真正的解决方案,但值得深思。
  • 我尝试使用手动加载类include_once。这非常有效,编辑一旦发生就会生效。问题是我不想手动包含我的所有文件,我想使用作曲家自动加载器。我已经使用它很长时间了,我宁愿修复它突然出现的任何问题。

好的,最后,我的一些理论:

  • 有些东西显然是在缓存东西,但我不知道是什么。我想这可能与 PHP 操作码缓存有关,但据我所知,我没有启用 php 操作码缓存。
  • 另一种理论是文件系统挂载可能不起作用。但是,它正在工作,因为当我编辑 worker.php 时,每次都会立即进行更改。如果没有文件系统挂载,则不会发生这种情况。
  • 另一种理论是,要么 Docker 以某种方式缓存某些东西(我不知道怎么做),要么 Lando 是?我对兰多一无所知。也许它有某种我不知道的缓存方案。
  • 最后一个理论是,自动加载的类以某种方式被 PHP 本身或我的作曲家或类似的东西缓存。我也不知道这是怎么可能的,但我不是作曲家或 php 内部工作的专家,所以如果这里涉及到代码缓存,我不知道。

所以我知道人们可能会要求一些东西:Dockerfile

FROM php:7.3-apache

RUN apt-get update \
    && apt-get install -y \
       git \
       zip \
       unzip \
       libzip-dev \
       libxml2-dev \
       libssl-dev \
       libc-client-dev \
       libkrb5-dev \
    && docker-php-ext-configure imap --with-kerberos --with-imap-ssl \
    && CFLAGS="-I/usr/src/php" docker-php-ext-install zip mysqli pdo pdo_mysql xmlreader imap

RUN curl --silent --show-error https://getcomposer.org/installer | php
RUN mv composer.phar /usr/local/bin/composer

# Bake composer dependencies into the image for production
WORKDIR /app

COPY composer.json ./
COPY composer.lock ./

RUN export COMPOSER_ALLOW_SUPERUSER=1 && \
    composer install --no-scripts --no-autoloader --no-dev

COPY . ./

RUN export COMPOSER_ALLOW_SUPERUSER=1 && \
    composer dump-autoload --optimize && \
    composer run-script post-install-cmd

COPY vhost.conf /etc/apache2/sites-available/000-default.conf

RUN chown -R www-data:www-data ./ && \
    a2enmod rewrite

EXPOSE 80

.lando.yml

name: mysite
env_file:
  - .env
proxy:
  appserver:
    - mysite.lndo.site
  database:
    - db.mysite.lndo.site
services:
  appserver:
    type: compose
    services:
      build: .
      command: apache2-foreground
  database:
    type: mysql
    portforward: 3306
    creds:
      ---super secret---

作曲家.json

{
    "name": "MySite/MySite",
    "description": "Would work great if not for caching issues. :(",
    "type": "project",
    "require": {
        "ext-json": "*",
        "ext-imap": "*",
        "doctrine/orm": "^2.6.2",
        "doctrine/migrations": "^2.0",
        "zbateson/mail-mime-parser": "^1.1",
        "rct567/dom-query": "^0.7.0",
        "sabre/xml": "^2.1",
        "phpmailer/phpmailer": "^6.0"
    },
    "autoload": {
        "psr-4": {
            "MySite\\": "./lib"
        }
    }
}

更新:我发现通过删除vendor/symfony/console然后运行composer install它似乎清除了缓存。我希望我能从这里弄清楚,但答案仍然让我难以捉摸。symfony 控制台与自动加载缓存代码有什么关系?我不知道。

4

1 回答 1

2

我终于想通了,但花了我一整天。我希望有人偶然发现这一点,它可以节省你的时间。这是我必须做的,这很容易:

只需将以下代码放入您的 composer.json 文件并运行composer install

    "config": {
        "optimize-autoloader": true
    },

我不知道为什么这有效。我会假设启用优化器会导致缓存,但它似乎禁用了它。老实说,我不知道为什么会这样。如果其他人可以比我更好地解释这一点,那么我会投票支持你的答案而不是我的答案。

于 2019-11-03T07:29:35.587 回答