阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

多线程基准测试工具sysbench 0.5 简介

141次阅读
没有评论

共计 3033 个字符,预计需要花费 8 分钟才能阅读完成。

一 前言 
因为在准备做压力测试方面的工作,看到 sysbench 目前最新的版本是 0.5,相比之前的 0.4 的版本,最大的变化是 test 参数的改变,在压测 MySQL 时,新版本中 test 将取值为 lua 脚本,该种方式给压测工作带来很大的灵活性。
二 安装
因为之前的博文中讲述过如何安装 sysbench 故本文不做过多讲解,不过需要提示请确保当前系统中是否安装 m4  autoconf  automake libtool 这几个包,
如果没有则通过 yum install  -y m4  autoconf  automake libtool 安装
获取 sysbench 然后安装

  1. ./autogen.sh
  2. ./configure prefix=/opt/sysbench withmysql withmysqlincludes=/opt/mysql/include withmysqllibs=/usr/lib64/mysql
  3. make and make install 安装完成之后 执行 sysbench  –help 查看完整的帮助。

安装完成之后 执行 sysbench  –help 查看完整的帮助。
三使用
之前 0.5 版本 test 值是 lua 脚本,检查一下 db 压测可以使用那些脚本

  1. [root@rac4 11:32:45 ~/sysbench/sysbench/tests/db]
  2. # ls *.lua
  3. common.lua insert.lua oltp_simple.lua select.lua select_random_ranges.lua update_non_index.lua
  4. delete.lua oltp.lua parallel_prepare.lua select_random_points.lua update_index.lua

看看大家压测的时候用到的最典型的脚本

  1. [root@rac4 11:36:32 ~/sysbench/sysbench/tests/db]
  2. # more update_non_index.lua
  3. pathtest = string.match(test, “(.*/)”) or “”
  4. dofile(pathtest .. “common.lua”)
  5. function thread_init(thread_id)
  6.    set_vars()
  7. end
  8. function event(thread_id)
  9.    local table_name
  10.    local c_val
  11.    local query
  12.    table_name = “sbtest”.. sb_rand_uniform(1, oltp_tables_count)
  13.    c_val = sb_rand_str(“###########-###########-###########-###########-###########-###########-###########-###########-###########-###########”)
  14.    query = “UPDATE “ .. table_name .. ” SET c='” .. c_val .. “‘ WHERE id=” .. sb_rand(1, oltp_table_size)
  15.    rs = db_query(query)
  16. end

如果大家会 lua 脚本,则可以根据自己的业务场景,简单的定制化压测脚本。

  1. cd /root/sysbench/
  2. /opt/sysbecn/bin/sysbench test=./sysbench/tests/db/update_non_index.lua mysqltableengine=innodb mysqldb=test oltptablesize=5000000 mysqluser=root mysqlsocket=/srv/my3308/run/mysql.sock oltptablescount=16 prepare
  3. /opt/sysbecn/bin/sysbench test=./sysbench/tests/db/update_non_index.lua mysqltableengine=innodb mysqldb=test oltptablesize=5000000 mysqluser=root mysqlsocket=/srv/my3308/run/mysql.sock oltptablescount=16 run
  4. /opt/sysbecn/bin/sysbench test=./sysbench/tests/db/update_non_index.lua mysqltableengine=innodb mysqldb=test oltptablesize=5000000 mysqluser=root mysqlsocket=/srv/my3308/run/mysql.sock oltptablescount=16 cleanup

四 遇到的问题
# ./autogen.sh
libtoolize 1.4+ wasn’t found, exiting
# ./autogen.sh
automake 1.10.x (aclocal) wasn’t found, exiting
说明需要安装  libtool,automake 的安装包
安装完上述几个包之后,我还遇到了如下错误:
libtool: link: gcc -W -Wall -Wextra -Wpointer-arith -Wbad-function-cast -Wstrict-prototypes -Wnested-externs -Winline -funroll-loops -Wundef -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations -Wredundant-decls -Wcast-align -pthread -O2 -ggdb3 -o sysbench sysbench.o sb_timer.o sb_options.o sb_logger.o db_driver.o  tests/fileio/libsbfileio.a tests/threads/libsbthreads.a tests/memory/libsbmemory.a tests/cpu/libsbcpu.a tests/mutex/libsbmutex.a scripting/libsbscript.a drivers/mysql/libsbmysql.a -L/opt/mysql/lib -lmysqlclient_r scripting/lua/src/liblua.a -ldl -lrt -lm -pthread
/usr/bin/ld: cannot find -lmysqlclient_r
collect2: ld returned 1 exit status
原因是因为自己当前环境中没有安装 mysql-devel 导致没有 libmysqlclient_r.so.16。解决方法
yum install -y  mysql-devel 

基于 sysbench-0.5 的 MySQL 自动化压测及分析方案  http://www.linuxidc.com/Linux/2016-10/136105.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-01/139391.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计3033字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中