sysbench自定义lua脚本实现实际的业务逻辑压力测试

昝辉Zac Zac的SEO博客,坚持12年,优化成为生活。

sysbench本身就是一款开源的多线程性能测试工具,可以执行CPU/内存/线程/IO/数据库等方面的性能测试,数据库目前支持MySQL/Oracle/PostgreSQL了,下面给各位介绍sysbench自定义lua脚本实现实际的业务逻辑压力测试例子.

使用sysbench进行mysql的oltp测试,一般的测试在sysbench中在tests/db中提供了一个oltp.lua脚本可以进行oltp的压力测试.

但不能完全模拟自己实际业务的压力测试,不同的业务,数据结构,数据量都是不一样的,为了更接近实际业务的读写压力测试,就得自己写lua脚本,然后通过sysbench进行压力测试.

写这个lua脚本很简单,只需要会写lua脚本就可以了.

1、首先收集实际业务的访问数据库的sql;

2、准备一台恢复好的备份库(从线上导一个).

3、将收集的sql写在lua脚本里(具体如何写,后面举个例子).

4、通过sysbench的--test参数和--mysql-db参数进行测试(这里就不需要prepare了,直接run就行).

举个小例子,模拟实际业务环境:

  1. CREATETABLE`t1`(
  2. `id`int(10)NOTNULLAUTO_INCREMENT,
  3. `name`varchar(50)DEFAULTNULL,
  4. PRIMARYKEY(`id`)
  5. )ENGINE=InnoDBAUTO_INCREMENT=10101DEFAULTCHARSET=utf8

插入模拟的际业务数据:

  1. delimiter$$
  2. createprocedureadd_data(inmaxnumint)
  3. begin
  4. declareiintdefault0;
  5. declaresvarchar(500);
  6. while(i<maxnum)do
  7. selectconcat("abcdedsfsfsdfsfsf",i)intos;
  8. insertintot1(name)values(s);
  9. seti=i+1;
  10. endwhile;
  11. end$$
  12. delimiter;
  13. calladd_data(10000);

准备lua脚本:[root@sever3 db]# cat test.lua

  1. functionthread_init(thread_id)
  2. --set_vars()
  3. db_connect()
  4. end
  5. //phpfensi.com
  6. functionevent(thread_id)
  7. localtable_name
  8. localrs
  9. table_name="t1"
  10. db_query("begin")
  11. fori=1,10000do
  12. rs=db_query("SELECTnameFROM"..table_name.."WHEREid="..i)
  13. end
  14. end

set_vars() 如果需要使用更多的参数,需要执行这个,前面需要引用下common.lua

db_connect() 是连接数据库的,这个是sysbench里的函数,不管那么多,直接用就行。

thread_init() 第一个调用的lua函数

event(thread_id) 可以把sql逻辑写到这里,–num-threads多少个,就会同时调用多少个,然后进行压测就ok.

  1. [root@sever3sysbench]#./sysbench--mysql-socket=/data/mysql_3309/mysql.sock--test=tests/db/test.lua--mysql-user=root--num-threads=12--report-interval=10--rand-type=uniform--max-time=30--max-requests=0--percentile=99--mysql-db=testrun
  2. sysbench0.5:multi-threadedsystemevaluationbenchmark
  3. Runningthetestwithfollowingoptions:
  4. Numberofthreads:12
  5. Reportintermediateresultsevery10second(s)
  6. Randomnumbergeneratorseedis0andwillbeignored
  7. Threadsstarted!
  8. [10s]threads:12,tps:0.00,reads/s:64131.41,writes/s:0.00,responsetime:3291.51ms(99%)
  9. [20s]threads:12,tps:0.00,reads/s:79980.83,writes/s:0.00,responsetime:1947.61ms(99%)
  10. [30s]threads:12,tps:0.00,reads/s:78354.15,writes/s:0.00,responsetime:2418.21ms(99%)
  11. OLTPteststatistics:
  12. queriesperformed:
  13. read:2280000
  14. write:0
  15. other:228
  16. total:2280228
  17. transactions:0(0.00persec.)
  18. deadlocks:0(0.00persec.)
  19. read/writerequests:2280000(72705.35persec.)
  20. otheroperations:228(7.27persec.)
  21. Generalstatistics:
  22. totaltime:31.3595s
  23. totalnumberofevents:228
  24. totaltimetakenbyeventexecution:368.0393s
  25. responsetime:
  26. min:985.61ms
  27. avg:1614.21ms
  28. max:3756.13ms
  29. approx.99percentile:3289.54ms
  30. Threadsfairness:
  31. events(avg/stddev):19.0000/3.83
  32. executiontime(avg/stddev):30.6699/0.42

相关广告
  • sysbench自定义lua脚本实现实际的业务逻辑压力测试 sysbench自定义lua脚本实现实际的业务逻辑压力测试 sysbench自定义lua脚本实现实际的业务逻辑压力测试
相关阅读

sysbench自定义lua脚本实现实际的业务逻辑压力测试

2019/10/10 17:46:31 | 谷歌SEO算法 | 1号店SEO