How to get a core dump from apache when segfaulting
I've followed instructions from many locations online on how to get a core dump from apache when it is producing a segfault, but it still refuses to generate the dump.
I have:
- Added the
CoreDumpDirectory
directive into thehttpd.conf
file and set it to/tmp
- Executed
ulimit -c unlimited
- Provided the pattern for dumps using
echo '/tmp/core-%e.%p' > /proc/sys/kernel/core_pattern
- Also ran
echo 0 > /proc/sys/kernel/core_uses_pid
Httpd has been restarted, but still no dumps created.
I'm running CentOS 5.8 x64 with httpd-2.2.3-65.el5.centos.3
and php-5.3.20-13.el5.art
Any help would be much appreciated!
My answer is this:
-
Set up the directive as follow
CoreDumpDirectory /tmp/mycoredump
-
Create the directory:
mkdir -p /tmp/mycoredump
-
Assign ownership to the directory www-data or httpd
chown -R www-data:www-data /tmp/mycoredump
-
Set permissions to:
chmod 777 /tmp/mycoredump
-
Restart Apache:
service apache2 restart
Note that if you have PrivateTmp=true
set in your /usr/lib/systemd/system/apache2.service
(or whatever it's called on your system), meaning Apache actually looks for /tmp
inside something like /tmp/systemd-private-c27fc5b152d546159d675e170641529b-apache2.service-IcEt0m/
, Apache won't be able to write to that dir and you won't get cores dumped at all (due to the systemd
tmp directory having 700 root-only perms).
The solution is to either set PrivateTmp=false
or modify the permission of the systemd tmp directory after the server starts.
I wasted hours on this to only just now finally realize what the problem was.