NAME
mkill - Kills slow queries
SYNOPSIS
mkill [--host={mysql_host}] [--dbuser={mysql_user}]
[--password={mysqluser_pw}]
[--filter-user={regex}] [--filter-host={regex}] [--filter-db={regex}]
[--filter-command={regex}] [--filter-state={regex}] [--filter-info={{regex}}]
[--user={user}] [--slow={seconds}]
[--daemonize]
mkill --help
mkill --version
DESCRIPTION
This is an alpha version of this program. Please let me know what you think and what additional features would be nice. Future version will most likely perform the same but have different output. One idea i've been thinking about is letting you specify filters which short perl snippets instead of just regexes.
This program kills long running queries based on several criteria including query time, host, user, database, state, and query content.
The following keys are active while mkill is running:
q - quit
OPTIONS
All options can be abbreviated by their shortest unique abbreviation.
- -?, --help
-
Show the help screen and exit.
- -v, --version
-
Show the version number and exit.
- -h {mysql_host}, --host={mysql_host}
-
By default, the mysqld on localhost is monitored. Specify an alternate host with this option.
- -dbu {mysql_user}, --dbuser={mysql_user}
-
By default, the user 'mysqltop' is used to connect to the database. Specify an alternate user with this option.
- -p {mysqluser_pw}, --password={mysqluser_pw}
-
By default, there is no password associated with the mysqltop user, specify a password with this option.
- -sl {seconds}, --slow={seconds}
-
The number of seconds before a slow query is killed. The default is 180 seconds.
FILTER OPTIONS
- -u {user}, --user={user}
-
Kill only threads owned by this user.
- -fu {regex_pattern}, --filter-user={regex_pattern}
- -fh {regex_pattern}, --filter-host={regex_pattern}
- -fd {regex_pattern}, --filter-db={regex_pattern}
- -fs {regex_pattern}, --filter-state={regex_pattern}
- -fc {regex_pattern}, --filter-command={regex_pattern}
- -fi {regex_pattern}, --filter-info={regex_pattern}
-
Filter the queries based on the regex_pattern provided. The regex_pattern is a perl regular expression. The regular expression match is done with case insensitivity.
For example, to only kill select statements on the user table, use the following:
--filter-info='select from user'
or, to be more forgiving for mutil-table joins and extra spaces, use:
--filter-info='select\s+from\s+.*\buser\b.*where'
Be careful to escape any special shell characters in the regex.
All options can be stored in initialization files. Command line options override options stored in the initialization file(s). The following files are checked for arguments: current direcotry .mkillc, home directory .mkillc, /usr/local/etc/mkillc, /etc/mkillc. Options in the former files override options in the later files.
The format of the initialization file is one option per line. Options are specified just as they would be on the command line. They can be abbreviated and use the one or two hyphen syntax. Comments and blank lines are ignored. The following is an exmple .mkillc file which kills any 'select' statements from 'user1' which last more than 120 seconds.
# Only kill 'user1' 'select' queries > 120 seconds
-fu user1
-filter-info='select'
--slow=1 # refresh every one seconds
SETUP
The most convenient way to setup your system to use mkill is to create a database user called mysqlkill which has no password. For security purposes, this user should have all privileges set to N except Process_priv which must be set to Y.
To grant these privileges, execute the following from the MySQL command prompt
mysql> grant select on test.* to mysqlkill;
mysql> grant select on test.* to mysqlkill@localhost;
mysql> update user set process_priv='y' where user='mysqlkill';
mysql> flush privileges;
Note: GRANT only works in MySQL 3.22.11 or later, for earlier versions add the user manually and fix the permissions as noted above. Note 2: the GRANT to mysqlkill and mysqlkill@localhost may be modified depending upon which hosts you want to grant access from. In general, you probably want to limit it to the hosts in your domain.
In addition, the mysqlkill user must have Select_priv to the test database. This requirement is only needed because the DBI driver requires a database to connect to even though no database commands are issued. Most commands this program issues are non-database specific (SHOW FULL PROCESSLIST, SHOW VARIABLES, KILL id). When database-specific commands are needed, mkill will prompt for a username/password if the default one fails.
To install mkill, run the following shell commands:
perl Makefile.PL
make
make install
The default {install_prefix} is /usr/local which means that mkill is installed in /usr/local/bin/. To change this, run:
perl Makefile.PL --prefix={install_prefix}
or modify the PREFIX line in Makefile.PL.
Requires the following perl modules:
Module Available At
------------ --------------------------------------------------------
DBI Distributed as Bundle::DBI: http://www.cpan.org/authors/id/TIMB
DBD::mysql http://www.cpan.org/authors/id/JWIED
Getopt::Long (Distributed with Perl 5)
Net::Domain Part of libnet: http://www.cpan.org/authors/id/GBARR/
AUTHOR
Marc Prewitt, Chelsea Networks <mprewitt@chelsea.net>
Copyright (C) 2003 Marc Prewitt/Chelsea Networks, under the GNU GPL. mkill comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under certain conditions; see the COPYING file for details.
KNOWN BUGS
$Id: mkill.PL,v 1.2 2003/06/20 14:36:43 mdprewitt Exp $
The get char routines used to quit the program currently require the user to hit the RETURN key on the keyboard after entry. This will soon be fixed.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 795:
'=end' without a target? (Should be "=end showsatus")