在RHEL/CentOS 64位(32位没用过)6.0以上版本中,有core文件被截断的问题,即使你已经设置了ulimit -S -c unlimited。
原因好像是因为core pattern设置是abrt,abrt的问题导致core文件很小或者不产生core文件。解决的方法是不使用abrt作为core pattern
segfault at 0 ip 000000387712164f sp 00007fffb37d5b48
error 4 in libc-2.12.so[3877000000+175000]
查看机器的core pattern的设置:
sysctl -a | grep core_pattern
或者:
cat /proc/sys/kernel/core_pattern
如果core pattern设置成了abrt,改成core方式:
linux-y94w:/ # sysctl -w kernel.core_pattern=core.%p.%e
kernel.core_pattern = core.%p.%e
或者:
linux-y94w:/ # sysctl -w kernel.core_pattern=core.%p
kernel.core_pattern = core.%p
程序产生core的原因
造成程序core dump的原因很多,这里根据以往的经验总结一下:
1 内存访问越界
a) 由于使用错误的下标,导致数组访问越界
b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有
正常的使用结束符
c) 使用strcpy, strcat, sprintf, strcmp, strcasecmp等字符串操
作函数,将目标字符串读/写爆。应该使