华为云云耀云服务器L实例评测|使用sysbench对云耀云服务器mysql的性能测试

news2025/7/15 15:57:02

目录

引言

1 在centos上安装mysql

1.1 在云服务器上安装 Docker

1.2 在 Docker 中运行 MySQL 容器

2 安装sysbench并进行性能测试

2.1 安装和配置 sysbench

2.2 运行 sysbench 性能测试

3  分析测试结果

3.1 运行结果

3.2 对运行结果进行翻译

3.3 性能分析

4  清理测试

结论


引言

华为云服务器提供超高性价比的云计算资源,让你以超低门槛快速构建和扩展你的应用。拥有多种实例规格,从性能到成本的平衡得以轻松实现。

本文将使用一款高性价比的 22GB 内存、3MB 缓存的华为云服务器上的 CentOS 操作系统,来展示如何使用 sysbench 工具对 MySQL 数据库的性能进行测试。这样,你可以充分利用这一强大的计算平台,以确保你的应用在高性能要求下仍能如期运行。

1 centos上安装mysql

1.1 在云服务器上安装 Docker

首先,确保你的华为云云耀云服务器L实例上已安装 Docker。你可以按照 Docker 官方文档或云服务提供商的指南来完成 Docker 的安装。

1.2  Docker 中运行 MySQL 容器

首先查看镜像

docker search mysql5.7

下载镜像

docker pull docker.io/bingozhou/mysql5.7

耐心等待几分钟,就会出现下载成功的提示。

Using default tag: latest

Trying to pull repository docker.io/bingozhou/mysql5.7 ...

latest: Pulling from docker.io/bingozhou/mysql5.7

9f0706ba7422: Pull complete

2290e155d2d0: Pull complete

547981b8269f: Pull complete

2c9d42ed2f48: Pull complete

55e3122f1297: Pull complete

abc10bd84060: Pull complete

c0a5ce64f2b0: Pull complete

c4595eab8e90: Pull complete

098988cead35: Pull complete

300ca5fa5eea: Pull complete

43fdc4e3e690: Pull complete

dcc4404efef3: Pull complete

a2771f3f3276: Pull complete

Digest: sha256:bc3bcd6b0edd018c997085d3082f99fff48e248a51d4459fd005f3c416798a7c

Status: Downloaded newer image for docker.io/bingozhou/mysql5.7:latest

使用以下命令从 Docker Hub 下载 MySQL 镜像并在容器中运行

 docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d docker.io/bingozhou/mysql5.7

这会启动一个 MySQL 容器,使用指定的 root 密码。我这里直接设置了一个简单的密码123456,如果想要设置其他密码,替换123456即可。

1.3连接到 MySQL 容器

首先需要在华为云服务器的安全组设置中,对入站规则进行配置,放开3306端口的访问。

找一台上网的笔记本,使用navicat连接mysql数据库,输入服务器ip,以及之前设置的 root 密码以连接到 MySQL 容器。

1.4 准备测试数据库

MySQL 容器内部,创建一个用于性能测试的数据库和表。以下是一个示例:

CREATE DATABASE sysbenchdb;

USE sysbenchdb;

CREATE TABLE sbtest (

    id INT AUTO_INCREMENT PRIMARY KEY,

    k INT,

    c CHAR(120),

    pad CHAR(60)

);

这组SQL语句的作用是在数据库中创建名为 "sysbenchdb" 的新数据库,然后切换到这个新创建的数据库。接下来,在 "sysbenchdb" 数据库内创建一个名为 "sbtest" 的表,该表包括一个自增的整数主键 "id",一个整数字段 "k",一个长度为 120 字符的字符型字段 "c",以及一个长度为 60 字符的字符型字段 "pad"。这个表通常用于性能测试和基准测试,用于模拟和评估数据库在处理大量数据时的性能表现。

2 安装sysbench并进行性能测试

2.1 安装和配置 sysbench

在云服务器上安装 sysbench 工具。使用以下命令:

sudo yum install sysbench

出现

说明sysbench安装成功。

2.2 运行 sysbench 性能测试

在云服务器上运行 sysbench MySQL 进行性能测试。以下是一个示例命令:

sysbench oltp_read_write --db-driver=mysql --mysql-host=127.0.0.1 --mysql-user=root --mysql-password=123456 --mysql-db=sysbenchdb --tables=1 --table-size=1000000 prepare

上面的命令利用 sysbench 工具与本地 MySQL 数据库建立连接,创建一个名为 "sysbenchdb" 的数据库,其中包含一张拥有 1,000,000 行数据的测试表。这个操作旨在为之后的性能测试提供必要的测试数据环境。通过准备这些数据,我们可以模拟真实负载条件,对数据库性能进行评估,以确保它在处理大量读写操作时的表现。这有助于验证数据库的稳定性和性能,以满足实际应用程序的需求。

sysbench oltp_read_write --db-driver=mysql --mysql-host=127.0.0.1 --mysql-user=root --mysql-password=123456 --mysql-db=sysbenchdb --tables=1 --table-size=1000000 --threads=8 --time=60 run

上面的命令使用 sysbench 工具,在连接到本地 MySQL 数据库的情况下,执行一个 OLTP(联机事务处理)读写性能测试。在测试过程中,将使用 8 个线程模拟并发访问,执行各种读写操作,包括事务处理。测试的时间持续为 60 秒。这允许我们评估数据库的性能和响应时间,以便在高负载情况下确定其是否能够满足应用程序的需求,以及性能是否符合预期。这个测试有助于发现潜在的性能瓶颈,进一步进行优化或扩展数据库。

3  分析测试结果

命令运行之后,稍等一会儿,就会出现测试的结果,如下所示。

3.1 运行结果

3.2 对运行结果进行翻译

SQL 统计信息:

已执行的查询:

读操作:445,466

写操作:127,263

其他操作:63,634

总共:636,363

事务数:31,815(每秒 530.12 次)

查询数:636,363(每秒 10,603.53 次)

忽略的错误:4 个(每秒 0.07 个)

重新连接次数:0 次(每秒 0.00 次)

一般性能统计:

总共耗时:60.0128

总事件数:31,815

延迟(毫秒):

最小延迟:5.00 毫秒

平均延迟:15.09 毫秒

最大延迟:485.43 毫秒

95th 分位数延迟:20.37 毫秒

总延迟:479,974.06 毫秒

线程公平性:

事件数(平均/标准偏差):3976.8750/18.70

执行时间(平均/标准偏差):59.9968/0.00

3.3 性能分析

在这次 MySQL 性能测试中,共执行了 636,363 条查询,每秒执行了约 10,603 条查询。其中,读操作占大多数(445,466 次),而写操作也相当频繁(127,263 次),而其他类型的操作则较少(63,634 次)。

总共执行了 31,815 个事务,平均每秒执行了约 530.12 个事务。这意味着数据库能够在较高的并发负载下维持相对较高的事务处理性能。

查询的平均延迟为 15.09 毫秒,最大延迟为 485.43 毫秒。延迟在大多数情况下相对较低,而 95th 分位数的延迟在 20.37 毫秒左右,这意味着大多数查询在较短的时间内完成。

性能测试结果表明,MySQL 数据库在这次测试中表现出了良好的性能,具有较高的吞吐量和较低的延迟。这对于支持高负载的应用程序非常重要。同时,线程公平性的标准偏差相对较低,表示性能测试在各个线程之间的分布较为均匀。

请注意,性能测试结果的解释和评估可能因具体应用场景和性能需求而异。这些结果可以帮助你了解数据库的性能表现,从而采取进一步的优化措施,以确保数据库在高负载条件下稳定运行。

4  清理测试

在测试完成后,可以使用以下命令清理测试数据:

sysbench oltp_read_write --db-driver=mysql --mysql-host=127.0.0.1 --mysql-user=root --mysql-password=123456 --mysql-db=sysbenchdb --tables=1 --table-size=1000000 cleanup

这个命令的目的是删除在性能测试中创建的测试数据,以便你可以在下一次测试之前清除旧数据,保持测试环境的干净和一致性。这对于多次测试非常重要,以避免旧数据对新测试结果产生干扰。

结论

通过遵循上述步骤,你可以在云服务器上使用 Docker 安装 MySQL 并使用 sysbench 进行性能测试。测试的实际执行过程中,只需要相应地替换密码和容器 IP 地址,以匹配你的实际配置。此外,根据你的性能测试需求,你可以轻松地修改 sysbench 测试的参数和配置,以满足不同负载和性能场景的要求。这个过程能够帮助你全面评估 MySQL 数据库的性能,以确保它满足你的应用程序的性能需求。无论是进行性能调优还是测试新应用的性能,这个方法都为你提供了有力的工具。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1102887.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AIGC - 入门向量空间模型

文章目录 向量和向量空间向量的运算什么是向量空间?向量空间的几个重要概念向量之间的距离曼哈顿距离(Manhattan Distance)欧氏距离(Euclidean Distance)切比雪夫距离(Chebyshev Distance) 向量…

qml加载ttf字体库

1,下载获取ttf文件 iconfont-阿里巴巴矢量图标库 字体图标下载 - FontAwesome 字体图标中文Icon 2,添加到项目文件 3,项目添加字体库 #include <QGuiApplication> #include <QQmlApplicationEngine> #include <QFontDatabase> #include <QDebug>in…

Error: GlobalConfigUtils setMetaData Fail Cause:java.lang.NullPointerException

文章目录 1、在开发中会出现这样的错误。2、其次&#xff0c;再看其他错误&#xff1a; 1、在开发中会出现这样的错误。 完整错误&#xff1a;Caused by: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: GlobalConfigUtils setMetaData Fail ! Cause…

白银现货K线走势图分析

K线图又称蜡烛图、阴阳烛&#xff0c;这一理论起源于日本&#xff0c;是最古老的技术分析方法。在众多的现货白银技术分析方法中&#xff0c;K线分析是核心和根本&#xff0c;因为很多的技术分析方法的分析要素和计算方式&#xff0c;都是来自K线中的四个价格。 面对同样一张的…

C++进阶篇1---继承

一、继承的概念和定义 1.1概念 继承机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保持原有类特性的基础上进行扩展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c;称为派生类。继承呈现了面向对象程序设计的层次结构&#xff…

Leetcode刷题详解——长度最小的子数组

1. 题目链接&#xff1a;209. 长度最小的子数组 2. 题目描述&#xff1a; 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度**。**如果不…

OpenHarmony页面级UI状态存储:LocalStorage

LocalStorage 是页面级的 UI 状态存储&#xff0c;通过 Entry 装饰器接收的参数可以在页面内共享同一个 LocalStorage 实例。LocalStorage 也可以在 UIAbility 内&#xff0c;页面间共享状态。 本文仅介绍 LocalStorage 使用场景和相关的装饰器&#xff1a;LocalStorageProp 和…

Qt系列-常用控件使用整理

1、QMainWindow介绍 菜单栏最多只有一个 //菜单栏创建 菜单栏最多只能有一个QMenuBar*bar menuBar();//将菜单栏放入到窗口中setMenuBar(bar);//创键菜单QMenu*fileMenubar->addMenu("文件");QMenu*editMenubar->addMenu("编辑");//创建菜单项QActi…

apk和小程序渗透

apk和小程序域服务器通信使用的还是http协议&#xff0c;只是使用了加密。只要可以获取到http的请求报文&#xff0c;就可以回归到web渗透的层面。apk和小程序的渗透很复杂&#xff0c;涉及逆向时要进行脱壳&#xff0c;脱壳后反编译了&#xff0c;源代码没做加密就能直接逆向出…

基于springboot实现家具网站设计与实现平台项目【项目源码+论文说明】计算机毕业设计

摘要 随着移动互联网技术的深入发展&#xff0c;电子商务也不断的完善&#xff0c;线上销售额不断提高&#xff0c;网络消费成为人民日常生活的一部分。并且随着电子商务的发展&#xff0c;也呈现出多元化方向&#xff0c;各种农村电商、生鲜电商、家具电商等&#xff0c;带动…

Location的匹配

nginx的正则表达式: ^:字符串的起始位置 $:字符窜的结束位置 *:匹配所有 :匹配前面的字符一次或者多次 ?:匹配前面的字符0次或者1次 .:任意单个字符 {n}:连续重复出现n次。 {n,m}:连续重复出现n-m次 [a-Z0-9A-Z] [C]:匹配单个字符c ():分组 |:或 一 Location的分类&#xff1a…

笔试强训day01

文章目录 易错点1、字符串格式打印%m.ns\n&#xff08;m&#xff0c;n为整数&#xff09;易错点2、指针的理解易错点3、编程题&#xff1a;组队竞赛 易错点1、字符串格式打印%m.ns\n&#xff08;m&#xff0c;n为整数&#xff09; 正确答案&#xff1a;B。 #include<iostre…

小程序如何设置配送方式

配送方式是一个非常重要的功能&#xff0c;它直接关系到用户的购物体验和商家的运营效率。小程序提供了灵活的配送方式设置&#xff0c;可以根据不同的需求进行系统级别和单个商品的设置。 首先&#xff0c;我们来看系统级别的配送方式设置。在小程序管理员后台->配送设置…

模板学堂|DataEase协助电商企业开展用户运营

DataEase开源数据可视化分析平台于2022年6月正式发布模板市场&#xff08;https://dataease.io/templates/&#xff09;。模板市场旨在为DataEase用户提供专业、美观、拿来即用的仪表板模板&#xff0c;方便用户根据自身的业务需求和使用场景选择对应的仪表板模板&#xff0c;并…

【Java 进阶篇】深入理解 JavaScript DOM Node 对象

在前端开发中&#xff0c;与HTML文档进行交互是一项基本任务。文档对象模型&#xff08;Document Object Model&#xff0c;简称DOM&#xff09;为开发者提供了一种以编程方式访问和操作HTML文档的方式。DOM的核心是节点&#xff08;Node&#xff09;对象&#xff0c;它代表了文…

“Flex弹性布局、轮播图mock遍历数据和首页布局解析与实践“

目录 引言1. Flex弹性布局介绍及使用什么是Flex弹性布局&#xff1f;Flex容器与Flex项目Flex属性详解 2. 轮播图mock遍历数据简述轮播图的作用和意义处理mock数据的重要性使用Mock模拟数据遍历 3. 首页布局总结 引言 在现代网页开发中&#xff0c;灵活性和响应式布局是至关重要…

高数定理集合啦

haha~ 最近在准备数学竞赛&#xff0c;好久没有发布笔记啦&#xff0c;今天就来一波高数里常用的定理吧&#xff0c;不全面的话后续会更新哒~ 费马定理&#xff1a;对于一个函数的局部极值点&#xff0c;如果导数存在&#xff0c;那么导数在该点处必须为零&#xff0c;即 f(x)0…

理解宇称时间对称:探索物理世界的对称性

&#x1f482; 个人网站:【工具大全】【游戏大全】【神级源码资源网】&#x1f91f; 前端学习课程&#xff1a;&#x1f449;【28个案例趣学前端】【400个JS面试题】&#x1f485; 寻找学习交流、摸鱼划水的小伙伴&#xff0c;请点击【摸鱼学习交流群】 在物理学的深奥领域&…

Kotlin Compose Multiplatform 跨平台开发实践之加入 iOS 支持

前言 几个月前 Compose Multiplatform 的 iOS 支持就宣布进入了 Alpha 阶段&#xff0c;这意味着它已经具备了一定的可用性。 在它发布 Alpha 的时候&#xff0c;我就第一时间尝鲜&#xff0c;但是只是浅尝辄止&#xff0c;没有做过多的探索&#xff0c;最近恰好有点时间&…

【配置环境】SQLite数据库安装和编译以及VS下C++访问SQLite数据库

一&#xff0c;环境 Windows 11 家庭中文版&#xff0c;64 位操作系统, 基于 x64 的处理器SQLite - 3.43.2Microsoft Visual Studio Community 2022 (64 位) - Current 版本 17.5.3 二&#xff0c;SQLite简介 简要介绍 SQLite&#xff08;Structured Query Language for Lite&a…