-
Notifications
You must be signed in to change notification settings - Fork 31
/
mysql_stats.py
executable file
·64 lines (56 loc) · 2.26 KB
/
mysql_stats.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/usr/bin/env python
#
# License: MIT
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
#
# By default, MySQL does not allow root to run mysqladmin with no password.
# To get this script working, create /root/.my.cnf and put the following lines
# in it (sans # signs)...
#
#[client]
#user = a_valid_mysql_user
#password = a_secret_password_1234
#host = localhost
#
# ...filling in your values for the user and password. Be sure to chmod .my.cnf
# to 600. You don't want other users to be able to read the username and
# password.
import commands
import sys
metric_types = {
"threads": "int",
"questions": "gauge",
"slow_queries": "gauge",
"opens": "gauge",
"flush_tables": "gauge",
"open_tables": "int",
"queries_per_second_avg": "float",
}
(status, output) = commands.getstatusoutput("su -c \"mysqladmin status\"")
if status != 0:
print "status err Error running mysqladmin status: %s" % output
sys.exit(status)
print "status ok mysqladmin success"
pairs = output.split(" ")
for pair in pairs:
(key, value) = pair.split(": ")
key = key.lower().replace(" ", "_")
if metric_types.get(key):
print "metric %s %s %s" % (key, metric_types[key], value)