2010-05-05 23:42:29 +02:00
|
|
|
Debugging mysqld crashes
|
|
|
|
========================
|
|
|
|
Author: Michal Marek <mmarek@suse.cz>
|
2014-12-06 14:56:41 +01:00
|
|
|
Last modified: 2014-11-21
|
2010-05-05 23:42:29 +02:00
|
|
|
|
|
|
|
Contents
|
|
|
|
--------
|
|
|
|
1) Query log
|
|
|
|
2) Coredumps and Backtraces
|
|
|
|
3) Trace files
|
|
|
|
|
|
|
|
In case your MySQL server crashes, here are some hints on what to
|
|
|
|
include in a bugreport at https://bugzilla.novell.com/ . Please report
|
|
|
|
there only bugs in the MySQL packages packaged by Novell/SUSE, bugs in
|
|
|
|
binaries / source provided by MySQL AB should be reported at
|
|
|
|
http://bugs.mysql.com/ .
|
|
|
|
|
|
|
|
1) Query log
|
|
|
|
------------
|
|
|
|
Note: Skip this chapter if you already have an exact query that
|
|
|
|
crashes the server
|
|
|
|
|
|
|
|
To find out which query possibly crashed the server, add the following
|
|
|
|
line to your /etc/my.cnf into section [mysqld]:
|
|
|
|
|
|
|
|
log=/var/lib/mysql/mysqld-query.log
|
|
|
|
|
|
|
|
Mysqld then will, at some performance cost, log all queries into this
|
|
|
|
file. After a server crash, you can examine the queries from the time it
|
|
|
|
crashed and try to reproduce the crash with single queries (this might
|
|
|
|
not allways work, eg. if the crash is caused by some race condition).
|
|
|
|
|
|
|
|
Note that this log file may become extremly large, so if you decide to
|
|
|
|
attach it whole to the bugzilla, don't forget to
|
|
|
|
|
|
|
|
bzip2 -k /var/lib/mysql/mysqld-query.log
|
|
|
|
|
|
|
|
and attach the bzipped file instead.
|
|
|
|
|
|
|
|
2) Coredumps and Backtraces
|
|
|
|
---------------------------
|
|
|
|
Another valuable information for the developers is the backtrace. The
|
|
|
|
easies way to get one is to let mysqld produce a coredump. Add the
|
|
|
|
following line to your /etc/my.cnf into section [mysqld]:
|
|
|
|
|
|
|
|
core-file
|
|
|
|
|
|
|
|
Note: this unfortunatelly doesn't work in SUSE Linux 10.1 and older.
|
|
|
|
On these systems, you need to run safe_mysqld directly under user
|
|
|
|
mysql:
|
|
|
|
|
|
|
|
su - mysql
|
|
|
|
mysqld_safe --socket=/var/lib/mysql/mysql.sock \
|
|
|
|
--datadir=/var/lib/mysql --core-file &
|
|
|
|
|
|
|
|
The core file will be written to the /var/lib/mysql/ directory. I
|
|
|
|
suggest setting the kernel variable kernel.core_uses_pid to 1
|
|
|
|
|
|
|
|
sysctl -w kernel.core_uses_pid=1
|
|
|
|
|
|
|
|
so that the coredumps don't overwrite each other if you experience
|
|
|
|
multiple crashes.
|
|
|
|
|
|
|
|
After you got the core file, install the gdb and mysql-debuginfo
|
|
|
|
packages and run
|
|
|
|
|
|
|
|
gdb /usr/sbin/mysqld /var/lib/mysql/core
|
|
|
|
(gdb) bt
|
|
|
|
|
2014-12-06 14:56:41 +01:00
|
|
|
Replace mysqld with the mysqld version you used (mysqld, mysqld-max)
|
|
|
|
and core with the actual name of the coredump.
|
2010-05-05 23:42:29 +02:00
|
|
|
|
|
|
|
3) Trace files
|
|
|
|
--------------
|
2014-12-06 14:56:41 +01:00
|
|
|
Start mysqld using following command:
|
2010-05-05 23:42:29 +02:00
|
|
|
|
|
|
|
$ MYSQLD_DEBUG=yes rcmysql start
|
|
|
|
|
2014-12-06 14:56:41 +01:00
|
|
|
The init script will then start mysqld and add the --core-file,
|
2010-05-05 23:42:29 +02:00
|
|
|
--log and --debug options for you. The query log will be stored in
|
|
|
|
|
|
|
|
/var/lib/mysql/myqld-query.log
|
|
|
|
|
|
|
|
and the trace file in
|
|
|
|
|
|
|
|
/var/lib/mysql/mysqld.trace
|
|
|
|
|
|
|
|
If you don't like the options set by the init script, just put your own
|
2014-12-06 14:56:41 +01:00
|
|
|
into /etc/my.cnf and the init script will honor them.
|
2010-05-05 23:42:29 +02:00
|
|
|
|
|
|
|
The trace file will contain various debug information and function
|
|
|
|
calls/returns and will become _extremly_ huge after a while, so don't
|
|
|
|
attach it to bugzilla unless requested.
|
|
|
|
|