在调优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. 注册中心eureka

    最近在忙一些其它的事情,两个城市来回跑还要办一些手续,挺费劲的,学习的事情也就耽误了一些,尽量赶吧. spring cloud为分布式的微服务架构提供了一站式的解决方案,eureka注册中心在spri ...

  2. spring boot 配置redis

    先配置属性: # database name spring.redis.database=0 # server host spring.redis.host=127.0.0.1 # server pa ...

  3. 如何有效防止DEDE织梦系统被挂木马安全设置(仅供参考)

    尊敬的客户,您好!     感谢广大客户对我司工作的信任和支持!      我司在最近的一个多月内陆续发现多起因 DedeCMS 安全漏洞造成网站被上传恶意脚本的事件,入侵者可利用恶意脚本对外发送大量 ...

  4. java实现连接mysql数据库单元测试查询数据项目分享

    1.按照javaweb项目的要求逐步建立搭建起机构,具体的类包有:model .db.dao.test;具体的架构详见下图: 2.根据搭建的项目架构新建数据库test和数据库表t_userinfo并且 ...

  5. activeMq 配置(一)

    基础知识补充 1.ActiveMQ从入门到精通(一)https://www.jianshu.com/p/ecdc6eab554c 2.ActiveMQ从入门到精通(二)https://www.jian ...

  6. Java中的阻塞队列-SynchronousQueue

    SynchronousQueue是一个不存储元素的阻塞队列.每一个put操作必须等待一个take操作,否则不能继续添加元素.SynchronousQueue可以看成是一个传球手,负责把生产者线程处理的 ...

  7. hystrix应用介绍(三)

    hystrix提供了两种隔离策略:线程池隔离和信号量隔离.hystrix默认采用线程池隔离. 1.线程池隔离 不同服务通过使用不同线程池,彼此间将不受影响,达到隔离效果. 例如: 我们可以通过andT ...

  8. IDEA插件JRebel安装配置与破解激活详细教程(转)

    JRebel 介绍 IDEA上原生是不支持热部署的,一般更新了 Java 文件后要手动重启 Tomcat 服务器,才能生效,浪费不少生命啊.目前对于idea热部署最好的解决方案就是安装JRebel插件 ...

  9. Django Rest Framework进阶二

    一.版本 版本控制:当程序越来越大,后期需要再加入一些功能或者进行二次开发时就需要加上版本号了. 之前我们在没有接触rest_framework之前一般是以下这种方式来实现的 class UserVi ...

  10. 错误Cannot find module 'stylus'

    vue项目中使用stylus预处理器写css语法,老是出现 Cannot find module ‘stylus’ 的错误,鼓捣了很久,包括webstorm中配置stylus的支持,安装依赖. 终于找 ...