Laravel连接在任何文件更改后重置


Laravel connection reset after any file changes

我在本地环境(Windows 10)中安装了laravel 4.2进行测试,但在更新任何文件后不断收到连接重置错误。

我的

项目将加载,服务器将正确显示我的页面。但是,如果我更新文件(例如索引),然后尝试访问呈现新更新文件的页面,我总是会收到连接重置错误。即使是像句点一样简单的变化。

更有趣的是,当我使用 php artisan 来提供我的文件时,我从来没有遇到连接重置问题。如果我通过工匠服务访问页面,它可以工作,然后突然间 xampp 想要工作,但只有在我之前从工匠那里加载过一次页面之后。

如果我再次对文件进行更改,则必须重复此过程。

本地设置

我的项目从 xampp (v 3.2.2) 本地托管,具有以下 v-hosts 配置。主机文件也已正确配置。

<VirtualHost *:80>
DocumentRoot "C:/xampp/htdocs/myproject/public"
ServerName myproject.local
ServerAlias myproject.local
ErrorLog "logs/myproject.log"
CustomLog "logs/custom.myproject.log" combined
<Directory "C:/xampp/htdocs/myproject/public">
    AllowOverride All
    Require all granted
</Directory>

简而言之:我更改了一个文件,在尝试访问该页面时在 xampp 上重置了连接。我从工匠那里查看页面,然后在 xampp 上刷新页面,突然它起作用了。

更新

我已经尝试了卢卡斯建议的替代方法,例如拉贡,但是相同的错误仍然存在。在尝试访问该页面时更新任何文件后,我收到连接重置错误。

我在拉拉贡中找到了更多信息,查看了阿帕奇日志。

[周二 3 月 01 日 08:52:22.785519 2016] [mpm_winnt:通知] [PID 6748:TID 544] AH00428:父进程:子进程 8276 退出,状态3221225725 -- 正在重新启动。[周二 3 月 01 08:52:22.928687 2016][SSL:警告][PID 6748:TID 544]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 Mar 01 08:52:22.938712 2016][mpm_winnt:通知][PID 6748:TID 544]AH00455:已配置 Apache/2.4.17 (Win32) OpenSSL/1.0.2d PHP/5.6.16 -- 恢复正常操作[周二 Mar 01 08:52:22.938712 2016][mpm_winnt:通知][PID 6748:TID 544]AH00456: Apache Lounge VC11 服务器构建时间: Oct 13 2015 10:54:13[周二 Mar 01 08:52:22.938712 2016][核心:通知][PID 6748:TID 544]AH00094:命令行:"C:''''laragon''''bin''''apache''''apache-2.4.17/bin/httpd -d C:/laragon/bin/apache/apache-2.4.17"[周二 3 月 01 08:52:22.939695 2016][mpm_winnt:通知][PID 6748:TID 544]AH00418:父进程:创建的子进程 3672[周二 3 月 01 08:52:23.214917 2016][SSL:警告][PID 3672:TID 532]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 3 月 01 08:52:23.296629 2016][SSL:警告][PID 3672:TID 532]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 3 月 01 08:52:23.306647 2016][mpm_winnt:通知][PID 3672:TID 532]AH00354:子线程:启动 64 个工作线程。[周二 3 月 01 08:52:24.159843 2016][mpm_winnt:通知][PID 6748:TID 544]AH00428:父进程:子进程 3672 退出,状态3221225725 -- 正在重新启动。[周二 3 月 01 08:52:24.305896 2016][SSL:警告][PID 6748:TID 544]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 3 月 01 08:52:24.315916 2016][mpm_winnt:通知][PID 6748:TID 544]AH00455:已配置 Apache/2.4.17 (Win32) OpenSSL/1.0.2d PHP/5.6.16 -- 恢复正常操作[周二 3 月 01 08:52:24.315916 2016][mpm_winnt:通知][PID 6748:TID 544]AH00456: Apache Lounge VC11 服务器构建时间: Oct 13 2015 10:54:13[周二 3 月 01 08:52:24.315916 2016][核心:通知][PID 6748:TID 544]AH00094:命令行:"C:''''laragon''''bin''''apache''''apache-2.4.17/bin/httpd -d C:/laragon/bin/apache/apache-2.4.17"[周二 Mar 01 08:52:24.317905 2016][mpm_winnt:通知][PID 6748:TID 544]AH00418:父进程:创建的子进程 3600[周二 Mar 01 08:52:24.580068 2016][SSL:警告][PID 3600:TID 552]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 3 月 01 08:52:24.666114 2016][SSL:警告][PID 3600:TID 552]AH01909:www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID[周二 Mar 01 08:52:24.675120 2016][mpm_winnt:通知][PID 3600:TID 552]AH00354:子线程:启动 64 个工作线程。

这个问题最终通过 Apache 的配置更改得到解决。

将以下内容添加到 httpd.conf 文件中:

<IfModule mpm_winnt_module>
   ThreadStackSize 8888888
</IfModule>

然后重新启动。

问题是默认情况下Windows的堆栈大小比Linux/Unix系统小。我花了一段时间才弄清楚这一点。Apache正在悄无声息地崩溃,我的日志中没有收到任何错误,因此很难追踪。

我正在从事的项目有大量的正则表达式调用,显然这是导致 apache 在 Windows 上出现此问题的已知触发器。如果你看一下 apache 文档,我们可以将 ThreadStackSize 更新到更接近 8MB 的 Unix/Linux 系统的值。

http://httpd.apache.org/docs/2.2/mod/mpm_common.html#ThreadStackSize

我希望这可以帮助其他任何人在运行apache作为本地服务器的Windows系统上进行开发。这在一段时间内一直是一个令人头疼的问题。

php artisan serve使用构建在服务器(php -S localhost:80 -t public)上的PHP来托管应用程序。

也许问题可能是您的 apache 配置,所以试试这个:

# define DOCROOT variable
define DOCROOT "C:/xampp/htdocs"
<Directory "${DOCROOT}">
    AllowOverride All
    Require all granted
</Directory>
<VirtualHost *:80>
    DocumentRoot "C:/xampp/htdocs/myproject/public/"
    ServerName myproject.dev
</VirtualHost>

如果问题仍然存在,请尝试使用Largon并始终以管理员身份打开它。

打开php错误日志可以帮助您找到真正的问题。 我的代码中有一个错误(直接在函数上使用 isset() )