在调优MySQL数据库和监控数据库时,很多朋友不知道如何下手,怎么来确定是不是参数设置的合理,下面给出一些如何计算指标,来确定数据库参数是否设置合理,希望给大家一些方法,去做MySQL数据库优化,最好对照一下方法,看看自己的生产库配置是否有问题。
 
在show global status;查看各个值。
 
平均查看是否频繁打开表
Opened_tables/Uptime  = xx/s
299304/21062119= 0.0142/s   --每秒不到1次的打开表,说明都是在内存里缓存了,比较理想
 
平均查看是否频繁打开文件
Opened_files/Uptime = xx/s
732146117/21062119= 34.7613/s     --比较频繁 ,可能是如下参数比较小,缓存少导致
+-------------------+-------+
| Variable_name     | Value |
+-------------------+-------+
| innodb_open_files | 3000  |
| open_files_limit  | 65535 |
+-------------------+-------+
 
平均查看是否频繁打开表结构
Opened_table_definitions/Uptime = xx/s
32631/21062119= 0.0015/s    --每秒不到1次的打开表结构,说明都是在内存里缓存了,比较理想
 
innodb buffer的预读取是否有用
Innodb_buffer_pool_read_ahead_evicted:预读取被清理的页数量
Innodb_buffer_pool_read_ahead:预读取的页数量
( 1 - Innodb_buffer_pool_read_ahead_evicted / Innodb_buffer_pool_read_ahead ) *100  =  xx%
( 1 - 149/4896862)*100 =  99.9970%   --此百分比很高,说明预读取的页被清理出内存的很少,预读取设置比较理想
 
innodb_read_ahead_threshold:此参数是设置预读取的页数,设置0是关闭预读取功能
 
查看log file大小是否合适
Innodb_log_waits :log file发生等待的次数,说明log buffer太小或者是刷新频繁导致
Innodb_os_log_written :redo日志写的字节数
( innodb_log_file_size * innodb_log_files_in_group / innodb_buffer_pool_size ) *100 =  xx%
(1572864000*2/25769803776)*100 = 12.2070%   --使用率,推荐在 1.2% -- 50%之间
 
innodb_rollback_on_timeout :超时回滚,尽量关闭
 
平均每秒请求读指定行数据的次数
Handler_read_rnd
Handler_read_rnd/Uptime  = xx/s
120716896940/21062119 = 5731.4697/s   --可能需要大量的排序,可能需要大量的扫描表或者没有使用正确索引导致的
 
平均每秒join没有使用索引的次数
Select_full_join /Uptime = xx/s
723959/21062119 = 0.0344/s  --此值不为0 ,需要注意检查是否没有索引
 
join没有使用索引的百分比
( Select_full_join / Com_select ) * 100 = xx%
(723959/27756137450)*100 = 0.0026%
 
平均每秒join时第一个表全表扫描次数
Select_scan /Update = xx/s
18777133984/ 21062119 = 891.5121/s   --全表扫描次数太多
 
平均每秒的连接次数
Connections /uptime = xx/s
11646933/21062119 =  0.5530/s
 
线程创建连接的百分比
Threads_created:线程创建连接的次数
( Threads_created / Connections ) *100 = xx%
(69532/11646933)*100 = 0.5970/s
 
( Max_used_connections / max_connections ) *100 = xx%
(875/5512)*100 =  15.8745%   --表示最多使用了设置的最大连接数的15.8% ,最大连接数设置的比实际大很多,够用

MySQL如何计算重要的指标,来确定配置是否正确的更多相关文章

  1. MySQL+MyCat分库分表 读写分离配置

    一. MySQL+MyCat分库分表 1 MyCat简介 java编写的数据库中间件 Mycat运行环境需要JDK. Mycat是中间件.运行在代码应用和MySQL数据库之间的应用. 前身 : cor ...

  2. 【0.2】【MySQL】常用监控指标及监控方法(转)

    [MySQL]常用监控指标及监控方法 转自:https://www.cnblogs.com/wwcom123/p/10759494.html  对之前生产中使用过的MySQL数据库监控指标做个小结. ...

  3. Winserver2012下mysql 5.7解压版(zip)配置安装

    一.安装 下载mysqlzip版本mysql不需要运行可执行文件,解压即可,下载zip版本mysqlmsi版本mysql双击文件即可安装,相对简单,本文不介绍此版本安装 配置环境变量打开环境变量配置页 ...

  4. MySQL Cluster 7.3.5 集群配置实例(入门篇)

    一.环境说明: CentOS6.3(32位) + MySQL Cluster 7.3.5,规划5台机器,资料如下: 节点分布情况: MGM:192.168.137. NDBD1:192.168.137 ...

  5. MySQL Cluster 7.3.5 集群配置参数优化(优化篇)

    按照前面的教程:MySQL Cluster 7.3.5 集群配置实例(入门篇),可快速搭建起基础版的MySQL Cluster集群,但是在生成环境中,还是有很多问题的,即配置参数需要优化下, 当前生产 ...

  6. MySQL 5.5.35 单机多实例配置详解

    一.前言 二.概述 三.环境准备 四.安装MySQL 5.5.35 五.新建支持多实例的配置文件(我这里配置的是四个实例) 六.初始化多实例数据库 七.提供管理脚本 mysqld_multi.serv ...

  7. 安装完 MySQL 后必须调整的 10 项配置(转)

    英文原文:10 MySQL settings to tune after installation 译文原文:安装完 MySQL 后必须调整的 10 项配置 当我们被人雇来监测MySQL性能时,人们希 ...

  8. 【MySQL】源码编译安装和配置MySql 5.5.32(单实例)

    [需求描述] 在CentOS环境中,通过编译源码的方式,安装并且配置“单实例”的MySQL5.5.32数据库. MySQL的安装目录为:/application/mysql-5.5.32 MySQL数 ...

  9. MySql安装(rpm)和启动配置

    MySql安装(rpm)和启动配置 安装环境: OS:Oracle Linux 5.9 安装步骤: 1.解压MySql安装包 [root@bakdbserver mysql]# tar -xf MyS ...

随机推荐

  1. ruby逻辑判断符号

    puts true and false  #相当于 (puts true) and false Use &&/|| for boolean expressions, and/or fo ...

  2. stm32串口学习(二)

    今天继续学习stm32的串口编程(利用库函数).上次我们说了串口的发送,这次我们说接收. 接收可以用查询的方法,也可以用中断.显然,工程中多用中断的方式,那么就来看看中断接收. 代码其实很简单,基本的 ...

  3. GET和POST区别和用法

    很多人都分不清GET与POST的区别,以及什么时候用GET?什么时候用POST? GET和POST两种方法都是将数据送到服务器,但你该用哪一种呢? HTTP标准包含这两种方法是为了达到不同的目的.PO ...

  4. lftp 快速使用

    登录 lftp username:password@ip:port 设置字符集 set ftp:charset 'gbk' set ftp:charset 'utf-8' 下载文件 mget *.tx ...

  5. c#-day01学习笔记

    C#语言基础 .net之父--------安德斯/海尔斯伯格 .net是一个平台,一个集合,一个环境 .net出现的背景 .net的核心功能:能够在任何的时间,任何的地点,使用任何的设备,访问网络 . ...

  6. three.js学习笔记--基础知识

    基础知识 从去年开始就在计划中的three.js终于开始了 历史介绍 (摘自ijunfan1994的转载,感谢作者) OpenGL大概许多人都有所耳闻,它是最常用的跨平台图形库. WebGL是基于Op ...

  7. python类的反射

    反射 通过字符串映射或者修改程序运行时的状态.属性.方法, 有一下4个方法 小例子--根据用户输入调用方法: class Dog(object): def __init__(self,name): s ...

  8. Linux系统错误码对照表

    C Name Value Description EPERM 1 Operation not permitted ENOENT 2 No such file or directory ESRCH 3 ...

  9. Invalid MyEclipse License - Discontinuing this MyEclipse operation. 出现这个错误怎么改正?

    Invalid MyEclipse License - Discontinuing this MyEclipse operation这句话的意思是无效的许可证-停用此MyEclipse操作入门就是你的 ...

  10. IOS transform的使用(移动,放大,旋转)

    @interface ViewController () - (IBAction)up; - (IBAction)big ; - (IBAction)leftRotate ; @property (n ...