MySQL · 工具使用 · MySQL client pager/edit/tee 介绍

2023-10-08 13:43:13 浏览数 (1)

我们日常使用的MySQL client 有用的命令使用介绍

pager

pager 任何命令

常用的比如:

pager grep ‘Pending normal aio reads’

就可以执行show engine innodb status 以后只看grep 的内容

代码语言:txt复制
mysql> pager grep 'Pending normal aio reads'
PAGER set to 'grep 'Pending normal aio reads''
mysql> show engine innodb statusG
Pending normal aio reads: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] , aio writes: [256, 256, 256, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] ,
1 row in set (0.00 sec)

pager less

那么执行show engine innodb status 以后直接less 查看结果

pager vim -

然后执行show engine innodb status 就可以直接进入到vim 里面编辑执行结果

关闭pager 就是执行 nopager 或者 n 就可以

P 又重新恢复上一个pager 的设置

还有一些骚操作 比如:

如果我只想要看执行的时间, 不想要看具体的结果, 这么多次执行可以在同一个屏幕里面显示, 那么可以执行

代码语言:txt复制
mysql> pager cat > /dev/null
PAGER set to 'cat > /dev/null'
    
# Trying an execution plan
mysql> SELECT ...
1000 rows in set (0.91 sec)
    
# Another execution plan
mysql> SELECT ...
1000 rows in set (1.63 sec)

比如我要对比两次查询的结果是否一致, 那么可以通过md5 命令来进行对比

代码语言:txt复制
mysql> pager md5sum
PAGER set to 'md5sum'
     
# Original query
mysql> SELECT ...
32a1894d773c9b85172969c659175d2d  -
1 row in set (0.40 sec)
     
# Rewritten query - wrong
mysql> SELECT ...
fdb94521558684afedc8148ca724f578  -
1 row in set (0.16 sec)

比如最常用的show processlist 里面, 也可以使用pager 去查有多少个sleep 的线程

代码语言:txt复制
mysql> pager grep Sleep | wc -l
PAGER set to 'grep Sleep | wc -l'
mysql> show processlist;
337
346 rows in set (0.00 sec)

或者可以写的更复杂一些, 统计所有的.

代码语言:txt复制
mysql> pager awk -F '|' '{print $6}' | sort | uniq -c | sort -r
PAGER set to 'awk -F '|' '{print $6}' | sort | uniq -c | sort -r'
mysql> show processlist;
    309  Sleep       
      3 
      2  Query       
      2  Binlog Dump 
      1  Commandpager 后面也可以用写一个脚本来承接, 更骚

#!/bin/sh

grep -A 1 'TRX HAS BEEN WAITING'

代码语言:txt复制
把这个脚本保存在 /tmp/lock_waits 上, 那么就可以过滤show engine innodb status 里面 trx wait 的

mysql> pager /tmp/lock_waits

PAGER set to '/tmp/lock_waits'

mysql> show innodb statusG

------- TRX HAS BEEN WAITING 50 SEC FOR THIS LOCK TO BE GRANTED:

RECORD LOCKS space id 0 page no 52 n bits 72 index GEN_CLUST_INDEX of table test/t trx id 0 14615 lock_mode X waiting

1 row in set, 1 warning (0.00 sec)

代码语言:txt复制
当然还有更复杂的, 把explain 的结果进行更详细的展示的

edit

edit 命令能够把你上一句命令放在vim 编辑器里面进行编辑, 然后再执行

mysql> select count(*) from film left join film_category using(film_id) left join category using(category_id) where name='Music';

代码语言:txt复制
然后执行 edit 命令, 就进入到vim 终端编辑了

tee

把执行的结果输出到另外一个文件里面

mysql> tee queries.log

Logging to file 'queries.log'

mysql> use sakila

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> select count(*) from sakila;

ERROR 1146 (42S02): Table 'sakila.sakila' doesn't exist

mysql> select count(*) from film;

----------

| count(*) |

----------

| 1000 |

----------

1 row in set (0.00 sec)

mysql> exit

代码语言:txt复制

0 人点赞