性能容量关键指标:

每秒tps,峰值tps

基础数据量,日均增长数据量

最大连接数

内存分配

IOPS

重点关注指标:

业务指标:

每秒并发用户请求、每秒订单数、用户请求响应时长

折算成性能指标:

qps、tps、rt

提出测试预期目标:

根据性能指标制定测试方案

测试结果尽可能以这些指标来表达

业务预期指标解读

读写比例:读多写少、读少写多、读写相当、统计为主、纯写入为主

存盘模式(数据可靠性要求):实时、异步、不关注

用户端的语言、字符编码(latin1、utf8、utf8mb4)

数据恢复实时性要求

日新增数据量

数据库连接方式

历史数据归档方式

业务平均、峰值指标

业务目标评估要点

服务器配置

存储引擎选择

数据库高可用方案

数据可用性方案

数据库备份方案

相应优化方案:

CPU,更换更好、更多核心的CPU

I/O,更换IOPS性能更高的设备,例如SSD,PCIE SSD

内存,增加内存,合理分配

MySQL,升级版本

选择InnoDB引擎,并且设计合适的表结构,避免锁竞争

建立性能基线

某个运行时刻的状态记录、快照

中位线 or 均线

用于和未来的状态进行对比

未来时刻产生关键事件后的新状态,作为下一个基线

https://github.com/zhishutech/mysqldba/tree/master/mysql-snapshot

系统性能指标:

CPU、内存、I/O

MySQL性能指标:

tps、qps、DMLs、响应时长、内存利用率、锁等待

业务指标

每秒业务量、每次交易时长

采集工具:

top、free、vmstat、sar、iostat、dstat、nmon、oradba.pl等

CPU:%user、%idle、%sys、%iowait

%user (<10%)、%idle (>80%)、%sys (<5%)、%iowait (<10%)

IO:tps/iops、await、svctm、%util

tps/iops (越大越好)、await (<5~10)、svctm (<5)、%util (<50%)

内存:free (free、buffers、cached)、used,以及swap

used非常高,但cached非常低,要引起关注了,可能发生内存泄漏

MySQL

tps越大越好、rt越小越好、lock越少越好、hit ratio越高越好、waits越少越好

table_locks_wait,innodb_log_waits,innodb_buffer_pool_wait_free大于0说明负载很大

压力测试

基准压力测试目的:

采购新设备,评估新设备性能

开发新项目,评估数据库容量

新系统上线前,预估/模拟数据库负载

更换数据库版本,评估性能变化

设计测试模型要点:

明确测试的核心目标、诉求

排除干扰,专注测试目的

确定测试环境

确定测试过程中的衡量和变量

保证测试结果的可重复性

设计压测模型注意事项:

只在本地加压

压测数据量小

压测时间过短

压测模式太少

压力负载过大或过小

每轮测试完毕要净化环境

MySQL数据预热:

5.6以前,执行一次mysqldump,或全量select

5.6以后,buffer bool dump & restore

常用压测工具介绍:

tpcc-mysql、sysbench、fio

测试方法,结果解读:

MySQL压力测试基准值

测试结果模板

测试报告编写

压测client、server分开

压测数据量、时长、并发量过大过小都不合适

压测结果除了TPS/TPmC,也要关注性能数据

利用压测发现性能瓶颈因素

系统性能瓶颈大概率发生在磁盘I/O层

相应的优化措施,大多数靠加索引

MySQL容量规划和性能测试的更多相关文章

  1. 二 mysql容量规划,性能测试

    何为基线- 当前运行状态记录.快照- 用于和未来的状态进行对比- 未来时刻产生关键事件后的新状态,作为下一个基线基线数据收集,关注哪些要点- 系统负载- MySQL运行状态- 相应的业务指标1.系统& ...

  2. MySQL容量规划之tcpcopy应用之道

    官方文档:https://github.com/session-replay-tools/mysql-replay-module tcpcopy可以将正式环境上来自客户端的请求复制一份到测试端并复现, ...

  3. MongoDB的容量规划及硬件配置

    mongo是基于内存的数据库,应尽量将工作集中的数据全部加载到内存中,即内存应大于工作集 本文译自Chad Tindel的英文博客: http://www.mongodb.com/blog/post/ ...

  4. MySQL/MariaDB数据库的性能测试

      MySQL/MariaDB数据库的性能测试 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数据库服务衡量指标 qps: query per second(每秒支持多少查询 ...

  5. web容量规划

    容量和性能   容量规划是基于当前性能判断系统需要什么及什么时候需要,它既是资本支出合理化证明过程也是一个技术变更;   性能调优是优化已存在的系统性能;   一般服务的升级步骤是:性能调优 -> ...

  6. 新上线MySQL数据库规划

    新上线MySQL数据库规划1.删除test库2.删除root用户或者让root用户只可在本机登陆而对于有业务访问的数据库,在做删除root用户前需要依次确认 function.procedure.ev ...

  7. Hbase集群类型|集群配置|服务器选型|磁盘容量规划

    HBase和Hadoop的集群类型 1.单机模式 主要用于开发工作,一台机器上运行所有的守护进程,或者一台机器运行多个虚拟机.一般用于评估和测试. 2.小型集群 20台机器以内的集群,不同的机器运行不 ...

  8. Elasticsearch集群规模和容量规划的底层逻辑

    转载自: https://mp.weixin.qq.com/s?__biz=MzI2NDY1MTA3OQ==&mid=2247484628&idx=1&sn=666e416ae ...

  9. mysql 5.7.15 vs mysql 5.6.31性能测试以及不同linux内核性能比较

    最近,将部分开发和测试环境的mysql升级到5.7之后,今天抽时间测试了下5.6和5.7 PK查询的性能,使用mysqlslap进行测试,测试结果发现在低配下,percona 5.6.31大约比5.7 ...

随机推荐

  1. ubuntu之路——day2

    一:sougou输入法安装 详情参考:https://blog.csdn.net/xin17863935225/article/details/82285177 注意切换成fcitx架构 因为linu ...

  2. [转]Myeclipse之web项目的部署(发布)流程

    在myeclipse下新建web工程abc.系统设置默认如下: 项目保存位置:workspace目录\abc Source文件夹:src,保存所有的java类文件(.java文件)和xml文件. We ...

  3. iview3 版本 升级

    Button 废弃 type ghost,原先的 default 样式有改变. Icon 的图标升级至 ionicons 3.0 图标,图标名称有改变. Breadcrumb 废弃 href 属性. ...

  4. 似然函数 | 最大似然估计 | likelihood | maximum likelihood estimation | R代码

    学贝叶斯方法时绕不过去的一个问题,现在系统地总结一下. 之前过于纠结字眼,似然和概率到底有什么区别?以及这一个奇妙的对等关系(其实连续才是f,离散就是p). 似然函数 | 似然值 wiki:在数理统计 ...

  5. AI学习网址记录

    https://ai.yanxishe.com/ https://ai.yanxishe.com/page/blogDetail/14365 GAN网络 对抗式生成网络-图像超分辨及图像修复 完全可见 ...

  6. Flutter Container容器组件、Text文本组件详解

    import 'package:flutter/material.dart'; void main(){ runApp(MyApp()); } class MyApp extends Stateles ...

  7. vue模块化以及封装Storage组件实现保存搜索的历史记录

    <template> <div id="app"> <input type="text" v-model='todo' @keyd ...

  8. Dart泛型

    /* 通俗理解:泛型就是解决 类 接口 方法的复用性.以及对不特定数据类型的支持(类型校验) */ //只能返回string类型的数据 // String getData(String value){ ...

  9. 深入学习c++--智能指针(四)--使用建议

    1. 不要自己手动管理资源 2. 一个裸指针不要用两个shared_ptr管理,unique_ptr 3. 使用shared_ptr作为函数的接口,如果有可能用 const shared_ptr&am ...

  10. docker容器中解决出现:^H^H^H^H

    docker容器中解决出现:^H^H^H^H 环境:docker容器是debain系统 解决: 把stty erase ^H 添加到.bash_profile中 vim /etc/profile st ...