Я делаю приложение Symfony 3.4 в качестве службы REST (поэтому я установил обычный JMS Serializer, FoSRest и lexik/jwt-authentication-bundle) и тестирую его на XAMPP (Windows 10).
Когда я делаю запросы XHR через мое внешнее приложение использует app_dev.php в качестве конечной точки (очень) часто происходит сбой Apache при одновременном выполнении 2+ запросов.
Читая здесь и там, похоже, что эта проблема часто вызывается попыткой записи на файл сеанса, поскольку обработчик сеанса symfony по умолчанию - session.handler.native_file
.
Итак, я сначала попытался поставить null
(который, согласно документации, использует собственный обработчик сеанса PHP), это уменьшило частоту сбоев, но не решило проблему. полностью
Затем я попытался использовать Symfony\Component\HttpFoundation\Session\Storage\Handler\PdoSessionHandler
, из-за чего сбои происходили даже реже, чем раньше, но случайные сбои все еще случаются.
Теперь, когда я использую базу данных в качестве обработчика сеанса, я замечаю, что сеанс не записывается в базу данных, когда я делаю запросы XHR (хотя это происходит, если я открываю обычную веб-страницу, обслуживаемую приложением), что не должно Меня это не удивляет, так как я установил свой security.yml
таким образом, что маршруты REST должны быть без сохранения состояния, и все же игра с конфигурацией handler_id
влияет на то, как часто мой apache дает сбой.
То же самое не происходит, если я открываю несколько веб-страниц, обслуживаемых одним и тем же приложением, и этого не происходит, если я использую производственную конечную точку (app.php).
Есть ли способ исправить это полностью?
РЕДАКТИРОВАТЬ: по запросу
Можете ли вы добавить журналы ошибок apache и журналы ошибок php?
Это просто повторяется каждый раз, когда он перезагружается. Я заметил эту строку: AH00428: Parent: child process 29076 exited with status 3221226356 -- Restarting.
, которая может быть интересна для изучения
[Sun Dec 17 00:39:58.548676 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00428: Parent: child process 22856 exited with status 3221226356 -- Restarting.
[Sun Dec 17 00:39:59.544151 2017] [ssl:warn] [pid 17564:tid 532] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:39:59.740710 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00455: Apache/2.4.26 (Win32) OpenSSL/1.0.2l PHP/7.1.7 configured -- resuming normal operations
[Sun Dec 17 00:39:59.740710 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00456: Apache Lounge VC14 Server built: Jun 15 2017 12:39:41
[Sun Dec 17 00:39:59.740710 2017] [core:notice] [pid 17564:tid 532] AH00094: Command line: 'c:\\xampp\\apache\\bin\\httpd.exe -d C:/xampp/apache'
[Sun Dec 17 00:39:59.746705 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00418: Parent: Created child process 29076
[Sun Dec 17 00:40:01.201423 2017] [ssl:warn] [pid 29076:tid 592] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:01.414295 2017] [ssl:warn] [pid 29076:tid 592] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:01.455312 2017] [mpm_winnt:notice] [pid 29076:tid 592] AH00354: Child: Starting 150 worker threads.
[Sun Dec 17 00:40:17.006680 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00428: Parent: child process 29076 exited with status 3221226356 -- Restarting.
[Sun Dec 17 00:40:17.371667 2017] [ssl:warn] [pid 17564:tid 532] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:17.403690 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00455: Apache/2.4.26 (Win32) OpenSSL/1.0.2l PHP/7.1.7 configured -- resuming normal operations
[Sun Dec 17 00:40:17.403690 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00456: Apache Lounge VC14 Server built: Jun 15 2017 12:39:41
[Sun Dec 17 00:40:17.403690 2017] [core:notice] [pid 17564:tid 532] AH00094: Command line: 'c:\\xampp\\apache\\bin\\httpd.exe -d C:/xampp/apache'
[Sun Dec 17 00:40:17.409694 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00418: Parent: Created child process 24332
[Sun Dec 17 00:40:18.667139 2017] [ssl:warn] [pid 24332:tid 524] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:18.858441 2017] [ssl:warn] [pid 24332:tid 524] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:18.895469 2017] [mpm_winnt:notice] [pid 24332:tid 524] AH00354: Child: Starting 150 worker threads.
[Sun Dec 17 00:40:20.972550 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00428: Parent: child process 24332 exited with status 3221226356 -- Restarting.
[Sun Dec 17 00:40:21.481091 2017] [ssl:warn] [pid 17564:tid 532] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:21.513627 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00455: Apache/2.4.26 (Win32) OpenSSL/1.0.2l PHP/7.1.7 configured -- resuming normal operations
[Sun Dec 17 00:40:21.513627 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00456: Apache Lounge VC14 Server built: Jun 15 2017 12:39:41
[Sun Dec 17 00:40:21.513627 2017] [core:notice] [pid 17564:tid 532] AH00094: Command line: 'c:\\xampp\\apache\\bin\\httpd.exe -d C:/xampp/apache'
[Sun Dec 17 00:40:21.519144 2017] [mpm_winnt:notice] [pid 17564:tid 532] AH00418: Parent: Created child process 27440
[Sun Dec 17 00:40:22.991094 2017] [ssl:warn] [pid 27440:tid 552] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:23.266105 2017] [ssl:warn] [pid 27440:tid 552] AH01909: www.example.com:443:0 server certificate does NOT include an ID which matches the server name
[Sun Dec 17 00:40:23.301132 2017] [mpm_winnt:notice] [pid 27440:tid 552] AH00354: Child: Starting 150 worker threads.
Когда вы говорите, что сбой apache означает, что вам нужно снова запустить apache, или вы просто получаете сообщение об ошибке? Какую ошибку вы получаете?
Я просто получаю обычное окно сбоя приложения, в котором говорится: «Apache перестал работать», если я нажимаю «Закрыть приложение», оно перезапускается само по себе, и запрос, вызвавший сбой, просто завершается с ошибкой без кода состояния или сообщения об ошибке (что ожидается, поскольку соединение с сервером прервано). Как вы можете видеть, в журналах нет конкретной ошибки, кроме этого кода состояния.
Как у вас настроены apache и php mod_apache, php-fpm? Какие ограничения на сервер apache у вас есть, сколько рабочих php?
Я не знаю, как ответить на этот вопрос, я использую стандартный apache и php из пакета XAMPP без изменений в конфигурации. Я могу сказать вам, что php загружается как обработчик apache, поэтому нет CGI или FastCGI. В любом случае на простых страницах или в производственном режиме в Symfony все работает нормально.
НОВОСТИ:
Я обнаружил, что, поскольку я выполнял запросы CORS, он создавал файл сеанса для каждого запроса, я исправил это, и это немного улучшило мою проблему, но она все еще существует.
Я пытался использовать Redis в качестве обработчика сеанса для PHP, но на самом деле это только ухудшило ситуацию.
Я сделал простой тест, в котором я вызывал одну и ту же страницу (которая использует сеанс) 1000 раз, она работает нормально, пока я ставлю
session_write_close();
в конце, иначе она падает.