MySQL进阶学习与初阶复习第四天
目录
一.mysqladmin - MySQL 服务器管理程序
作⽤
使⽤⽅法
⽀持的命令
常⽤选项
二.mysqlshow - 显⽰数据库、表和列信息
作⽤
注意事项
使⽤⽅法
常⽤选项
三.mysqldumpslow - 总结慢查询⽇志⽂件
作⽤
注意事项
使⽤⽅法
常⽤选项
一.mysqladmin - MySQL 服务器管理程序
作⽤
mysqladmin 是⼀个执⾏管理操作的客⼾端。可以⽤来检查服务器的配置和当前状态,以及创建和删除数据库等。
使⽤⽅法
mysqladmin 可以使⽤以下语法:
mysqladmin [options] command [command-arg] [command [command-arg]] ...
⽀持的命令
语法中的command 表⽰命令,有些命令后⾯需要跟上⼀个参数,如下列出了mysqladmin 的常⽤命令:
version
显⽰来⾃服务器的版本信息。
查看服务器状态
- Uptime MySQL 服务器已运⾏的秒数。
- Threads 活动线程(客⼾端)的数量。
- Questions ⾃服务器启动以来客⼾端的问题(查询)数。
- Slow queries 慢SQL的查询数。
- Opens 服务器已打开的表数。
- Flush tables 服务器已执⾏flush-*、refresh和reload命令的数量。
- Open tables 当前打开的表数。
2. create db_name
创建⼀个数据库名为 db_name 。
3. drop db_name
删除名为 db_name 的数据库及其所有表。
4. extended-status
显⽰服务器状态变量的值。
5. flush-hosts
刷新主机缓存中的所有信息。
6. flush-logs [log_type ...]
刷新所有⽇志。 log_type 中可以提供以下⼀种或多种⽇志类型binary, engine, error, general, relay, slow,多个类型之间⽤空格分隔。
7. flush-privileges
重新加载授权表
8. flush-status
清除状态变量。
9. flush-tables
刷新所有表。
10. flush-threads
刷新线程缓存。
11. password new_password
设置新密码。
- 如果密码中有空格必须⽤双引号把密码包裹起来
- password 后可以省略新密码,mysqladmin会在之后提⽰输⼊新密码
- password 做为最后⼀个command 时才可以省略密码值,否则下⼀个参数将作为密码被设置。
Warning 有可能存在安全问题
Setting a password using mysqladmin should be considered insecure. On some systems, your password becomes visible to system status programs such as ps that may be invoked by other users to display command lines. MySQL clients typically overwrite the command-linepassword argument with zeros during their initialization sequence. However, there is still a brief interval during which the value is visible. Also, on some systems this overwriting strategy is ineffective and the password remains visible to ps. (SystemV Unix systems and perhaps others are subject to this problem.)
12. ping
检查服务器是否可⽤
13. processlist
显⽰活动服务器线程的列表。
14. kill id , id ,...
终⽌服务器线程。如果给出了多个线程ID值,则列表中不能有空格。
15. reload
重新加载授权表。
16. refresh
刷新所有表。
17. shutdown
停⽌服务器。
18. start-replica
在副本服务器上开始复制。MySQL 8.0.26及以后的版本使⽤此命令。
19. start-slave
在副本服务器上开始复制。MySQL 8.0.26 之前使⽤此命令。
20. status
显⽰简短的服务器状态消息。
21. stop-replica
停⽌副本服务器上的复制。MySQL 8.0.26及以后的版本使⽤此命令。
22. stop-slave
停⽌副本服务器上的复制。MySQL 8.0.26 之前使⽤此命令。
23. variables
显⽰服务器系统变量及其值。
常⽤选项
mysqladmin 的常⽤选项参考公共选项部分,可以在命令⾏中指定,也可以在选项⽂件中通过[mysqladmin] 和 [client] 组进⾏指定
二.mysqlshow - 显⽰数据库、表和列信息
作⽤
mysqlshow 客⼾端可⽤于快速查看存在哪些数据库、数据库中的表以及表中的列或索引。
注意事项
mysqlshow 为⼀些 SHOW 语句提供了⼀个命令⾏接⼝。关于SHOW的使⽤参⻅官⽅⽂件“SHOW语句”。直接使⽤这些SQL语句也可以获得相同的信息。
使⽤⽅法
mysqlshow 可以使⽤以下语法:
mysqlshow [options] [db_name [tbl_name [col_name]]]
- db_name tbl_name col_name 可以使⽤通配符 * 、 ? 、 % 或 _
- 如果没有指定数据库,则显⽰所有数据库名称列表。
- 如果没有指定表,则显⽰数据库中所有匹配的表。
- 如果没有指定列,则显⽰表中所有匹配的列和列类型。
- 输出仅显⽰当前权限可以访问的数据库、表或列的名称。
mysqlshow test_db -uroot -p # 显⽰test_db数据库中的所有表
mysqlshow test_db student -uroot -p # 显⽰student表中的所有字段
mysqlshow test_db student id -uroot -p # 显⽰student表中id字 段的信息
常⽤选项
mysqlshow 的常⽤选项参考公共选项部分,可以在命令⾏中指定,也可以在选项⽂件中通过[mysqlshow] 和 [client] 组进⾏指定,具体选项参考公共选项列表。
三.mysqldumpslow - 总结慢查询⽇志⽂件
作⽤
在平时使⽤MySQL数据库时,经常进⾏查询操作,有些查询语句执⾏的时间⾮常⻓,当执⾏时间超过设定的阈值时,我们称这个查询为慢查询,慢查询的相关信息通常需要⽤⽇志记录下来称为慢查询⽇志,mysqldumpslow可以解析慢查询⽇志⽂件并汇总其内容,有关慢查询⽇志的内容我们在MySQL服务器配置与管理专题进⾏讲解.
注意事项
通常情况下,mysqldumpslow 会将相似的查询分组并显⽰摘要输出,⼀般会把数字和字符串⽤ N 和 "S" 代替,要想显⽰真实的值可以使⽤ -a 和 -n 选项。
使⽤⽅法
mysqldumpslow 可以使⽤以下语法
mysqldumpslow [options] [log_file ...]
如下图这样找到慢查询日志文件。
show variables like "%query%";
在没有给出任何选项的输出如下:
Reading mysql slow query log from /usr/local/mysql/data/mysqld80-slow.log
Count: 1 Time=4.32s (4s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t2 select * from t1 # 执⾏的SQL
Count: 3 Time=2.53s (7s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t2 select * from t1 limit N # 执⾏的SQL
Count: 3 Time=2.13s (6s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t1 select * from t1 # 执⾏的SQL
常⽤选项
mysqldumpslow 的常⽤选项
选项 | 说明 |
-a | 不⽤ N 和 'S' 代替numbers和String |
-n N | 在名称中包含N个以上的数字⽤ N 代替 |
-g pattern | 仅考虑与指定模式匹配的慢查询 |
--help | 显⽰帮助信息并退出 |
-h host_name | 与*-slow.log⽂件名对应的MySQL服务器主机名。 可以包含通配符。默认值是*(匹配所有)。 |
-i name | 服务器示例名称 |
-l | 不要从总时间中减去锁占⽤的时间 |
-r | 倒序顺列 |
-s sort_type | 如何对输出进⾏排序 |
-t N | 显⽰输出中的前N个查询 |
--verbose, -v | 打印有关程序功能的更多信息 |
• -s sort_type sort_type可选的值如下所⽰:
- t , at : 按查询时间或平均查询时间排序,默认排序
- l , al : 按锁占⽤时间或平均锁占⽤时间排序
- r , ar : 按发送的⾏数或平均发送的⾏数排序
- c : 按计数排序