1 Demonstrations of dbstat, the Linux eBPF/bcc version. 2 3 4 dbstat traces queries performed by a MySQL or PostgreSQL database process, and 5 displays a histogram of query latencies. For example: 6 7 # dbstat mysql 8 Tracing database queries for pids 25776 slower than 0 ms... 9 query latency (ms) : count distribution 10 0 -> 1 : 990 |****************************************| 11 2 -> 3 : 7 | | 12 4 -> 7 : 0 | | 13 8 -> 15 : 0 | | 14 16 -> 31 : 0 | | 15 32 -> 63 : 0 | | 16 64 -> 127 : 0 | | 17 128 -> 255 : 0 | | 18 256 -> 511 : 0 | | 19 512 -> 1023 : 0 | | 20 1024 -> 2047 : 2 | | 21 ^C 22 23 It's immediately evident that the vast majority of queries finish very quickly, 24 in under 1ms, but there are some super-slow queries occasionally, in the 1-2 25 seconds bucket. 26 27 We can filter out the shorter queries with the -m switch: 28 29 # dbstat mysql -m 1000 30 Tracing database queries for pids 25776 slower than 1000 ms... 31 query latency (ms) : count distribution 32 0 -> 1 : 0 | | 33 2 -> 3 : 0 | | 34 4 -> 7 : 0 | | 35 8 -> 15 : 0 | | 36 16 -> 31 : 0 | | 37 32 -> 63 : 0 | | 38 64 -> 127 : 0 | | 39 128 -> 255 : 0 | | 40 256 -> 511 : 0 | | 41 512 -> 1023 : 0 | | 42 1024 -> 2047 : 8 |****************************************| 43 ^C 44 45 By default, dbstat will try to detect mysqld and postgres processes, but if 46 necessary, you can specify the process ids with the -p switch. Here, the -i 47 switch is also used to request histograms at 3 second intervals: 48 49 # dbstat mysql -p $(pidof mysql) -i 3 50 Tracing database queries for pids 25776 slower than 0 ms... 51 [06:14:36] 52 query latency (ms) : count distribution 53 0 -> 1 : 758 |****************************************| 54 2 -> 3 : 1 | | 55 4 -> 7 : 0 | | 56 8 -> 15 : 0 | | 57 16 -> 31 : 0 | | 58 32 -> 63 : 0 | | 59 64 -> 127 : 0 | | 60 128 -> 255 : 0 | | 61 256 -> 511 : 0 | | 62 512 -> 1023 : 0 | | 63 1024 -> 2047 : 1 | | 64 65 [06:14:39] 66 query latency (ms) : count distribution 67 0 -> 1 : 436 |****************************************| 68 2 -> 3 : 2 | | 69 4 -> 7 : 0 | | 70 8 -> 15 : 0 | | 71 16 -> 31 : 0 | | 72 32 -> 63 : 0 | | 73 64 -> 127 : 0 | | 74 128 -> 255 : 0 | | 75 256 -> 511 : 0 | | 76 512 -> 1023 : 0 | | 77 1024 -> 2047 : 1 | | 78 79 [06:14:42] 80 query latency (ms) : count distribution 81 0 -> 1 : 399 |****************************************| 82 2 -> 3 : 0 | | 83 4 -> 7 : 0 | | 84 8 -> 15 : 0 | | 85 16 -> 31 : 0 | | 86 32 -> 63 : 0 | | 87 64 -> 127 : 0 | | 88 128 -> 255 : 0 | | 89 256 -> 511 : 0 | | 90 512 -> 1023 : 0 | | 91 1024 -> 2047 : 1 | | 92 ^C 93 94 95 USAGE: 96 # dbstat -h 97 usage: dbstat.py [-h] [-v] [-p [PID [PID ...]]] [-m THRESHOLD] [-u] 98 [-i INTERVAL] 99 {mysql,postgres} 100 101 positional arguments: 102 {mysql,postgres} the database engine to use 103 104 optional arguments: 105 -h, --help show this help message and exit 106 -v, --verbose print the BPF program 107 -p [PID [PID ...]], --pid [PID [PID ...]] 108 the pid(s) to trace 109 -m THRESHOLD, --threshold THRESHOLD 110 trace queries slower than this threshold (ms) 111 -u, --microseconds display query latencies in microseconds (default: 112 milliseconds) 113 -i INTERVAL, --interval INTERVAL 114 print summary at this interval (seconds) 115 116 dbstat postgres # display a histogram of PostgreSQL query latencies 117 dbstat mysql -v # display MySQL latencies and print the BPF program 118 dbstat mysql -u # display query latencies in microseconds (default: ms) 119 dbstat mysql -m 5 # trace only queries slower than 5ms 120 dbstat mysql -p 408 # trace queries in a specific process 121