sysbench 命令:跨平台的基准测试工具

一、命令简介

sysbench 是一个跨平台的基准测试工具,用于评估系统性能,包括 CPU、内存、文件 I/O、数据库等性能。

比较同类测试工具

bench.sh

在上文 bench.sh:Linux 服务器基准测试中介绍了 bench.sh 一键测试脚本,它对新手十分友好。一键完成测试,主打一个省心。缺点是不能设置测试参数。

Clip_2024-09-26_22-23-15

sysbench

本文的 sysbench 命令填补了bench.sh的缺陷,sysbench命令则可以设置测试参数,更为灵活。

安装 sysbench

apt update
apt install sysbench

第二章“命令参数”会比较枯燥,可以直接跳到第三章,查看命令用法,以及实测结果。

二、命令参数

基本命令格式:

sysbench [测试模块] [全局选项] [命令] [测试参数]

常用测试模块:

  • cpu​:CPU 性能测试。
  • memory​:内存测试。
  • fileio​:文件 I/O 性能测试。
  • threads​:线程性能测试。
  • mutex​:互斥锁测试。
  • oltp​:OLTP(数据库)测试。

常用的全局选项:

  • --threads=N​:设置并发线程数,N​ 是线程数,默认是 1。
  • --time=N​:设置测试运行的时间(秒),默认是无限制。
  • --events=N​:设置最大事件数,测试在事件数达到 N 后结束。
  • --report-interval=N​:设置每 N 秒打印一次报告。
  • --rate=N​:每秒产生的事件数。

Sysbench 命令:

  • prepare​:准备测试环境(如创建测试文件)。
  • run​:运行测试。
  • cleanup​:清理测试环境(如删除测试文件)。

三、命令示例

准备了三台主机,电视盒子是arm架构,其余是x86架构,使用sysbench命令分别测试不同单元的跑了,并记录。

  1. 虚拟机:

    • 2C2G
    • CPU:i7 6700hq
    • ubuntu 22.04
  2. 电视盒子:

    • 4C2G
    • CPU:晶晨s905l3a。
    • 系统:armbian(ubuntu24.04)
  3. 云服务器:

    • 4C4G
    • CPU:未知
    • 系统:ubuntu 22.04

1. CPU 性能测试

实际是测试 CPU 计算质数的性能,所以不能完全代表CPU的综合性能。

单核性能
sysbench cpu --cpu-max-prime=20000 run
  • --cpu-max-prime=20000​ 表示计算 20,000 以内的质数。
  • run​ 表示运行测试。

测试结果

  • 虚拟机
CPU speed:
    events per second:   458.04

General statistics:
    total time:                          10.0020s
    total number of events:              4582

Latency (ms):
         min:                                    2.09
         avg:                                    2.18
         max:                                    3.46
         95th percentile:                        2.30
         sum:                                 9999.88

Threads fairness:
    events (avg/stddev):           4582.0000/0.00
    execution time (avg/stddev):   9.9999/0.00
  • 电视盒子
CPU speed:
    events per second:   375.26

General statistics:
    total time:                          10.0016s
    total number of events:              3755

Latency (ms):
         min:                                    2.66
         avg:                                    2.66
         max:                                    4.24
         95th percentile:                        2.66
         sum:                                 9999.37

Threads fairness:
    events (avg/stddev):           3755.0000/0.00
    execution time (avg/stddev):   9.9994/0.00
  • 云服务器
CPU speed:
    events per second:   337.99

General statistics:
    total time:                          10.0010s
    total number of events:              3381

Latency (ms):
         min:                                    2.89
         avg:                                    2.96
         max:                                    4.12
         95th percentile:                        3.02
         sum:                                 9995.00

Threads fairness:
    events (avg/stddev):           3381.0000/0.00
    execution time (avg/stddev):   9.9950/0.00
多核性能
sysbench cpu --cpu-max-prime=20000 --theads=核心数 run

把“核心数”换成你的服务器核心数,比如2,4,8。

测试结果:虚拟机>电视盒子>云服务器

  • 虚拟机
CPU speed:
    events per second:   858.40

General statistics:
    total time:                          10.0020s
    total number of events:              8587

Latency (ms):
         min:                                    2.22
         avg:                                    2.33
         max:                                   12.45
         95th percentile:                        2.43
         sum:                                19998.65

Threads fairness:
    events (avg/stddev):           4293.5000/0.50
    execution time (avg/stddev):   9.9993/0.00
  • 电视盒子
CPU speed:
    events per second:  1493.22

General statistics:
    total time:                          10.0026s
    total number of events:              14943

Latency (ms):
         min:                                    2.66
         avg:                                    2.68
         max:                                   18.54
         95th percentile:                        2.71
         sum:                                39998.98

Threads fairness:
    events (avg/stddev):           3735.7500/8.20
    execution time (avg/stddev):   9.9997/0.0
  • 云服务器
CPU speed:
    events per second:  1339.86

General statistics:
    total time:                          10.0027s
    total number of events:              13405

Latency (ms):
         min:                                    2.89
         avg:                                    2.98
         max:                                    4.71
         95th percentile:                        3.13
         sum:                                39989.84

Threads fairness:
    events (avg/stddev):           3351.2500/13.35
    execution time (avg/stddev):   9.9975/0.00

2. 内存性能测试

测试内存的读写速度:

sysbench memory --memory-block-size=1M --memory-total-size=10G run
  • --memory-block-size=1M​:每次内存读写的块大小为 1 MB。
  • --memory-total-size=10G​:总共测试 10 GB 的数据量。

测试结果:虚拟机>云服务器>电视盒子

  • 虚拟机
10240.00 MiB transferred (18088.04 MiB/sec)

General statistics:
    total time:                          0.5645s
    total number of events:              10240

Latency (ms):
         min:                                    0.05
         avg:                                    0.05
         max:                                    0.19
         95th percentile:                        0.08
         sum:                                  561.64

Threads fairness:
    events (avg/stddev):           10240.0000/0.00
    execution time (avg/stddev):   0.5616/0.00
  • 电视盒子
10240.00 MiB transferred (4792.52 MiB/sec)

General statistics:
    total time:                          2.1318s
    total number of events:              10240

Latency (ms):
         min:                                    0.21
         avg:                                    0.21
         max:                                    0.37
         95th percentile:                        0.21
         sum:                                 2126.68

Threads fairness:
    events (avg/stddev):           10240.0000/0.00
    execution time (avg/stddev):   2.1267/0.00
  • 云服务器
10240.00 MiB transferred (14686.15 MiB/sec)

General statistics:
    total time:                          0.6950s
    total number of events:              10240

Latency (ms):
         min:                                    0.06
         avg:                                    0.07
         max:                                    0.17
         95th percentile:                        0.08
         sum:                                  690.30

Threads fairness:
    events (avg/stddev):           10240.0000/0.00
    execution time (avg/stddev):   0.6903/0.00

3. 文件 I/O 性能测试

首先需要生成测试文件,然后运行 I/O 性能测试:

创建测试文件:
sysbench fileio --file-total-size=5G prepare
  • --file-total-size=5G​:生成一个 5 GB 的文件来测试。

写入速度:

  • 虚拟机
5368709120 bytes written in 4.63 seconds (1106.91 MiB/sec).
  • 电视盒子
内置mmc硬盘太小,无法完成测试。
  • 云服务器
5368709120 bytes written in 155.73 seconds (32.88 MiB/sec).
运行 I/O 测试:
sysbench fileio --file-total-size=5G --file-test-mode=rndrw --max-time=60 --max-requests=0 run
  • --file-test-mode=rndrw​:以随机读写模式测试。
  • --max-time=60​:测试持续时间为 60 秒。
  • --max-requests=0​:请求次数不限。

测试结果:虚拟机>云服务器>电视盒子

  • 虚拟机
File operations:
    reads/s:                      5385.18
    writes/s:                     3590.12
    fsyncs/s:                     11488.40

Throughput:
    read, MiB/s:                  84.14
    written, MiB/s:               56.10

General statistics:
    total time:                          60.0076s
    total number of events:              1227881

Latency (ms):
         min:                                    0.00
         avg:                                    0.05
         max:                                   28.11
         95th percentile:                        0.08
         sum:                                59288.93

Threads fairness:
    events (avg/stddev):           1227881.0000/0.00
    execution time (avg/stddev):   59.2889/0.00
  • 电视盒子
内置mmc硬盘太小,无法完成测试。
  • 云服务器
File operations:
    reads/s:                      35.77
    writes/s:                     23.85
    fsyncs/s:                     76.33

Throughput:
    read, MiB/s:                  0.56
    written, MiB/s:               0.37

General statistics:
    total time:                          60.3794s
    total number of events:              8081

Latency (ms):
         min:                                    0.00
         avg:                                    7.47
         max:                                11084.39
         95th percentile:                        0.17
         sum:                                60354.33

Threads fairness:
    events (avg/stddev):           8081.0000/0.00
    execution time (avg/stddev):   60.3543/0.00
清理测试文件:
sysbench fileio --file-total-size=5G cleanup

4. 数据库测试 (MySQL)

需要先配置 MySQL 相关选项,然后运行基准测试。

安装MySQL

sudo apt update
sudo apt install mysql-client-core-8.0 -y
sudo apt install mysql-server-8.0 -y

登录MySQL

sudo mysql -u root -p

创建测试数据库

CREATE DATABASE testdb;

退出MySQL

exit
创建测试表:
sysbench oltp_read_write --mysql-host=localhost --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb --tables=10 --table-size=10000 prepare

创建速度:虚拟机>电视盒子>云服务器

运行读写测试:
sysbench oltp_read_write --mysql-host=localhost --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb --tables=10 --table-size=10000 --threads=8 --time=60 run
  • --tables=10​:测试表的数量。
  • --table-size=10000​:每个表的行数。
  • --threads=8​:使用 8 个线程。
  • --time=60​:测试持续时间为 60 秒。
清理测试表:
sysbench oltp_read_write --mysql-host=localhost --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb cleanup

测试结果:虚拟机>电视盒子>云服务器

  • 虚拟机
SQL statistics:
    queries performed:
        read:                            360430
        write:                           102980
        other:                           51490
        total:                           514900
    transactions:                        25745  (428.94 per sec.)
    queries:                             514900 (8578.78 per sec.)
    ignored errors:                      0      (0.00 per sec.)
    reconnects:                          0      (0.00 per sec.)

General statistics:
    total time:                          60.0187s
    total number of events:              25745

Latency (ms):
         min:                                    5.67
         avg:                                   18.64
         max:                                  104.16
         95th percentile:                       27.66
         sum:                               479997.75

Threads fairness:
    events (avg/stddev):           3218.1250/14.90
    execution time (avg/stddev):   59.9997/0.01
  • 电视盒子
SQL statistics:
    queries performed:
        read:                            117348
        write:                           33528
        other:                           16764
        total:                           167640
    transactions:                        8382   (139.60 per sec.)
    queries:                             167640 (2791.97 per sec.)
    ignored errors:                      0      (0.00 per sec.)
    reconnects:                          0      (0.00 per sec.)

General statistics:
    total time:                          60.0391s
    total number of events:              8382

Latency (ms):
         min:                                   23.51
         avg:                                   57.28
         max:                                  219.09
         95th percentile:                       92.42
         sum:                               480099.51

Threads fairness:
    events (avg/stddev):           1047.7500/5.21
    execution time (avg/stddev):   60.0124/0.01
  • 云服务器
SQL statistics:
    queries performed:
        read:                            6818
        write:                           1948
        other:                           974
        total:                           9740
    transactions:                        487    (7.98 per sec.)
    queries:                             9740   (159.60 per sec.)
    ignored errors:                      0      (0.00 per sec.)
    reconnects:                          0      (0.00 per sec.)

General statistics:
    total time:                          61.0263s
    total number of events:              487

Latency (ms):
         min:                                   89.65
         avg:                                  999.24
         max:                                 5688.30
         95th percentile:                     3841.98
         sum:                               486629.54

Threads fairness:
    events (avg/stddev):           60.8750/1.69
    execution time (avg/stddev):   60.8287/0.07

这台云服务器实在太垃圾了,虽然一年的价格只要20块。CPU和数据库性能被电视盒子暴打。此外它是纯ipv6,使用起来颇多不便。只能说不测不知道,一测吓一跳。

电视盒子(armbian Linux)

image

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

RabbitMQ下载安装运行环境搭建

RabbitMQ运行环境搭建 1、Erlang及RabbitMQ安装版本的选择2、下载安装Erlang2.1、下载Erlang2.2、安装Erlang2.2.1、安装Erlang前先安装Linux依赖库2.2.2、解压Erlang压缩包文件2.2.3、配置2.2.4、编译2.2.5、安装2.2.6、验证erlang是否安装成功 3、RabbitMQ下载安装3.1、下载3…

FortiGate 无线组网

无线管理与配置 FortiAP 连接 internal 接口之后自动获得 ip 地址:192.168.1.xxx/24在 FortiGate 中创建 SSIDFortiGate 自动发现 FortiAP,将 FortiAP 添加到 FortiGate将 SSID 和 FortiAP 关联创建防火墙策略 下面我们就来一起看看在 FortiGate 中该如…

MT6765/MT6762(R/D/M)/MT6761(MT8766)安卓核心板参数比较_MTK联发科4G智能模块

联发科Helio P35 MT6765安卓核心板 MediaTek Helio P35 MT6765是智能手机的主流ARM SoC,于2018年末推出。它在两个集群中集成了8个ARM Cortex-A53内核(big.LITTLE)。四个性能内核的频率高达2.3GHz。集成显卡为PowerVR GE8320,频率…

前端——js基础

一、JavaScript (简称js)——js可以给网页实现一个动态效果 1.JavaScript 组成 - 核心语法 ECMScipt 简称(es): 规范js的基本语法 1.es是js的语法规范 管理者 2.js是es的实现 操作者 - DOM > 文档对象 提供js操作 (例如…

Golang | Leetcode Golang题解之第423题从英文中重建数字

题目: 题解: func originalDigits(s string) string {c : map[rune]int{}for _, ch : range s {c[ch]}cnt : [10]int{}cnt[0] c[z]cnt[2] c[w]cnt[4] c[u]cnt[6] c[x]cnt[8] c[g]cnt[3] c[h] - cnt[8]cnt[5] c[f] - cnt[4]cnt[7] c[s] - cnt[6]…

jq实现:点击图片时弹出详情弹窗,判断拖动图片时不弹出

1.需求分析: 要实现点击图片时弹出详情弹窗,但在拖动时不弹出,可以使用 jQuery 来判断用户的操作。可以通过设置一个标志变量来判断用户是否在拖动图片。 并且在鼠标拖动某个图片时将其层级设置为最上面,可以使用 jQuery 结合 CSS 的 z-index 属性 说明 : 标志变量:使用…

传输层TCP协议

一、TCP协议格式 我们看到报头固定有20字节,最后选项大小不固定。 4位首部长度(二进制0000 ~ 1111,十进制范围[0, 15])单位是4字节(存放字节大小范围[0, 60])包括了20字节固定长度 选项长度。若选项大小为…

PWA(Progressive web APPs,渐进式 Web 应用): manifest.json、 Service Worker

文章目录 引言I 什么是 PWA功能特性技术上分为三个部分:II Web 应用清单将Web 应用清单文件链接到站点manifest.json字段说明III Service WorkerService worker 本质Service worker 运行在 worker 上下文注册服务辅助角色扩展知识将 PWA 作为脱机应用定义当前文档与被链接文档…

用Python实现运筹学——Day 4: 线性规划的几何表示

一、学习内容 线性规划的几何表示: 线性规划问题的解通常位于一个凸多边形(即可行解空间)的顶点上,这意味着在求解线性规划问题时,只需要找到可行解空间中的顶点并计算出目标函数值,再选择其中的最优解。 可…

C++之分割字符串的两种方式

方式一 #include <string> #include <vector> #include <sstream> #include <iostream>std::vector<std::string> split(const std::string& str, char delim) {std::stringstream ss(str);std::string item;std::vector<std::string>…

C语言贪吃蛇小游戏演示和说明

C语言贪吃蛇小游戏演示和说明 设计贪吃蛇游戏的主要目的是让大家夯实C语言基础&#xff0c;训练编程思维&#xff0c;培养解决问题的思路&#xff0c;领略多姿多彩的C语言。 游戏开始后&#xff0c;会在中间位置出现一条只有三个节点的贪吃蛇&#xff0c;并随机出现一个食物&am…

keepalived+lvs集群,实现高可用

环境准备&#xff1a;两台虚拟机&#xff0c;关闭防火墙&#xff0c;selinux,配置阿里云仓库&#xff0c;配置epel 192.168.88.21 dr1 负载均衡器 master 192.168.88.22 dr2 负载均衡器 backup 192.168.88.23 rs1 web1 192.168.88.24 rs2 web2 实验说明&…

项目启动错误

说明&#xff1a;记录一次项目启动&#xff0c;报数据库访问错误&#xff0c;如下&#xff1a; 错误信息&#xff1a;Invalid default&#xff1a;public abstract java.lang.Class tk.mybatis.spring.annotation.MapperScan.fatoryBean() 解决 没有引入mybatis依赖&#xff…

通信工程学习:什么是VIM虚拟化基础设施管理器

VIM:虚拟化基础设施管理器 VIM(Virtualized Infrastructure Manager)虚拟化基础设施管理器,是一种负责管理和控制虚拟化环境中所有虚拟资源的工具和系统。以下是关于VIM虚拟化基础设施管理器的详细解释: 一、定义与功能 VIM是网络功能虚拟化(NFV)架构中…

HarmonyOS---权限和http/Axios网络请求

网络请求(http,axios) 目录 一、应用权限管理1.1权限的等级1.2授权方式1.3声明权限的配置1.4如何向用户进行申请 二、内置http请求使用三、Axios请求使用&#xff08;建议&#xff09;3.1 使用方式一3.2 使用方式二&#xff08;建议&#xff09; 一、应用权限管理 应用权限保护…

Leetcode面试经典150题-322.零钱兑换

给你一个整数数组 coins &#xff0c;表示不同面额的硬币&#xff1b;以及一个整数 amount &#xff0c;表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额&#xff0c;返回 -1 。 你可以认为每种硬币的数量是无限的。 示…

uniapp 常用高度状态栏,导航栏,tab栏,底部安全高度

实际效果 使用 //使用 let posConfig this.getPosConfig(); // 传false返回值为 px大小 console.log(posConfig.safeBottomH) // 入参 是否转换为rpxgetPosConfig(toRpx true) {const systemInfo uni.getSystemInfoSync();// #ifdef MPconst menuButtonInfo uni.getMenuBu…

基于RPA+BERT的文档辅助“悦读”系统 | OPENAIGC开发者大赛高校组AI创作力奖

在第二届拯救者杯OPENAIGC开发者大赛中&#xff0c;涌现出一批技术突出、创意卓越的作品。为了让这些优秀项目被更多人看到&#xff0c;我们特意开设了优秀作品报道专栏&#xff0c;旨在展示其独特之处和开发者的精彩故事。 无论您是技术专家还是爱好者&#xff0c;希望能带给…

Linux云计算 |【第四阶段】NOSQL-DAY2

主要内容&#xff1a; Redis集群概述、部署Redis集群&#xff08;配置manage管理集群主机、创建集群、访问集群、添加节点、移除节点&#xff09; 一、Redis集群概述 1、集群概述 所谓集群&#xff0c;就是通过添加服务器的数量&#xff0c;提供相同的服务&#xff0c;从而让…

计算机毕业设计之:微信小程序的校园闲置物品交易平台(源码+文档+讲解)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…