通过 SHOW STATUS 可以提供服务器状态信息,也可以使用 mysqladmin extendedstatus 命令获得。SHOW STATUS 可以根据需要显示 session 级别的统计结果和 global级别的统计结果。
以下几个参数对 Myisam 和 Innodb 存储引擎都计数:
1. Com_select 执行 select 操作的次数,一次查询只累加 1;
2. Com_insert 执行 insert 操作的次数,对于批量插入的 insert 操作,只累加一次;
3. Com_update 执行 update 操作的次数;
4. Com_delete 执行 delete 操作的次数;

以下几个参数是针对 Innodb 存储引擎计数的,累加的算法也略有不同:
1. Innodb_rows_read select 查询返回的行数;
2. Innodb_rows_inserted 执行 Insert 操作插入的行数;
3. Innodb_rows_updated 执行 update 操作更新的行数;
4. Innodb_rows_deleted 执行 delete 操作删除的行数;
通过以上几个参数,可以很容易的了解当前数据库的应用是以插入更新为主还是
以查询操作为主,以及各种类型的 SQL 大致的执行比例是多少。对于更新操作的计数 ,是对执行次数的计数,不论提交还是回滚都会累加。
对于事务型的应用,通过 Com_commit 和 Com_rollback 可以了解事务提交和回滚的情况,对于回滚操作非常频繁的数据库,可能意味着应用编写存在问题。
此外,以下几个参数便于我们了解数据库的基本情况:
1. Connections 试图连接 Mysql 服务器的次数
2. Uptime 服务器工作时间
3. Slow_queries 慢查询的次数
 
下面是将操作命令脚本化了,而且实时动态输出:
mysqladmin -h127.0.0. -r -i  extended-status |awk -F "|" 'BEGIN { count=0; } { if($2 ~ /Variable_name/ && ++count%15 == 1){print "----------|---------|--- MySQL Command Status --|----- Innodb row operation -----|-- Buffer Pool Read --";    print "---Time---|---QPS---|select insert update delete|   read inserted updated deleted|   logical    physical";} else if ($2 ~ /Queries/){queries=$3;} else if ($2 ~ /Com_select /){com_select=$3;} else if ($2 ~ /Com_insert /){com_insert=$3;} else if ($2 ~ /Com_update /){com_update=$3;} else if ($2 ~ /Com_delete /){com_delete=$3;} else if ($2 ~ /Innodb_rows_read/){innodb_rows_read=$3;} else if ($2 ~ /Innodb_rows_deleted/){innodb_rows_deleted=$3;} else if ($2 ~ /Innodb_rows_inserted/){innodb_rows_inserted=$3;} else if ($2 ~ /Innodb_rows_updated/){innodb_rows_updated=$3;} else if ($2 ~ /Innodb_buffer_pool_read_requests/){innodb_lor=$3;} else if ($2 ~ /Innodb_buffer_pool_reads/){innodb_phr=$3;} else if ($2 ~ /Uptime / && count >= 2){  printf(" %s |%9d",strftime("%H:%M:%S"),queries);printf("|%6d %6d %6d %6d",com_select,com_insert,com_update,com_delete);printf("|%8d %7d %7d %7d",innodb_rows_read,innodb_rows_inserted,innodb_rows_updated,innodb_rows_deleted); printf("|%10d %11d\n",innodb_lor,innodb_phr);}}'

输出结果如下:

----------|---------|--- MySQL Command Status --|----- Innodb row operation -----|-- Buffer Pool Read --
---Time---|---QPS---|select insert update delete| read inserted updated deleted| logical physical
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
----------|---------|--- MySQL Command Status --|----- Innodb row operation -----|-- Buffer Pool Read --
---Time---|---QPS---|select insert update delete| read inserted updated deleted| logical physical
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |
:: | | | |

可以清楚的看见QPS,以及各种SQL的执行频率,通过上面的执行结果来看,我现在主要是读比较频繁。好了,就说到这里了。^_^

最新文章

  1. 手把手教你玩转nginx负载均衡(二)----安装虚拟机操作系统
  2. HTML table、form表单标签的介绍
  3. DATETIME类型和BIGINT 类型互相转换
  4. Fckeditor PHP/ASP File Upload Vul
  5. ajax实现文件下载
  6. JAVA学习Swing章节按钮组件JButton的简单学习
  7. 使用Eclipse构建Maven的SpringMVC项目
  8. Wpf实现图片自动轮播自定义控件
  9. Ubuntu14.04 切换root账户su root失败解决办法
  10. Liunx0000(初步认识)
  11. Android(java)学习笔记103:Map集合的获取功能
  12. 深入了解一下PYTHON中关于SOCKETSERVER的模块-A
  13. Python模拟登录实战(二)
  14. 服务启动项 Start类型详解
  15. webservice 第一节 .net SoapHeader验证
  16. iOS中 学会如何对sqlite3 进行封装 (纯手工)
  17. js 数组去重常见的几种方式
  18. jacascript 事件对象event
  19. 升级AndroidStudio3.4问题汇总
  20. sql group by聚合函数

热门文章

  1. Mybatis(二)基于注解的入门实例
  2. akka cluster singleton
  3. 百度网盘上下载文件,调用api接口的请求方式和参数
  4. MySQL PARTITION 分区
  5. Kubernetes部署SpringCloud(二) 部署ZUUL与服务 非host, 伸缩与负载均衡
  6. C#自定义按钮、自定义WinForm无边框窗体、自定义MessageBox窗体
  7. springboot JPA
  8. Spring学习笔记--代理
  9. ArcGIS AddIn开发笔记(一)
  10. hdparm命令(转)