sysbench本身就是一款開(kāi)源的多線程性能測(cè)試工具,可以執(zhí)行CPU/內(nèi)存/線程/IO/數(shù)據(jù)庫(kù)等方面的性能測(cè)試,數(shù)據(jù)庫(kù)目前支持MySQL/Oracle/PostgreSQL了,下面給各位介紹sysbench自定義lua腳本實(shí)現(xiàn)實(shí)際的業(yè)務(wù)邏輯壓力測(cè)試?yán)?
使用sysbench進(jìn)行mysql的oltp測(cè)試,一般的測(cè)試在sysbench中在tests/db中提供了一個(gè)oltp.lua腳本可以進(jìn)行oltp的壓力測(cè)試.
但不能完全模擬自己實(shí)際業(yè)務(wù)的壓力測(cè)試,不同的業(yè)務(wù),數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)量都是不一樣的,為了更接近實(shí)際業(yè)務(wù)的讀寫(xiě)壓力測(cè)試,就得自己寫(xiě)lua腳本,然后通過(guò)sysbench進(jìn)行壓力測(cè)試.
寫(xiě)這個(gè)lua腳本很簡(jiǎn)單,只需要會(huì)寫(xiě)lua腳本就可以了.
1、首先收集實(shí)際業(yè)務(wù)的訪問(wèn)數(shù)據(jù)庫(kù)的sql;
2、準(zhǔn)備一臺(tái)恢復(fù)好的備份庫(kù)(從線上導(dǎo)一個(gè)).
3、將收集的sql寫(xiě)在lua腳本里(具體如何寫(xiě),后面舉個(gè)例子).
4、通過(guò)sysbench的--test參數(shù)和--mysql-db參數(shù)進(jìn)行測(cè)試(這里就不需要prepare了,直接run就行).
舉個(gè)小例子,模擬實(shí)際業(yè)務(wù)環(huán)境:
- 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
插入模擬的際業(yè)務(wù)數(shù)據(jù):
- delimiter $$
- create procedure add_data(in maxnum int)
- begin
- declare i int default 0;
- declare s varchar(500);
- while(i<maxnum) do
- select concat("abcdedsfsfsdfsfsf",i) into s;
- insert into t1(name)values(s);
- set i=i+1;
- end while;
- end $$
- delimiter ;
- call add_data(10000);
準(zhǔn)備lua腳本:[root@sever3 db]# cat test.lua
- function thread_init(thread_id)
- -- set_vars()
- db_connect()
- end
- //Vevb.com
- 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() 如果需要使用更多的參數(shù),需要執(zhí)行這個(gè),前面需要引用下common.lua
db_connect() 是連接數(shù)據(jù)庫(kù)的,這個(gè)是sysbench里的函數(shù),不管那么多,直接用就行。
thread_init() 第一個(gè)調(diào)用的lua函數(shù)
event(thread_id) 可以把sql邏輯寫(xiě)到這里,–num-threads多少個(gè),就會(huì)同時(shí)調(diào)用多少個(gè),然后進(jìn)行壓測(cè)就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: 64131.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: 3289.54ms
- Threads fairness:
- events (avg/stddev): 19.0000/3.83
- execution time (avg/stddev): 30.6699/0.42
新聞熱點(diǎn)
疑難解答
圖片精選