歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> Linux教程 >> 如何找出發生SEGV內存錯誤的程序

如何找出發生SEGV內存錯誤的程序

日期:2017/2/27 15:54:47   编辑:Linux教程

有用戶使用《lnmp一鍵安裝包》 在CentOS6.6 64bit上安裝php(php5.4、Opcache、ZendGuardLoader)、hhvm,用vhost.sh添加虛擬主機選擇php,使用 某主題(主題加密,需要使用ZendGuardLoader),啟用改主題直接報502錯誤。束手無策,於是找我來排錯,如下:

通過查看php日志/usr/local/php/var/log/php-fpm.log,有如下警告信息:

[16-Mar-2015 16:03:09] WARNING: [pool www] child 9453 exited on signal 11 (SIGSEGV) after 9.601040 seconds from start

日志中的信息表明,進程號為9453的進程由於收到SIGSEGV信號而退出了。收到這個信號的時候,程序是可以生成core文件的。不過通過日志 我們可以知道進程9453退出時沒有生成core文件。因為在php-fpm的日志中,如果退出時生成了core文件,日志中會有“SIGSEGV – core dumped”字樣。如:

[16-Mar-2015 16:04:29] WARNING: [pool www] child 9581 exited on signal 11 (SIGSEGV - core dumped) after 15.921916 seconds from start

core dump文件對於診斷Linux中 程序的問題非常有用。當程序異常退出的時候,可能會生成core文件。如,程序寫一個不屬於他的內存,操作系統出於保護,會發信號給程序,程序可能會因此 而退出,退出的時候可能會生成core文件。我們可以通過分析core文件,找出程序中那裡有內存問題。這篇文章主要是闡述生成core文件需要做的一些 設置。

如何生成core文件
默認Linux操作系統是不允許生成core文件的。如下:

[root@linuxeye ~]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 5762
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 65535
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 10240
cpu time               (seconds, -t) unlimited
max user processes              (-u) 65535
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

可以通過如下命令解除限制:

[root@linuxeye ~]# ulimit -c unlimited
[root@linuxeye ~]# ulimit -a
core file size          (blocks, -c) unlimited
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 5762
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 65535
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 10240
cpu time               (seconds, -t) unlimited
max user processes              (-u) 65535
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

注意,ulimit -c 的設置僅僅是對你完成設置後啟動的進程有效。而且退出登陸後,再進入需要從新設置。否則從新登陸後啟動的進程也無法生成core文件。
如果想永久生效,可以把命令加入到 /etc/profile 中。建議不要這樣做, 會瘋狂dump文件,浪費性能

如何找到core文件
一般情況下,core文件會生成在你執行程序的地方。文件名是core.進程號
你也可以指定core文件名和生成目錄。在/etc/sysctl.conf 文件中指定

# vi /etc/sysctl.conf
kernel.core_uses_pid = 1 #追加進程號到core文件名中
fs.suid_dumpable = 2 #確保設置屬主的進程也可以生成core文件
kernel.core_pattern = /tmp/core-%e-%s-%u-%g-%p-%t #指定core文件生成的位置和文件名規則。文件名規則可以使用的參數有:
%% – 符號%
%p – 進程號
%u – 進程用戶id
%g – 進程用戶組id
%s – 生成core文件時收到的信號
%t – 生成core文件的 時間 (seconds since 0:00h, 1 Jan 1970)
%h – 主機名
%e – 程序文件名

執行如下命令,讓設置生效

# sysctl -p

重啟php-fpm

service php-fpm restart

重現502錯誤
訪問http://demo.linuxeye.com/wp-admin/customize.php?theme=dux
日志/usr/local/php/var/log/php-fpm.log中會有“SIGSEGV – core dumped”字樣

如何使用core文件
可以使用gdb命令查看core文件信息

gdb -e /usr/local/php/sbin/php-fpm -c /tmp/core-php-fpm-11-501-501-9581-1426493066

根據上面的堆棧信息,可以知道Optimizer(即Opcache)有問題,編輯/usr/local/php/etc/php.ini,注銷掉Opcache段,重啟php-fpm ,正常。。。

轉自:http://blog.linuxeye.com/414.html
Copyright © Linux教程網 All Rights Reserved