mysql管理----状态参数释义

转载 2013年12月05日 15:05:13

下面是数据库MySQL优化的一些步骤

mysqllogo

一、通过show status和应用特点了解各种SQL的执行频率

通过SHOW STATUS可以提供服务器状态信息,也可以使用mysqladmin extended-status命令获得。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 慢查询的次数

二、定位执行效率较低的SQL语句
可以通过以下两种方式定位执行效率较低的SQL语句:
1.可以通过慢查询日志定位那些执行效率较低的sql语句,用–log-slow-queries[=file_name]选项启动时,mysqld写一个包含所有执行时间超过long_query_time秒的SQL语句的日志文件。可以链接到管理维护中的相关章节。

2.慢查询日志在查询结束以后才纪录,所以在应用反映执行效率出现问题的时候查询慢查询日志并不能定位问题,可以使用show processlist命令查看当前MySQL在进行的线程,包括线程的状态,是否锁表等等,可以实时的查看SQL执行情况,同时对一些锁表操作进行优化。

三、通过EXPLAIN分析低效SQL的执行计划
通过以上步骤查询到效率低的SQL后,我们可以通过explain或者desc 获取MySQL如何执行SELECT语句的信息,包括select语句执行过程表如何连接和连接的次序。
explain可以知道什么时候必须为表加入索引以得到一个使用索引来寻找记录的更快的SELECT。
 
mysql> explain select sum(moneys) from sales a,companys b where a.company_id = b.id and a.year = 2006;
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
| select_type   | table | type  | possible_keys| key            | key_len   | rows  | Extra     |
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
| SIMPLE    | b     | index | PRIMARY   | PRIMARY   | 4     |    1  | Using index   |
| SIMPLE    | a     | ALL   | NULL      | NULL      | NULL  |   12  | Using where   |
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
2 rows in set (0.02 sec)
 
select_type:select 类型
table:输出结果集的表
type:表示表的连接类型

①当表中仅有一行是type的值为system是最佳的连接类型;

②当select操作中使用索引进行表连接时type的值为ref;

③当select的表连接没有使用索引时,经常会看到type的值为ALL,表示对该表进行了全表扫描,这时需要考虑通过创建索引来提高表连接的效率。

possible_keys:表示查询时,可以使用的索引列.
key:表示使用的索引
key_len:索引长度
rows:扫描范围
Extra:执行情况的说明和描述
 
四、确定问题,并采取相应的优化措施
经过以上步骤,基本可以确认问题出现的原因,可以根据情况采取相应的措施,进行优化提高执行的效率。
例如上面的例子,我们确认是对a表的全表扫描导致效率的不理想,我们对a表的year字段创建了索引,查询需要扫描的行数明显较少。
 
mysql> explain select sum(moneys) from sales a,companys b where a.company_id = b.id and a.year = 2006;
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
| select_type   | table | type  | possible_keys| key            | key_len   | rows  | Extra     |
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
| SIMPLE    | b     | index | PRIMARY   | PRIMARY   | 4     |    1  | Using index   |
| SIMPLE    | a     | ref       | year      | year      | 4     |    3  | Using where   |
+—————-+———-+———–+—————-+—————-+———-+———–+—————-+
2 rows in set (0.02 sec)

转载自:http://www.jfox.info/shu-ju-ku-MySQL-you-hua-de-yi-xie-bu-zhou

详细的Http状态参数

  • 2013年04月23日 11:12
  • 56KB
  • 下载

memcached 运行状态参数及存储原理详解

这些状态的说明如下: pid memcache服务器的进程ID uptime 服务器已经运行的秒数 time 服务器当前的uni...

memcached 运行状态参数及存储原理详解

memcached 运行状态参数及存储原理详解 这些状态的说明如下: pid memcache服务器的进程ID uptime ...

设置BM、SGBM和GC算法的状态参数

5. 如何设置BM、SGBM和GC算法的状态参数? (1)StereoBMState // 预处理滤波参数 preFilterType:预处理滤波器的类型,主要是用于降低亮度...

memcached 运行状态参数及存储原理详解

这些状态的说明如下: pid memcache服务器的进程ID uptime 服务器已经运行的秒数 time 服务器当前的unix时间戳...
  • lyd518
  • lyd518
  • 2014年07月09日 13:40
  • 1324

MySQL参考手册第5章:服务器管理-系统参数、变量与状态

服务器管理有几方面,1 命令行及配置文件的选项 2 系统变量 3 系统状态。如果对这3方面能很熟悉,则即可以对MySQL进行较好的调整和监控。然而难点也在于此,这此选项、变量、状态值众多,动辄数百个,...
  • zzulp
  • zzulp
  • 2014年06月04日 15:57
  • 2412

MySQL运行状态查询与参数说明

  • 2017年10月23日 12:13
  • 433KB
  • 下载

mysql常用配置参数和状态变量

  • 2013年06月24日 09:48
  • 61KB
  • 下载

Websphere commerce 订单状态初步释义

正在审批支付核准:在正常情况下,一个订单被提交后,订单的状态显示为 正在审批支付核准。 n         如果是货到付款,payLater,billMe等支付方式,支付状态显示为[成功]。这里不需...

54个参数的潜在信息显示释义

  • 2012年10月21日 23:07
  • 69KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mysql管理----状态参数释义
举报原因:
原因补充:

(最多只允许输入30个字)