| author | Radek Brich <brich.radek@ifortuna.cz> | 
| Mon, 14 Apr 2014 22:28:12 +0200 | |
| changeset 96 | acf63df539b7 | 
| parent 93 | b72591087495 | 
| permissions | -rwxr-xr-x | 
| 93 
b72591087495
Change python3.2 to python3 in scripts.
 Radek Brich <brich.radek@ifortuna.cz> parents: 
83diff
changeset | 1 | #!/usr/bin/env python3 | 
| 2 | 2 | |
| 9 
2fcc8ef0b97d
Reorganize again :-) Add setup.py.
 Radek Brich <radek.brich@devl.cz> parents: 
7diff
changeset | 3 | from pgtoolkit import pgstats, toolbase | 
| 83 
515fadd3d286
Add dependency on pycolib. Move common modules to pycolib. Add example table schema for meta DB.
 Radek Brich <radek.brich@devl.cz> parents: 
73diff
changeset | 4 | from pycolib.ansicolor import highlight, YELLOW, BOLD | 
| 2 | 5 | |
| 6 | ||
| 7 
685b20d2d3ab
Reorganize directories. PgDataDiff - reworked. PgManager - add fetchone_adapted, fetchall_adapted to cursor.
 Radek Brich <radek.brich@devl.cz> parents: 
5diff
changeset | 7 | class LongQueriesTool(toolbase.SimpleTool): | 
| 2 | 8 | def __init__(self): | 
| 7 
685b20d2d3ab
Reorganize directories. PgDataDiff - reworked. PgManager - add fetchone_adapted, fetchall_adapted to cursor.
 Radek Brich <radek.brich@devl.cz> parents: 
5diff
changeset | 9 | toolbase.SimpleTool.__init__(self, name='longqueries', desc='List long queries.') | 
| 73 
390376b9e70f
Update longqueries tool: add --age parameter.
 Radek Brich <radek.brich@devl.cz> parents: 
44diff
changeset | 10 |         self.parser.add_argument('--age', default='1m', help='How long must be the query running to be listed.')
 | 
| 2 | 11 | self.init() | 
| 12 | ||
| 13 | def main(self): | |
| 14 |         stats = pgstats.PgStats(self.pgm.get_conn('target'))
 | |
| 15 | ||
| 73 
390376b9e70f
Update longqueries tool: add --age parameter.
 Radek Brich <radek.brich@devl.cz> parents: 
44diff
changeset | 16 | for ln in stats.list_long_queries(self.args.age): | 
| 44 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 17 | print(highlight(1), | 
| 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 18 | 'backend PID: ', ln['procpid'], | 
| 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 19 |                   ', query_start: ', ln['query_start'].strftime('%F %T'),
 | 
| 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 20 | ', client IP: ', ln['client_addr'], | 
| 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 21 | ln['waiting'] and ', ' + highlight(1, YELLOW|BOLD) + 'waiting' or '', | 
| 
4fe39c59c515
Update longqueries tool: add client IP, waiting attributes.
 Radek Brich <radek.brich@devl.cz> parents: 
39diff
changeset | 22 | highlight(0), sep='') | 
| 2 | 23 | print(ln['query']) | 
| 5 | 24 | print() | 
| 2 | 25 | |
| 26 | ||
| 27 | tool = LongQueriesTool() | |
| 28 | tool.main() | |
| 29 |