返回顶部
首页 > 资讯 > 数据库 >MySQL如何测试
  • 606
分享到

MySQL如何测试

2024-04-02 19:04:59 606人浏览 安东尼
摘要

这篇文章主要介绍Mysql如何测试,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言:基准测试benchmark:基本技能,是针对系统设计的一种压力测试,是唯一方便有效、可学习系统在

这篇文章主要介绍Mysql如何测试,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

前言:

基准测试benchmark:基本技能,是针对系统设计的一种压力测试,是唯一方便有效、可学习系统在给定的工作负载下回发生什么 的方法,他可以观察系统在不同压力下的行为,评估系统的容量,掌握哪些是重要的变化,或观察系统如何处理不同的数据,可在系统实际负载外创建虚拟场景进行测试(掌握系统行为)

正文:

如前言,基准测试很、重、要!可以完成的工作: 总的来说:测试硬件、预估硬件、验证系统、测压力、调配置

1、验证基于系统的假设,确认假设是否符合实际情况;2、重现系统中某些异常行为,以解决;3、测试系统当前的运行情况,利用历史结果分析诊断无法预测的问题; 4、模拟更高的负载找出系统随压力增加而可能遇到的扩展性瓶颈;5、规划未来的业务增长,硬件、网络容量、相关资源;6、测试应用适应可变环境的能力;7、测试不同的硬件、软件和操作系统配置,证明设备是否配置正确;

数据库的基准测试的作用,就是分析在当前的配置下(包括硬件配置、OS、数据库设置等),数据库的性能表现,从而找出mysql的性能阈值,并根据实际系统的要求调整配置。【源】

与真实压力不同:真实的复杂多变;基准测试要求尽可能快执行完成,简单直接、结果易比较、成本低易行

2.2策略

针对系统整体:集成式full-stack

单独测试Mysql:单组件式single-component

推荐整体测试:要正确设置

1、用户关注的是整体的性能;2、MySQL并非总是瓶颈;3、更能揭示应用的真实表现

推荐单独测试:需要数据

1、需比较不同schema或查询的性能;2、针对某个具体问题的测试;3、避免漫长,做短期、快速周期循环

2.2.1指标

目标:细化为一系列问题,具体问题具体分析

吞吐量:

单位时间内事务处理数,TPC-C、多用户交互式应用,每秒事务数,每分钟事务数

响应时间或延迟

测试任务所需的整体时间,平均响时、最小响时、最大和所占百分比;借助图表

并发性:

测试应用在不同并发下的性能,关注正在工作中的并发操作、同时工作中的线程数 连接数;

WEB服务器并发性!=数据库的,仅表会话存储机制数据处理能力;测web并发 任意时间有多少并发;

可扩展性

可扩展性:给系统增加一倍工作,理性情况下能获得两部的结果;给系统增一倍资源可或2倍吞吐量

系统业务压力可能发生变化:测可扩展性非常必要;该指标对容量规范有用:提供信息来发现应用瓶颈

尽可能收集测试需求,基于需求设计测试,忌只关注部分指标,而忽略其他指标

2.3方法

要尽可能接近真实应用的情况:

使用全集、数据分布特点、真实分布参数、是否多用户、匹配用户行为、多类型、检查错误日志、系统预热:重启后多长时间才达到正常性能容量、持续一定时间;

2.3.1设计、规范

提出问题、目标明确

    标准的基准测试:合适的方案 TPC-H OLTP

    专用的测试:复杂、迭代,获易还原的生产数据集快照

计划: 参数、结果文档化、测试详细记录

2.3.2时间

基准测试应运行足够长的时间,无法确认时间可一直运行,持续观察知道确认系统已稳定

一个简单的测试规则:等系统看起来稳定的时间至少=系统预热的时间

2.3.3获取系统性能和状态

尽量多地收集被测系统的信息

best建目录、每执行一轮测试创建单独子目录,将结果、配置文件、测试指标、脚本和其他相关说明保存其中

需要记录是数据:

系统状态、性能指标:CPU使用率  、磁盘I/O、网络流量统计、SHOWGLOBAL STATUS计数器

合理的间隔,记录开始时间、利用时间戳、只是收集就好

2.3.4获取准确的结果

回答些问题:

是否选择了正确的基准测试?是否为问题收集了数据?预热时间是否足够长?

是否采用了错误的测试标准:io密集型引用采用CPU密集型测试标准来评估性能?

测试结果是否可重复?重测前确保系统状态一致;对症测

影响因素:

外部压力、性能分析、监控系统、详细日志、周期性作业

注意:

过程中所需资源是专来测试的;测试中尽量少修改参数、通过迭代逐步修改基准测试的参数;认真研究过程中的异常情况并找到原因

2.3.5运行测试分析结果

自动化:减少人为失误,Makefile文件、脚本

测试结果满足目前需求,简单运行几轮测试,看看结果就OK了,如结果变化很大,可多运行几次、或更长时间

结果:

     分析,将数字变成知识,最终的目的是回答在设计时的问题

如何抽象有意义的结果,依赖于如何收集数据,写脚本分析数据、减少人为失误、工作量、可重复、文档化

2.3.6绘图重要性

一张图胜过千言万语嘛,本来有些知识点宝宝是想画导图的,但是么有画

书中有这么一个语句,分享一下:SHOW FULL PROCESSLIST    SHOW PROCESSLIST显示哪些线程正在运行,您也可以使用mysqladmin processlist语句得到此信息,如果您有SUPER权限,您可以看到所有线程,否则,您只能看到您自己的线程,不使用FULL关键词,则只显示每个查询的前100个字符【源】

2.4基准测试工具

集成测试工具:整个应用

1、ab是Apache Http,每秒最多可处理多少请求【参考】【2】

2、http_load:ab类似更灵活,被设计为对web服务器测试,通过一个输入文件提供多个URL,随机选择进行测试,也可定制,使其按照时间比率进行测试【参考】

3、jmeter,java程序,可加载其他应用并测试其性能,这个听不错的,上面两个没有接触过,不评论

单组件式:测MySQL,基于MySQL的系统性能

1、mysqlslap:mysql5.1后自带,模拟服务器的负载,输出计时信息,可执行并发连接数、指定sql语句,否则自动生成select语句【参考】

2、MySQL Benchmark Suite(sql-bench):自带、5.7拿掉,基准测试套件,用于不同数据库服务器上进行比较测试,单线程串行执行,测执行查询的速度;包含了大量预定义测试,易使用,轻松比较不同引擎或配置的性能测试,CPU密集型的,结果会显示哪些类型的操作在服务器上执行更快,缺点:测试数据集小且无法用指定的数据,需要perl BDB支持;【参考】

3、Super SMack:MySQL、postgresql,提供压力测试和负载均衡,复杂而强大的工具,可模拟多用户访问,加载测试数据到库、随机数据填充测试表【参考】

4、Database Test Suite:类似某些工业标准测试的工具集,免费TPC-C OLTP测试工具

5、sysbench:多线程系统压测,据影响数据库服务器性能的因素评估系统的性能,全能测试工具,支持MySQL、操作系统、硬件的硬件测试【参考】【2】

MySQL的BENCHMARK()函数:测试特定操作的执行速度,参数可以是需要执行的次数或表达式(任何标量表达式)

2.5案例

此处省略n字

2.6总结

终于等到你~音乐起;建议至少要熟悉sysbench,如何使用oltp(比较不同系统性能) 和fileio 测试;经常执行基准测试,制定一些原则很必要,选择合适的测试工具、建立脚本库,收集信息分析结果,熟练一种绘图工具;

以上是“MySQL如何测试”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL如何测试

本文链接: https://lsjlt.com/news/54576.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL如何测试
    这篇文章主要介绍MySQL如何测试,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言:基准测试benchmark:基本技能,是针对系统设计的一种压力测试,是唯一方便有效、可学习系统在...
    99+
    2024-04-02
  • mysql如何测试shell
    这篇文章主要介绍了mysql如何测试shell,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 a=0echo ...
    99+
    2024-04-02
  • 如何测试测试用例?
    编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天编程网就整理分享《如何测试测试用例?》,文章讲解的...
    99+
    2024-04-05
  • 如何测试mysql安装成功
    要测试 mysql 安装是否成功,请执行以下步骤:检查服务状态(mysql -u root -p)创建测试数据库(create database testdb;)选择测试数据库(use ...
    99+
    2024-06-14
    mysql
  • MySQL测试
    MySQL 数据库系统 MySQL 特点:多进程多用户高性能高可靠易用性 MySQL AB --> SUN --> Oracle MySQL --> MariaDB 关系型数据库 RDBM...
    99+
    2024-04-02
  • 如何使用sysbench测试Mysql性能
    这篇文章主要介绍了如何使用sysbench测试Mysql性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 s...
    99+
    2024-04-02
  • mysql数据库如何测试数据
    要测试MySQL数据库中的数据,可以使用以下方法:1. 使用SQL查询语句来检索特定表中的数据。可以使用SELECT语句来选...
    99+
    2023-09-20
    mysql数据库
  • mysql双机热备份如何测试
    要测试MySQL双机热备份的可靠性和稳定性,可以按照以下步骤进行测试: 首先确保双机热备份已经正确配置和运行,包括主服务器和备服...
    99+
    2024-04-09
    mysql
  • mysql测试表
    mysql> CREATE PROCEDURE pro_testdata(IN inr int)    ->   BEGIN    -> ...
    99+
    2024-04-02
  • 如何搭建MySQL Group Replication测试环境
    这篇文章给大家分享的是有关如何搭建MySQL Group Replication测试环境的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。    最近看了下My...
    99+
    2024-04-02
  • 如何解析mysql pump的性能测试
    如何解析mysql pump的性能测试,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。   在MySQL 5.7中做逻辑备份恢...
    99+
    2024-04-02
  • 如何进行MySQL并行复制测试
    今天就跟大家聊聊有关如何进行MySQL并行复制测试,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。    对于主从延迟,其实一...
    99+
    2024-04-02
  • 如何进行MySQL构造测试数据
    这篇文章给大家介绍如何进行MySQL构造测试数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 构造测试数据(笛卡尔积,6 次100 万)create ta...
    99+
    2024-04-02
  • 手工测试如何转自动化测试
    我接触了太多测试同行,由于多数同行之前一直做手工测试,现在很迫切希望做自动化测试,其中不乏工作5年以上的同行。 我 从事软件自动化测试已经数年了,接触过底层服务端、API 、Web、APP、H5 等等,对自动化算是比较了...
    99+
    2023-06-02
  • 工具 | 如何对 MySQL 进行 TPC-C 测试?
    作者:丁源 RadonDB 测试负责人 负责 RadonDB 云数据库、容器化数据库的质量性能测试,迭代验证。对包括云数据库以及容器化数据库性能和高可用方案有深入研究。 |背景 根据 DWorks 2020 年发布的《中国自研数据库登...
    99+
    2015-03-18
    工具 | 如何对 MySQL 进行 TPC-C 测试?
  • MySQL中如何使用压力测试工具
    这篇文章主要为大家展示了MySQL中如何使用压力测试工具,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。一、MySQL自带的压力测试工具——Mysqlslapm...
    99+
    2024-04-02
  • MySQL如何使用sysbench做OLTP基准测试
    这篇文章给大家分享的是有关MySQL如何使用sysbench做OLTP基准测试的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 一、 安装① 下载源码...
    99+
    2024-04-02
  • 如何测试 MySQL SSL 连接的可靠性
    如何测试 MySQL SSL 连接的可靠性概述:MySQL 是一个流行的关系型数据库管理系统,常用于存储和管理大量数据。为了保护敏感信息的安全性,MySQL 提供了 SSL 连接的功能,通过加密通信来传输数据。然而,如何确保 MySQL S...
    99+
    2023-10-22
    MySQL ssl 可靠性
  • MySQL中如何自动生成测试数据
    MySQL中可以通过以下几种方法来自动生成测试数据: 使用INSERT INTO语句插入数据:可以编写INSERT INTO语句来...
    99+
    2024-04-30
    MySQL
  • 【测试开发】Mq消息重复如何测试?
    本篇文章主要讲述重复消费的原因,以及如何去测试这个场景,最后也会告诉大家,目前互联网项目关于如何避免重复消费的解决方案。 Mq为什么会有重复消费的问题 Mq 常见的缺点之一就是消息重复消费问题,产生这种问题的原因是什么呢?有以下几点: 工...
    99+
    2023-09-15
    php 开发语言 自动化测试 软件测试 功能测试 程序人生 职场发展
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作