视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
sysbench自定义lua脚本实现实际的业务逻辑压力测试
2020-11-09 12:55:55 责编:小采
文档


使用sysbench进行mysql的oltp测试,一般的测试在sysbench中在tests/db中提供了一个oltp.lua脚本可以进行oltp的压力测试。 但不能完全模拟自己实际业务的压力测试,不同的业务,数据结构,数据量都是不一样的,为了更接近实际业务的读写压力测试,就得自己写l

使用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就行)

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

CREATE TABLE `t1` (
 `id` int(10) NOT NULL AUTO_INCREMENT,
 `name` varchar(50) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10101 DEFAULT CHARSET=utf8

插入模拟的际业务数据:

delimiter $$
create procedure add_data(in maxnum int) 
begin 
	declare i int default 0;
	declare s varchar(500); 
	while(i

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

function thread_init(thread_id)
 -- set_vars()
 db_connect()
end
function event(thread_id)
 local table_name
 local rs
 table_name = "t1"
 db_query("begin")
 for i=1, 10000 do
 rs = db_query("SELECT name FROM ".. table_name .." WHERE id=" .. i)
 end
end

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

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

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

event(thread_id) ? 可以把sql逻辑写到这里, ? –num-threads多少个,就会同时调用多少个

然后进行压测就ok

[root@sever3 sysbench]# ./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=test run
sysbench 0.5: multi-threaded system evaluation benchmark
Running the test with following options:
Number of threads: 12
Report intermediate results every 10 second(s)
Random number generator seed is 0 and will be ignored
Threads started!
[ 10s] threads: 12, tps: 0.00, reads/s: 131.41, writes/s: 0.00, response time: 3291.51ms (99%)
[ 20s] threads: 12, tps: 0.00, reads/s: 79980.83, writes/s: 0.00, response time: 1947.61ms (99%)
[ 30s] threads: 12, tps: 0.00, reads/s: 78354.15, writes/s: 0.00, response time: 2418.21ms (99%)
OLTP test statistics:
 queries performed:
 read: 2280000
 write: 0
 other: 228
 total: 2280228
 transactions: 0 (0.00 per sec.)
 deadlocks: 0 (0.00 per sec.)
 read/write requests: 2280000 (72705.35 per sec.)
 other operations: 228 (7.27 per sec.)
General statistics:
 total time: 31.3595s
 total number of events: 228
 total time taken by event execution: 368.0393s
 response time:
 min: 985.61ms
 avg: 1614.21ms
 max: 3756.13ms
 approx. 99 percentile: 32.54ms
Threads fairness:
 events (avg/stddev): 19.0000/3.83
 execution time (avg/stddev): 30.6699/0.42

sysbench具体的使用、结果解读可以参数下

http://imysql.com/2014/10/17/sysbench-full-user-manual.shtml

下载本文
显示全文
专题