Java web应用性能分析之【sysbench基准测试】

news/2024/5/11 21:47:01

Java web应用性能分析之【CPU飙高分析之MySQL】-CSDN博客

Java web应用性能分析之【Linux服务器性能监控分析概叙】-CSDN博客

Java web应用性能分析概叙-CSDN博客

Java web应用性能分析之【基准测试】-CSDN博客

        上面基本科普了一下基准测试,这里我们将从sysbench安装、sysbench使用、sysbench报告解读等方面来详细讲解sysbench完成基准测试。

        一般情况下基准测试一定是有个对比。可以是相同硬件配置,不同品牌硬件服务器间的对比;也可以是在同一硬件服务器上,不同基准测试场景的对比。

sysbench简介

        SysBench是一个跨平台的基准测试工具,用于评估计算机系统在不同负载条件下的性能。它模拟真实场景下的工作负载,提供了多种测试模式,包括CPU、内存、磁盘、线程、数据库等方面的测试。

        主要包括以下几种测试:

  • cpu性能
  • 磁盘io性能
  • 调度程序性能
  • 内存分配及传输速度
  • POSIX线程性能
  • 数据库性能(OLTP基准测试)

sysbench安装

        sysbench的github地址GitHub - akopytov/sysbench: Scriptable database and system performance benchmark

        最新版本sysbench 1.0.20,下载地址:

Release Release 1.0.20 · akopytov/sysbench · GitHub

        安装方式,官网已经给出了说明指导

        需要重点注意的是这里,在./configure配置环境时,如果要测试mysql,需要指定“you can specify them explicitly with --with-mysql-includes and --with-mysql-libs options to ./configure.”这两个路径

        我在ubuntu18上安装如下:

sysbench基本操作

       基本语法:sysbench [options]... [testname] [command],执行sysbench –help,或者详见官网。

https://github.com/akopytov/sysbench?tab=readme-ov-file#general-syntax

command

         command是sysbench要执行的命令,包括:prepare、run、cleanup。

        顾名思义,prepare是为测试提前准备数据,run是执行正式的测试,cleanup是在测试完成后对数据库进行清理。后面我们的基准测试脚本也是按照这个来写的。

testname

        testname 是一个可选的内置测试名称(如 fileio、memory、cpu等),或一个捆绑的 Lua 脚本名称(如 oltp_read_only),或一个自定义 Lua 脚本的路径。testname指定了要进行的测试,在老版本的sysbench中,可以通过--test参数指定测试的脚本;而在新版本中,--test参数已经声明为废弃,可以不使用--test,而是直接指定脚本。

        例如,如下两种方法效果是一样的:

1

2

sysbench  --test=./tests/include/oltp_legacy/oltp.lua

sysbench ./tests/include/oltp_legacy/oltp.lua

        测试时使用的脚本为lua脚本,可以使用sysbench自带脚本,也可以自己开发。对于大多数应用,使用sysbench自带的脚本就足够了。不同版本的sysbench中,lua脚本的位置可能不同,可以自己在sysbench路径下使用find命令搜索oltp.lua。P.S.:大多数数据服务都是oltp类型的,如果你不了解什么是oltp,那么大概率你的数据服务就是oltp类型的。

options

        sysbench的options参数有很多,options是一个包含0个或多个以“--”开头的命令行选项的列表。其中比较常用的包括:

MySQL 连接信息参数

  • --mysql-host:MySQL服务器主机名,默认localhost;如果在本机上使用localhost报错,提示无法连接MySQL服务器,改成本机的IP地址应该就可以了。
  • --mysql-port:MySQL服务器端口,默认3306
  • --mysql-user:用户名
  • --mysql-password:密码
  • --mysql-db 指定数据库 默认sbtest

  • --mysql-ssl 使用 ssl 连接 默认off

  • --mysql-ssl-cipher ssl 使用 specific cipher

  • --mysql-compression 如果客户端库中有压缩功能,则使用压缩功能 默认off

  • --mysql-debug 跟踪所有客户端库调用 默认off

  • --mysql-ignore-errors 忽略的错误 [1213,1020,1205]

  • --mysql-dry-run 模拟运行,假装所有 MySQL 客户端 API 调用都成功,但不执行它们 默认off

MySQL 执行参数

  • --oltp-test-mode:执行模式,包括simple、nontrx和complex,默认是complex。simple模式下只测试简单的查询;nontrx不仅测试查询,还测试插入更新等,但是不使用事务;complex模式下测试最全面,会测试增删改查,而且会使用事务。可以根据自己的需要选择测试模式。
  • --oltp-tables-count:测试的表数量,根据实际情况选择
  • --oltp-table-size:测试的表的大小,根据实际情况选择
  • --threads:客户端的并发连接数
  • --time:测试执行的时间,单位是秒,该值不要太短,可以选择120
  • --report-interval:生成报告的时间间隔,单位是秒,如10

压测的lua脚本

        注:这些脚本均包含了oltp_common,所以调用这些脚本可以直接使用 oltp_common 脚本中的内容,oltp_common 脚本中编写了数据生成、数据清理等基础函数。

        lua脚本参数

sysbench的基准测试场景

基准场景步骤

        先确定单线程运行时的 TPS 值。

        根据系统最大的预估容量设置场景中的线程数、递增参数等;如果不会预估容量,可以直接多加一些线程,然后在递增的过程中查看曲线的变化;

        强调一下,如果你不会预估容量,可以直接多加一些线程,然后在递增的过程中查看曲线的变化;确定正式基准场景的压力参数。

基准场景的目的

        获得单接口最大 TPS:如果单接口最大 TPS 没有超过容量场景中的要求,那就必须要调优

        解决单接口基准场景中遇到的性能问题:也就是说,当我们在做单接口测试时,碰到了性能瓶颈一定要分析解决。

基准场景性能分析步骤

        第一阶段:硬件资源用完。即在基准场景中,我们要把 CPU、内存、网络、IO 等资源中的任一个耗尽,因为在这种情况下,我们很容易从全局监控的性能计数器中看到现象,可以接着去跟踪分析。

        第二阶段:优化到最高 TPS。即在基准场景中,我们要把单接口的 TPS 调到最高,以免成为容量场景中的瓶颈点。

主要测试方式

  1.         cpu性能 :找范围内最大素数{时间越短越好}
  2.         磁盘io性能:不同场景下IOPS{越大越好}
  3.         调度程序性能 :线程并发执行,循环响应信号量花费的时间{越少越好}
  4.         内存分配及传输速度:以不同块大小传输一定数量的数据吞吐量大小{越大越好}
  5.         POSIX线程性能 :并发线程同时申请互斥锁循环一定次数花费的时间{越少越好}
  6.         数据库性能(OLTP基准测试):qps、tps越高越好

         服务器硬件环境:阿里云主机  2核(vCPU)   4GiB内存   46GB磁盘 1 Mbps带宽。

        这里我们以测试cpu为例,脚本和分析,都一样。

        测试cpu

        测试素数上限20万,线程1、2、4、6、8、10

## 测试素数上限20万,线程2、4、8、10root@zhouxx:~# sysbench cpu --cpu-max-prime=200000 --threads=1 run
sysbench 1.0.20 (using bundled LuaJIT 2.1.0-beta2)Running the test with following options:
Number of threads: 1   ##线程数
Initializing random number generator from current timePrime numbers limit: 200000  ## 素数上限Initializing worker threads...Threads started!CPU speed:events per second:    17.24  #所有线程每秒完成的event数General statistics:total time:                          10.0349s  ##总耗时total number of events:              173  ##总共完成的event数Latency (ms):min:                                   56.78  ##最少耗时avg:                                   58.00 #平均耗时max:                                   70.17 #最大耗时95th percentile:                       61.08  ##95%都在61.08秒内找到sum:                                10033.47Threads fairness:events (avg/stddev):           173.0000/0.00 完成了几轮的素数计算execution time (avg/stddev):   10.0335/0.00  #每个线程平均耗时10秒,标准差为0##event: 完成了几轮的素数计算
##stddev(标准差): 在相同时间内,多个线程分别完成的素数计算次数是否稳定,如果数值越低,则表示多个线程的结果越接近(即越稳定)。该参数对于单线程无意义。root@zhouxx:~# sysbench cpu --cpu-max-prime=200000 --threads=2 run
sysbench 1.0.20 (using bundled LuaJIT 2.1.0-beta2)Running the test with following options:
Number of threads: 2
Initializing random number generator from current timePrime numbers limit: 200000Initializing worker threads...Threads started!CPU speed:events per second:    33.95General statistics:total time:                          10.0420stotal number of events:              341Latency (ms):min:                                   56.98avg:                                   58.86max:                                  116.2495th percentile:                       63.32sum:                                20072.61Threads fairness:events (avg/stddev):           170.5000/1.50execution time (avg/stddev):   10.0363/0.00root@zhouxx:~# 
root@zhouxx:~# sysbench cpu --cpu-max-prime=200000 --threads=4 run
sysbench 1.0.20 (using bundled LuaJIT 2.1.0-beta2)Running the test with following options:
Number of threads: 4
Initializing random number generator from current timePrime numbers limit: 200000Initializing worker threads...Threads started!CPU speed:events per second:    33.93General statistics:total time:                          10.0781stotal number of events:              342Latency (ms):min:                                   57.78avg:                                  117.53max:                                  159.6295th percentile:                      123.28sum:                                40193.86Threads fairness:events (avg/stddev):           85.5000/1.12execution time (avg/stddev):   10.0485/0.02root@zhouxx:~# sysbench cpu --cpu-max-prime=200000 --threads=8 run
sysbench 1.0.20 (using bundled LuaJIT 2.1.0-beta2)Running the test with following options:
Number of threads: 8
Initializing random number generator from current timePrime numbers limit: 200000Initializing worker threads...Threads started!CPU speed:events per second:    33.95General statistics:total time:                          10.1018stotal number of events:              343Latency (ms):min:                                  155.71avg:                                  234.83max:                                  279.1095th percentile:                      267.41sum:                                80545.85Threads fairness:events (avg/stddev):           42.8750/1.05execution time (avg/stddev):   10.0682/0.02root@zhouxx:~# sysbench cpu --cpu-max-prime=200000 --threads=10 run
sysbench 1.0.20 (using bundled LuaJIT 2.1.0-beta2)Running the test with following options:
Number of threads: 10
Initializing random number generator from current timePrime numbers limit: 200000Initializing worker threads...Threads started!CPU speed:events per second:    34.27General statistics:total time:                          10.1246stotal number of events:              347Latency (ms):min:                                  190.21avg:                                  290.45max:                                  327.9595th percentile:                      308.84sum:                               100786.19Threads fairness:events (avg/stddev):           34.7000/0.46execution time (avg/stddev):   10.0786/0.04root@zhouxx:~# 
       结果分析

        服务器进行CPU性能对比,当素数上限和线程数一致时:

  • 相同时间,比较event

  • 相同event,比较时间

  • 时间和event都相同,比较stddev(标准差)

        绘图

        这里直接用echart的折线图

        完整的测试过程,应该开着监控,观察服务器资源消耗情况。

        测试内存

        测试线程

        测试io

      测试mutex

      测试OLTP

        备注:--test=oltp 已经被弃用

sysbench测试cpu

sysbench测试内存

sysbench测试io

sysbench测试数据库

        测试mysql数据库前的准备工作:创建数据库和登录账号。

CREATE DATABASE sbtest CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;CREATE USER 'sbuser'@'%' IDENTIFIED BY "zhouxx1234";
grant all privileges on sbtest.* to 'sbuser'@'localhost' identified by 'zhouxx1234';
grant all privileges on sbtest.* to 'sbuser'@'%' identified by 'zhouxx1234';
grant all privileges on sbtest.* to 'sbuser'@'172.26.35.10' identified by 'zhouxx1234';
UPDATE mysql.user SET authentication_string=PASSWORD('zhouxx1234') WHERE User='sbuser';
flush privileges;

完整的sysbench基准测试脚本

测试oltp批量插入脚本

#!/bin/bashcurrent_data=$(date "+%Y-%m-%d")
current_time=$(date "+%H:%M:%S")#链接配置信息
dbhost="172.26.35.10"
dbport=3306
dbuser="sbuser"
dbpwd="zhouxx1234"
dbname=sbtest
#单表数据量
tbsize=3
#表数据量
tables=1
#选择引擎,默认innodb
testengine=innodb
# 压测使用的lua 脚本
luascript=bulk_insert.lua
# 线程数组
#threads=(1 5 10 15)
# 测试时间
sbtime=600mkdir -p /usr/share/sysbench/sblog
sbtestlogdir=/usr/share/sysbench/sblog         #存放log的地方,需要手动自己创建
path=/usr/sysbench/share/sysbench/         #存放sysbench脚本point_select.lua等其他脚本的地方#for thread in  ${threads[@]}
for thread in 1 5 10 15
do#测试结果输出日志sblogname=${sbtestlogdir}/sbtench_${testengine}_${luascript}_${thread}_$(date "+%Y%m%d%H%M%S").logecho "============================压测开始! 当前日期:$(date "+%Y-%m-%d %H:%M:%S")======================================压测地址:${dbhost},压测端口:${dbport},测试引擎对象:${testengine}压测数据量:${tables}张表每张表${tbsize}条数据量,压测时间:${sbtime} s,当前压测线程:${threads}日志地址:${sbtestlogdir}sysbench ${path}${luascript} --db-driver=mysql --mysql-host=${dbhost} \--mysql-port=${dbport} --mysql-user=${dbuser} \--mysql-password=${dbpwd} \--mysql-db=${dbname} --table_size=${tbsize} \--tables=${tables} --events=0 --time=${sbtime} \--mysql_storage_engine=${testengine}  \--threads=${thread} --percentile=95  \--range_selects=0 --skip-trx=1 --report-interval=5 prepare " >> ${sblogname}sysbench ${path}${luascript} --db-driver=mysql --mysql-host=${dbhost} \--mysql-port=${dbport} --mysql-user=${dbuser} \--mysql-password=${dbpwd} \--mysql-db=${dbname} --table_size=${tbsize} \--tables=${tables} --events=0 --time=${sbtime} \--mysql_storage_engine=${testengine}  \--threads=${thread} --percentile=95  \--range_selects=0 --skip-trx=1 --report-interval=5 prepare >> ${sblogname}sysbench ${path}${luascript} --db-driver=mysql --mysql-host=${dbhost} \--mysql-port=${dbport} --mysql-user=${dbuser} \--mysql-password=${dbpwd} \--mysql-db=${dbname} --table_size=${tbsize} \--tables=${tables} --events=0 --time=${sbtime} \--mysql_storage_engine=${testengine}  \--threads=${thread} --percentile=95  \--range_selects=0 --skip-trx=1 --report-interval=5 run >> ${sblogname}sysbench ${path}${luascript} --db-driver=mysql --mysql-host=${dbhost} \--mysql-port=${dbport} --mysql-user=${dbuser} \--mysql-password=${dbpwd} \--mysql-db=${dbname} --table_size=${tbsize} \--tables=${tables} --events=0 --time=${sbtime} \--mysql_storage_engine=${testengine}  \--threads=${thread} --percentile=95  \--range_selects=0 --skip-trx=1 --report-interval=5 cleanup >> ${sblogname}     echo "============================压测结束! 当前时间:$(date "+%Y-%m-%d %H:%M:%S")====================================== " >> ${sblogname}#sleep 10#/etc/init.d/atomstore restartdone


http://www.mrgr.cn/p/11263108

相关文章

gpu机器没有开启ipv6

参考: https://blog.csdn.net/asdfaa/article/details/137884414检查系统是否支持 IPv6,查看被禁用了 在启用 IPv6 之前,首先要确保您的系统支持 IPv6。要检查内核是否启用了 IPv6,可以运行以下命令: cat /proc/sys/net/ipv6/conf/all/disable_ipv6 如果返回的结果为 0,…

TCP相关问题总结

文章目录 TCP连接建立过程1. TCP三次握手2. TCP四次挥手3. TCP为什么是三次握手4. TCP为什么是四次挥手 TCP流量控制TCP拥塞控制1. 为什么需要拥塞控制2. 控制手段 TCP连接建立过程中出现丢包 TCP连接建立过程 1. TCP三次握手 首先client端发出连接请求,并且请求同…

Git和Github绑定

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

11 c++版本的贪吃蛇

前言 呵呵 这大概是 大学里面的 c 贪吃蛇了吧 有一些 面向对象的理解, 但是不多 最近 因为想要 在单片机上面移植一下 贪吃蛇, 所以 重新拿出了一下 这份代码 然后 将它更新为 c 版本, 还是 用了一些时间 这里 具体的实现 就不赘述, 仅仅是 发一下代码 以及 具体的使用…

python库使用总结

python库的使用 1:print(补充)2:math 2.1:math库包括的4个数学常数2.2math库中的函数幂对数函数三角曲线函数3:字符串处理函数补充:sorted(str) 对字符串中的元素进行排序,返回排序后的列表,而不是字符串 ​ reversed(str) 对字符串中的元素反向输出 3.1 字符串…

python学习思维导图分享

python 本文包含了我的一些python学习的笔记和思维导图 第一部分:python基础导图下载链接 第二部分:函数及其他文件操作导图下载链接 第三部分:类及网络编程导图下载链接 第四部分:mysql导图下载链接

linux中如何挂载yum云仓库进行软件的安装

1.首先在根目录下建立文件,用来挂载镜像文件 [rootclient ~]# mkdir /rhel9 2.挂载镜像文件: [rootclient ~]# mount /dev/cdrom /rhel9 3.切换到 /etc/yum.repos.d 下的目录并查看 ,创建 rhel9.repo文件,并编辑云仓库域名&am…

反爬虫方法

1.拒绝请求 a.根据 IP 判断 优点: 即时效果:一旦IP地址被封禁,来自该地址的流量将立即停止,从而防止了爬虫在封禁发生后进一步访问网站。 简单易行:IP封禁通常很容易实施,大多数服务器和CDN服务都提供了相应的工具来帮助封锁一系列的IP地址。 降低负载:通过封禁恶意或不…

计算机网络—— book

文章目录 一、概述1.1互联网的核心部分1.电路交换的主要特点2.分组交换的主要特点 1.2.计算机网络的性能1.速率2.带宽3.吞吐量4.时延5.利用率 1.3.计算机网络体系结构协议与划分层次具有五层协议…

简单理解盒子模型

1. 什么叫盒子模型 在html中大部分元素,特别是块元素display:block;都可以被看做一个盒子。网页布局就是一个一个盒子的平铺,堆叠,嵌套摆放。这么多的盒子放在一起,最重要的就是去关注他们的各种尺寸,边界等等,主要怕意料外的重叠一类导致的显示不正常。 2. W3C和IE盒子模…

物联网的基本功能及五大核心技术——青创智通

工业物联网解决方案-工业IOT-青创智通 物联网基本功能 物联网的最基本功能特征是提供“无处不在的连接和在线服务”,其具备十大基本功能。 (1)在线监测:这是物联网最基本的功能,物联网业务一般以集中监测为主、控制为…

类和对象【三】析构函数和拷贝构造函数

文章目录 析构函数析构函数的定义析构函数的作用主要作用次要作用 析构函数的特点 拷贝构造函数拷贝构造函数的定义拷贝构造函数的作用主要作用次要作用 拷贝构造函数的特点浅拷贝和深拷贝浅拷贝深拷贝 拷贝构造函数的调用场景 析构函数 析构函数的定义 析构函数(destructor) …

js逆向实战之中国男子篮球职业联赛官方网站返回数据解密

url:https://www.cbaleague.com/data/#/teamMain?teamId=29124 分析过程看流量包,返回数据全是加密的字符串,要做的就是解密回显数据。由于这里的网址都比较特殊,里面都带有id号,所以通过url关键字去搜索不是一个很好的办法。看initiators,里面有很多异步传输。异步传输…

Linux应急响应小结

通过系统运行状态、安全设备告警,主机异常现象来发现可疑现象通常的可疑现象有:资源占用、异常登录、异常文件、异常连接、异常进程等。目录用户排查历史命令网络排查进程排查文件排查持久化排查日志分析 通过系统运行状态、安全设备告警,主机异常现象来发现可疑现象通常的可…

XSS漏洞靶场

XSS漏洞靶场 level1 查看网站源码,发现get传参name的值test插入到了html头里面,还回显payload长度插入js代码,get传参 ?name=<script>alert()</script>本关小结:JS弹窗函数alert() level2貌似不对,查看下源码闭合掉双引号 "> <script>alert()&…

Laravel 6 - 第十一章 中间件

​ 文章目录 Laravel 6 - 第一章 简介 Laravel 6 - 第二章 项目搭建 Laravel 6 - 第三章 文件夹结构 Laravel 6 - 第四章 生命周期 Laravel 6 - 第五章 控制反转和依赖注入 Laravel 6 - 第六章 服务容器 Laravel 6 - 第七章 服务提供者 Laravel 6 - 第八章 门面 Laravel 6 - …

(2022级)成都工业学院数据库原理及应用实验六: SQL DML(增、删、改)

写在前面 1、基于2022级软件工程/计算机科学与技术实验指导书 2、成品仅提供参考 3、如果成品不满足你的要求&#xff0c;请寻求其他的途径 运行环境 window11家庭版 Navicat Premium 16 Mysql 8.0.36 实验要求 在实验三的基础上完成下列查询&#xff1a; 1、在科室表…

WIFI加密方式对无线速率的影响

目录无线加密三种选择:WEP、WPA和WPA2测试平台和测试方法非加密和WEP加密测试 结果差别巨大非加密条件下 300M无线路由实测WEP加密条件下 300M无线路由实测TKIP加密算法:WPA与WPA2成绩低迷WPA加密(TKIP加密算法)条件下 300M无线路由实测WPA2加密(TKIP加密算法)条件下 300…

10.Godot Input与自定义单例的使用

单例 单例是一个可以在任何一个脚本中对其进行直接访问的对象&#xff0c;分为内置单例与自定义单例。每个单例都是独一无二的对象。内置单例不是节点&#xff0c;主要成员是各类 Server&#xff0c;开发者可以使用它们直接控制游戏程序的图形与音效等内容。此外&#xff0c;还…

偶然看到一个古老的算法

九韶精选,你值得拥有只能说秦哥牛批!!!那个破三角公式到现在还没记住c++代码实现 #include<bits/stdc++.h> using namespace std; int n; int main(){cin>>n;//输入多项式的次数double *a=new double[n+1];//n次多项式申请n+1大小的数组for(int i=n;i>=0;i--)//…