OPcache прерывает регистрацию phpBB
Я не знаю, что случилось, но всякий раз, когда пользователь пытается зарегистрироваться на одном из моих форумов phpBB, nginx бросает 502 Bad gateway
, но если я отключу OPcache все работает нормально.
Это журнал ошибок от php-fpm
:
WARNING: [pool www] child 14677 exited on signal 11 (SIGSEGV) after 87782.968736 seconds from start
И это nginx
журнал ошибок:
[error] 14099#0: *78984 recv() failed (104: Connection reset by peer) while reading response header from upstream, client: x.x.x.x, server: x, request: "POST /ucp.php?mode=register HTTP/1.1", upstream: "fastcgi://unix:/var/run/php5-fpm.sock:", host: "x.tld", referrer: "https://x.tld/ucp.php?mode=register"
Pagespeed включен на всех моих хостах, а также лак.
Конфигурация Vhost:
[...]
# PageSpeed
pagespeed on;
pagespeed MemcachedThreads 1;
pagespeed MemcachedServers "localhost:11211";
#Varnish
pagespeed DownstreamCachePurgeLocationPrefix https://x.tld:80;
pagespeed DownstreamCachePurgeMethod PURGE;
pagespeed DownstreamCacheRewrittenPercentageThreshold 95;
pagespeed EnableFilters combine_javascript;
pagespeed EnableFilters combine_css;
pagespeed EnableFilters move_css_above_scripts;
pagespeed EnableFilters prioritize_critical_css;
pagespeed FileCachePath "/var/cache/pagespeed/";
pagespeed MapRewriteDomain https://x.tld http://x.tld;
[...]
location ~ \.php$ {
include fastcgi_params;
fastcgi_index index.php;
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
}
Конфигурация OPcache:
[opcache]
opcache.enable=1
opcache.enable_cli=1
opcache.memory_consumption=512
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=30000
opcache.max_wasted_percentage=5
opcache.use_cwd=1
opcache.validate_timestamps=1
opcache.revalidate_freq=1
opcache.fast_shutdown=1
opcache.optimization_level=0
Я пытался занести в черный список весь форум dir, но он работает, только если я полностью отключил OPcache
Редактировать:
С помощью PHP 5.6.5-1~dotdeb.1
на Debian GNU/Linux 7.8
Varnish 4.0.2
Edit2:
инвалид pagespeed
и попробовал xcache
отчеты nginx 503
и php-fpm worker
перезагружается.
Работает только если я полностью отключил кеширование в php
Edit3:
После создания дампа ядра, как предположил Яков Сосич, это результат:
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
Core was generated by `php-fpm: pool www '.
Program terminated with signal 11, Segmentation fault.
#0 _zend_mm_free_int (heap=0xf122c0, p=0x7f895b07c980) at /usr/src/php5.6/nonzts/source/dotdeb-php5/Zend/zend_alloc.c:2104
2104 /usr/src/php5.6/nonzts/source/dotdeb-php5/Zend/zend_alloc.c: No such file or directory.
2 ответа
После изучения вопроса я узнал, что opcache
ошибка была вызвана отсутствующим файлом, но это не было проблемой.
Моя php-версия была установлена без zend thread safety
особенность. После установки php с zts все работает нормально.
Один из способов решить проблему - это получить coredump PHP (после segfaults), а затем проанализировать coredump с помощью GDB (с установленными в системе пакетами debuginfo). Тогда вы сможете увидеть, какая именно PHP-линия вызывает у вас головную боль.
Кроме этого - никто не может дать вам совет по этому вопросу.
http://www.omh.cc/blog/2008/mar/6/fixing-apache-segmentation-faults-caused-php/