今天主要介绍MySQL数据库,或者说所有数据库的三个关键性能指标:

qps 每秒处理的查询数

tps 每秒处理的事务数

IOPS 每秒磁盘进行的I/O操作次数

一、TPS(适用innodb)

1. 概念

Transactions Per Second(每秒传输的事物处理个数),即服务器每秒处理的事务数。

TPS包括一条消息入和一条消息出,加上一次用户数据库访问。(业务TPS = CAPS × 每个呼叫平均TPS)

TPS是软件测试结果的测量单位。一个事务是指一个客户机向服务器发送请求然后服务器做出反应的过程。客户机在发送请求时开始计时,收到服务器响应后结束计时,以此来计算使用的时间和完成的事务个数。

一般的,评价系统性能均以每秒钟完成的技术交易的数量来衡量。系统整体处理能力取决于处理能力最低模块的TPS值。

2. TPS计算

(1) 方法一

Com_commit=SHOWGLOBAL STATUS LIKE 'Com_commit';

Com_rollback=SHOWGLOBAL STATUS LIKE 'Com_rollback';

Uptime=SHOWGLOBAL STATUS LIKE 'Uptime';

TPS=(Com_commit + Com_rollback)/Uptime

(2) 方法二

use information_schema;

select VARIABLE_VALUE into @num_com from GLOBAL_STATUS where VARIABLE_NAME='COM_COMMIT';

select VARIABLE_VALUE into @num_roll from GLOBAL_STATUS where VARIABLE_NAME='COM_ROLLBACK';

select VARIABLE_VALUE into @uptime from GLOBAL_STATUS where VARIABLE_NAME='UPTIME';

select (@num_com+@num_roll)/@uptime;

二、QPS(同时适用与InnoDB和MyISAM 引擎 )

1. 概念

每秒查询率QPS是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准,在因特网上,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。

对应fetches/sec,即每秒的响应请求数,也即是最大吞吐能力。

2. QPS计算

(1) 方法一

Questions=SHOWGLOBAL STATUS LIKE 'Questions';

Uptime=SHOWGLOBAL STATUS LIKE 'Uptime';

QPS=Questions/Uptime

(2) 方法二

use information_schema;

select VARIABLE_VALUE into @num_queries from GLOBAL_STATUS where VARIABLE_NAME='QUESTIONS';

select VARIABLE_VALUE into @uptime from GLOBAL_STATUS where VARIABLE_NAME='UPTIME';

select @num_queries/@uptime;

三、IOPS

1. 概念

IOPS (Input/Output Per Second)即每秒的输入输出量(或读写次数),是衡量磁盘性能的主要指标之一。IOPS是指单位时间内系统能处理的I/O请求数量,一般以每秒处理的I/O请求数量为单位,I/O请求通常为读或写数据操作请求。随机读写频繁的应用,如OLTP(Online Transaction Processing),IOPS是关键衡量指标。另一个重要指标是数据吞吐量(Throughput),指单位时间内可以成功传输的数据数量。对于大量顺序读写的应用,如VOD(Video On Demand),则更关注吞吐量指标。

传统磁盘本质上一种机械装置,如FC,SAS,SATA磁盘,转速通常为5400/7200/10K/15K rpm不等。影响磁盘的关键因素是磁盘服务时间,即磁盘完成一个I/O请求所花费的时间,它由寻道时间、旋转延迟和数据传输时间三部分构成。

寻道时间Tseek是指将读写磁头移动至正确的磁道上所需要的时间。寻道时间越短,I/O操作越快,目前磁盘的平均寻道时间一般在3-15ms。

旋转延迟Trotation是指盘片旋转将请求数据所在扇区移至读写磁头下方所需要的时间。旋转延迟取决于磁盘转速,通常使用磁盘旋转一周所需时间的1/2表示。比如,7200 rpm的磁盘平均旋转延迟大约为60*1000/7200/2 = 4.17ms,而转速为15000 rpm的磁盘其平均旋转延迟约为2ms。

数据传输时间Ttransfer是指完成传输所请求的数据所需要的时间,它取决于数据传输率,其值等于数据大小除以数据传输率。目前IDE/ATA能达到133MB/s,SATA II可达到300MB/s的接口数据传输率,数据传输时间通常远小于前两部分时间。

IOPS可细分为如下几个指标:

Toatal IOPS,混合读写和顺序随机I/O负载情况下的磁盘IOPS,这个与实际I/O情况最为相符,大多数应用关注此指标。

Random Read IOPS,100%随机读负载情况下的IOPS。

Random Write IOPS,100%随机写负载情况下的IOPS。

Sequential Read IOPS,100%顺序负载读情况下的IOPS。

Sequential Write IOPS,100%顺序写负载情况下的IOPS。

IOPS的测试benchmark工具主要有Iometer, IoZone, FIO等,可以综合用于测试磁盘在不同情形下的IOPS。对于应用系统,需要首先确定数据的负载特征,然后选择合理的IOPS指标进行测量和对比分析,据此选择合适的存储介质和软件系统。

2. IOPS计算

理论上可以计算出磁盘的最大IOPS,即IOPS = 1000 ms/ (Tseek + Troatation),忽略数据传输时间。假设磁盘平均物理寻道时间为3ms, 磁盘转速为7200,10K,15K rpm,则磁盘IOPS理论最大值分别为,

IOPS = 1000 / (3 + 60000/7200/2) = 140

IOPS = 1000 / (3 + 60000/10000/2) = 167

IOPS = 1000 / (3 + 60000/15000/2) = 200

3. 案例

需求:20TB存储空间同时满足4500 IOPS+RAID 5,我应该如何计算?RAID 5或者RAID 1/0的时候分别需要多少块硬盘?

首先需要知道I/O中读操作(Read)与写操作(Write)所占的百分比。然后通过下列公式,将主机的IOPS需求转换成硬盘实际IOPS负载:

假定4500 IOPS中读/写比是2:1,则不同RAID类型Drive IOPS要求分别如下:

RAID 1/0: (2/3)*4500 + 2*(1/3)*4500=6000IOPS

RAID 5: (2/3)*4500 + 4*(1/3)*4500=9000IOPS

RAID 6: (2/3)*4500 + 6*(1/3)*4500=12000IOPS

再参照下表中不同类型硬盘单块IOPS参数,得出需要多少块硬盘:

假定选用FC 15K RPM硬盘,则:

RAID 1/0: 6000/180=34块

RAID 5: 9000/180=50块

RAID 6: 12000/180=67块

注:实际情况下还需考虑Vault Drivers (共5块)以及Hot Spares (建议每30块硬盘一个)。

最后,如果选用600GB FC硬盘来实现20TB可用空间,则RAID 1/0需要78块,RAID 5需要42块。

【编辑推荐】

【责任编辑:赵宁宁 TEL:(010)68476606】

点赞 0

mysql单库tps_MySQL数据库三个关键性能指标--TPS\QPS\IOPS相关推荐

  1. MySQL性能指标TPS+QPS+IOPS压测

    1.前言 今天主要介绍MySQL数据库,或者说所有数据库的三个关键性能指标TPS\QPS\IOPS 2.性能指标概览 QPS(Queries Per Second): 就是每秒的查询数,对数据库而言就 ...

  2. mysql 性能 数据 指标_MySQL数据库:三个关键性能指标

    今天主要介绍MySQL数据库,或者说所有数据库的三个关键性能指标: qps 每秒处理的查询数 tps 每秒处理的事务数 IOPS 每秒磁盘进行的I/O操作次数 一.TPS(适用innodb) 1. 概 ...

  3. 清空MySQL单库下所有表数据 || 删除MySQL单库下所有表

    一.清空MySQL单库下所有表数据 -- 清空MySQL单库下所有表数据 SELECT CONCAT('truncate table ',TABLE_NAME,';') AS PLEASE_EXEC_ ...

  4. mysql单台跨数据库查询_在MySQL中怎样进行跨库查询?

    在MySQL中跨库查询主要分为两种情况,一种是同服务的跨库查询:另一种是不同服务的跨库查询:它们进行跨库查询是不同的,下面就具体介绍这两种跨库查询. 一.同服务的跨库查询 同服务的跨库查询只需要在关联 ...

  5. 易语言外部数据库MySQL支持库Access数据库Sqlite数据应用

    语言虽然有自己的数据库, 但易数据库只是以简单的.类似表格的形式组织数据信息,是一个小型数据库管理系统.有时编程中必须使用其它数据库.易语言支持以ODBC方式和ADO方式操作外部数据库. 一.ODBC ...

  6. java mysql单库多表_第69节:Java中数据库的多表操作

    第69节:Java中数据库的多表操作 前言 学习数据库的多表操作,去电商行业做项目吧!!! 达叔,理工男,简书作者&全栈工程师,感性理性兼备的写作者,个人独立开发者,我相信你也可以!阅读他的文 ...

  7. mysql 从库_mysql数据库主从配置

    在一篇文章<离线安装mysql数据库>,讲解了离线安装mysql数据库的过程,本文将讲解mysql数据库的主从配置方法.mysql数据库进行主从配置后,可以实现数据库的备份.同时应用也可以 ...

  8. mysql 控制函数库_数据库开发——MySQL——函数与流程控制

    一.函数 1.介绍 1.1.数学函数 ROUND(x,y) 返回参数x的四舍五入的有y位小数的值 RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定 ...

  9. mysql单实例多数据库_Mysql单实例数据库的安装

    一.硬件环境: Dell PowerEdge R710 Inter E5620 2.4GHz 3*300GB SAS热插拔硬盘 4GB*8 内存 二.软件环境 Centos 5.8 三.安装mysql ...

最新文章

  1. liunx 下dhcp中继及服务器配置
  2. 刻意练习:LeetCode实战 -- Task07. 合并两个有序链表
  3. 傅里叶,请再帮我们一次吧....
  4. Micron Flash芯片识别心得
  5. Ubuntu下设置电信拨号上网(10.04版)
  6. tkinter窗口居中方法
  7. 卡尔曼滤波器学习笔记(一)
  8. ssh登录 The authenticity of host 192.168.0.xxx can't be established. 的问题
  9. 如何制作统计报表(盈帆报表: efreprt.com)
  10. 第四十七题 UVA437 巴比伦塔 The Tower of Babylon
  11. PHP 调用金山词霸API获取音标和音频
  12. excel文件导出进度条的实现
  13. kdj指标主要看哪个值_终于有人把KDJ指标讲通透了,简单实用,建议收藏
  14. 如何在 Win7 下一键清空剪贴板
  15. CodeBlock输出汉字为乱码的解决方法
  16. FLTK Debian 安装中make报错 X11 libraries No package ‘xft‘ found No package ‘freetype2‘ found
  17. TCP/IP卷一:49---ICMP之(与ICMP相关的攻击)
  18. jQuery.fn的作用是什么
  19. linux命令:at 命令
  20. wpf使某个控件失去焦点_WPF的TextBox的焦点获取与失去焦点的死循环解决方案

热门文章

  1. 5道Python函数练习
  2. python多值参数函数介绍,数字累加例子
  3. Python骚操作:动态定义函数
  4. Python中按值来获取指定键的两种方法
  5. php大号字体代码,支持中文字母数字、自定义字体php验证码代码
  6. ubuntu如何禁用更新?
  7. word怎么设置图片编号(图片下标,图片标签,图片序号,图片注释,题注)(交叉引用)
  8. tensorflow教程 开发者指南——评估器 estimator(tensorflow官方推荐使用的编程API)
  9. yolo 标注转VOC格式(标注转换器)
  10. PAT甲级题目翻译+答案 AcWing(基础算法与数据结构)