在调优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. pat1066. Root of AVL Tree (25)

    1066. Root of AVL Tree (25) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue An A ...

  2. 重启部署在Linux系统下的tomcat服务

    重启部署在Linux系统下的tomcat服务具体的操作步骤: 1.在Winscp上建立连接,输入用户和密码,这个密码一般是看不到的: 2.查看服务:ps -ef  |  gerp  Java  注意在 ...

  3. 【input】——数据传入后台

    1.复选框 checkbox <label class="checkbox"> <input type="checkbox" name=&qu ...

  4. C#入门--索引器

    C#入门--索引器 索引器允许类或结构的实例按照与数组相同的方式进行索引.索引器类似于属性,不同之处在于它们的访问器采用参数. 索引器概述 索引器使得对象可按照与数组相似的方法进行索引. get 访问 ...

  5. iOS 上滑隐藏导航,下滑显示导航,仿斗鱼导航效果

    UItableView或 UIcollectionView 都是继承UIScrollView 滑动的时候,判断是上滑还是下滑 使用 UIScrollView 的代理方法 func scrollView ...

  6. CSS知识点梳理

  7. vue-样式问题

    问题: 今天在用vue开发单页面应用的时候,遇到一个问题,在A页面,直接刷新,页面的布局样式之类的是没有问题的,不过在B页面跳转到A页面,那么A页面有一些样式就不是预期的效果. 发现解决问题: 用调试 ...

  8. webpack gulp grunt 简单介绍

    本文主要是讲下webpack的相关知识点,理论比较多,因为webpack的功能非常强大,说到的也基本都是经常用到的. 这三个工具都属于前端自动化的工具,都是第三方的,并且国内很多大型团队也都有自己成熟 ...

  9. HUE安装与使用

    HUE安装与使用 1.介绍 HUE是一个开源的Apache Hadoop UI系统,早期由Cloudera开发,后来贡献给开源社区.它是基于Python Web框架Django实现的.通过使用Hue我 ...

  10. hive数据仓库建设

    hive数据仓库建设 1.设计原生日志表 原生日志表用来存放上报的原始日志,数据经过清洗加工后会进入到各个日志表中. 1.1 创建数据库 #创建数据库 $hive>create database ...