Oli*_*ixr 3 php windows laravel
我在本地环境(Windows 10)中安装了 Laravel 4.2 进行测试,但在更新任何文件后不断收到连接重置错误。
我的项目将加载并且服务器正确显示我的页面。但是,如果我更新文件(例如索引),然后尝试访问呈现新更新文件的页面,我总是会收到连接重置错误。即使是像句号这样简单的更改。
更有趣的是,当我使用php artisan来服务我的文件时,我从未遇到连接重置问题。如果我通过 artisanserve 访问该页面,它就可以工作,然后 xampp 突然想要工作,但只有在我之前从 artisan 加载过一次页面之后才可以。
如果我再次更改文件,我必须重复此过程。
本地设置
我的项目使用以下 v-hosts 配置从 xampp (v 3.2.2) 本地托管。主机文件也已正确配置。
<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>
Run Code Online (Sandbox Code Playgroud)
简而言之:我更改了一个文件,当尝试访问该页面时,我在 xampp 上重置了连接。我从 artisan 查看页面,然后在 xampp 上刷新页面,突然就可以了。
更新
我已经尝试过卢卡斯建议的替代方案,例如 laragon,但是同样的错误仍然存在。在尝试访问该页面时更新任何文件后,我收到连接重置错误。
我在 laragon 中的 apache 日志中找到了更多信息。
[Tue Mar 01 08:52:22.785519 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00428:父进程:子进程 8276 已退出,状态为 3221225725 -- 正在重新启动。 [Tue Mar 01 08:52:22.928687 2016] [ssl:warn] [pid 6748:tid 544] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:22.938712 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00455: Apache/2.4.17 (Win32) OpenSSL/1.0.2d PHP/5.6.16 配置 -- 恢复正常操作 [Tue Mar 01 08:52:22.938712 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00456:Apache Lounge VC11 服务器构建:2015 年 10 月 13 日 10:54:13 [Tue Mar 01 08:52:22.938712 2016] [core:notice] [pid 6748:tid 544] AH00094: 命令行: 'C:\\larragon\\bin\\apache\\apache-2.4.17/bin/ httpd -d C:/larragon/bin/apache/apache-2.4.17' [Tue Mar 01 08:52:22.939695 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00418:父级:创建子进程 3672 [Tue Mar 01 08:52:23.214917 2016] [ssl:warn] [pid 3672:tid 532] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:23.296629 2016] [ssl:warn] [pid 3672:tid 532] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:23.306647 2016] [mpm_winnt:notice] [pid 3672:tid 532] AH00354:子级:启动 64 个工作线程。 [Tue Mar 01 08:52:24.159843 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00428:父进程:子进程 3672 已退出,状态为 3221225725 -- 正在重新启动。 [Tue Mar 01 08:52:24.305896 2016] [ssl:warn] [pid 6748:tid 544] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:24.315916 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00455: Apache/2.4.17 (Win32) OpenSSL/1.0.2d PHP/5.6.16 配置 -- 恢复正常操作 [Tue Mar 01 08:52:24.315916 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00456:Apache Lounge VC11 服务器构建:2015 年 10 月 13 日 10:54:13 [Tue Mar 01 08:52:24.315916 2016] [core:notice] [pid 6748:tid 544] AH00094: 命令行: 'C:\\larragon\\bin\\apache\\apache-2.4.17/bin/ httpd -d C:/larragon/bin/apache/apache-2.4.17' [Tue Mar 01 08:52:24.317905 2016] [mpm_winnt:notice] [pid 6748:tid 544] AH00418:父进程:创建子进程 3600 [Tue Mar 01 08:52:24.580068 2016] [ssl:warn] [pid 3600:tid 552] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:24.666114 2016] [ssl:warn] [pid 3600:tid 552] AH01909: www.example.com:8443:0 服务器证书不包含与服务器名称匹配的 ID [Tue Mar 01 08:52:24.675120 2016] [mpm_winnt:notice] [pid 3600:tid 552] AH00354:子级:启动 64 个工作线程。
这个问题最终通过 Apache 的配置更改得到解决。
将以下内容添加到httpd.conf文件:
<IfModule mpm_winnt_module>
ThreadStackSize 8888888
</IfModule>
Run Code Online (Sandbox Code Playgroud)
然后重新启动。
问题在于 Windows 默认情况下的堆栈大小比 Linux/Unix 系统上的要小。我花了一段时间才弄清楚这一点。Apache 悄无声息地崩溃了,我的日志中没有收到任何错误,因此很难追踪。
我正在从事的项目有大量的正则表达式调用,显然这是导致 Windows 上的 apache 出现此问题的已知触发器。如果您查看 apache 文档,我们可以将ThreadStackSize更新为更接近 Unix/Linux 系统8MB的值。
http://httpd.apache.org/docs/2.2/mod/mpm_common.html#ThreadStackSize
我希望这可以帮助其他人在运行 apache 作为本地服务器的 Windows 系统上进行开发。一段时间以来,这是一个令人头疼的问题。