Home >Backend Development >PHP Tutorial >SIGBUS failure of php process, SIGBUS failure of php process_PHP tutorial

SIGBUS failure of php process, SIGBUS failure of php process_PHP tutorial

WBOY
WBOYOriginal
2016-07-12 08:51:13983browse

SIGBUS failure of the php process, SIGBUS failure of the php process

A certain sub-site is written in php. When accessing nginx, 502 errors will appear from time to time. It is more frequent during peak hours. Check The log of php-fpm found a large number of child exited on signal 7 (SIGBUS), which completely matched the 502 time in the access log, ruling out the possibility of overloading the php process, and then ruling out the suspicion of apc.

Since the php process dies after receiving the signal, try to grab some coredumps for analysis:

First set the save path of the coredump. Pay attention to the place with enough space, because the coredump may be more and larger (for example, if apc is turned on and set to 1G, then there will be 1G):

#echo "/tmp/core.%e.%p.%h.%t" > /proc/sys/kernel/core_pattern

Then modify ulimit to allow coredump:

#ulimit -c unlimited

Restart php-fpm. Before long, a bunch of coredump files will be generated in the /tmp/ directory. Very good. Pack them up and drag them back offline for analysis. Remember to close coredump and restart the program:

#ulimit -c 0

It is generally enough to use gdb to analyze coredump (for binary distribution, install the corresponding debug symbol package first):

gdb /usr/local/php/sbin/php-fpm core.php-fpm.10375.php.1365314990

Execute the bt command and look at the backtrace (I forgot to record the specific information). I found that it is hung in the lex_scan function. I looked at several coredumps and found that they are basically functions hung in the lex stage.

I don’t have much research on PHP source code. I searched Google for “php sigbus lex_scan” and the first two links basically gave me the answer:

  • https://bugs.php.net/bug.php?id=52752

The bug in the 2010 annual report has not been closed, because it does not seem to be a PHP bug. If you look carefully, there are examples of recurrences, and finally someone found a way to circumvent it.

  • http://zecrazytux.net/troubleshooting/php-sigbus-crash-prestashop

This guy went through the same analysis process as me and gave clear reasons and solutions.

To put it simply, lex_scan is performing syntax analysis on PHP files. At this time, an included PHP file was rewritten, and tragedy occurred.

To confirm, I used strace to track the execution of the php process, and finally caught it:

<p>11670 lstat("/home", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0</p>
<p>11670 stat("/home/www/cache/default.php", {st_mode=S_IFREG|0644, st_size=68579, ...}) = 0</p>
<p>11670 --- SIGBUS (Bus error) @ 0 (0)</p>

Source: http://blog.druggo.org/post/2013/05/02/A case of SIGBUS failure in php process

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1131690.htmlTechArticleSIGBUS failure in php process, SIGBUS failure in php process. A certain sub-site is written in php, and nginx will crash from time to time when accessing it. 502 errors occur, more frequently during peak hours. Checking the php-fpm log found a large number of...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn