super-smack压测工具
简介
super-smack是一款开源压测工具,支持MySQL、PostgreSQL、Oracle。本篇主要介绍一下使用super-smack压测MySQL体会。
1.SQL定义
2.数据字典定义
3.表结构
4.自动生成数据
5.SQL执行顺序与次数
6.多终端混合压测
MySQL性能表现与实际业务场景有很大关系。压测结果不代表正式生产环境容量,并且对于不同业务场景来说,QPS、TPS可能不再是决定性的指标。
安装
1. wgethttp://vegan.net/tony/supersmack/super-smack-1.3.tar.gz
2. tar xvzfsuper-smack-1.3.tar.gz
3../configure --prefix=/usr/local/super-smack--with-mysql \
--with-mysql-lib=/app/mysql/lib\
--with-mysql-include=/app/mysql/include/mysql
4. make
5. make install
本次安装是针对MySQL。通过./configure --help 可以看到帮助。
--with-mysql Build with MySQL support
--with-pgsql Build with PostgreSQL support
--with-oracle Build with Oracle support
在64位系统面安装需要做一些变量声明修改。在github上面有相应patch
https://github.com/yasunorikaku/super_smack_patch_for_x86_64
目录结构
gen-data
数据生成工具.用于生成数据表测试数据
./gen-data -n10000000 -f %48-64s%n,%32-64s,%n,%d >words.dat
1.-n 10000000 表示行数
2.-f 表示格式
3.s 表示字符串
4.n 表示序列
5.d 表示数字
super-smack
super-smack 客户主程序。用于发起压力测试,模拟操作客户端.
example smacks
模板文件一般有以下组成部分:
Client
client"admin"
{
user "用户名称";
host "主机";
db "数据库名称";
pass "密码";
socket "mysql socket ";
}
Table
table "http_auth"
{
client "admin";
create "create table http_auth
(username char(64) not null primary key,
pass char(12),
mail char(16),
uid integer not null,
gid integer not null,
key mail_key (mail)
)";
min_rows"90000";
data_file"words.dat";
gen_data_file"gen-data -n 90000 -f %36-36s%n, %10-10s,%10-10s,%n,%d";
}
dictionary
dictionary"word"
{
type "rand"; //Seq、Unique、Rand
source_type "file"; // file、list、template
source "words.dat";
delim ",";
file_size_equiv "55000";
}
query
query"delete_by_username"
{
query "delete from http_auth where username = '$word'";
type "delete_index";
has_result_set "y";
parsed "y";
}
smacker
client"smacker"
{
user "用户名称";
pass "用户密码";
host "主机";
db "数据库名称";
socket " mysql socket ";
query_barrel "5 select_by_username ";
}
注:可以定义多个client.
main
main
{
smacker.init();
smacker.set_num_rounds($2);
smacker.set_num_rounds($2);
smacker.create_threads($1);
smacker.connect();
smacker.unload_query_barrel();
smacker.collect_threads();
smacker.disconnect();
}
注:
1.运行客户需要输入$1、$2 .$2表示循环次数,$1表示线程个数.
2.可以加入多个client
输出
./super-smack -dmysql update-select-delete.smack -D/data/ 10 10
输出结果:[此处我定义两个终端]
Query BarrelReport for client smacker1
connect:max=14ms min=0ms avg= 6ms from 10clients
Query_type num_queries max_time min_time q_per_s
delete_index 60 25 0 329.64
insert_index 50 31 1 274.70
select_index 100 36 0 549.41
update_index 50 31 0 274.70
Query BarrelReport for client smacker
connect:max=20ms min=0ms avg= 5ms from 10clients
Query_type num_queries max_time min_time q_per_s
delete_index 60 4 0 328.13
insert_index 50 39 1 273.44
select_index 100 1 0 546.88
update_index 50 0 0 273.44
最后
1.可以自定义多个Query;
2.对于不同的查询需要定义多个数据字典;
3.支持多个客户端。
super-smack压测工具的更多相关文章
- 压测工具Locuse的使用
我是听朋友提起的"蝗虫"(Locust),然而她不想用python,我就拿来试一试~ http的 各种压测工具也已经太多了,所以主要是试试locust在当前比较流行的rpc协议上的 ...
- Http压测工具wrk使用指南
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- web压测工具http_load原理分析
一.前言 http_load是一款测试web服务器性能的开源工具,从下面的网址可以下载到最新版本的http_load: http://www.acme.com/software/http_load/ ...
- [软件测试]网站压测工具Webbench源码分析
一.我与webbench二三事 Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工作的性能.Webbench ...
- Http压测工具wrk使用指南【转】
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- python服务端多进程压测工具
本文描述一个python实现的多进程压测工具,这个压测工具的特点如下: 多进程 在大多数情况下,压测一般适用于IO密集型场景(如访问接口并等待返回),在这种场景下多线程多进程的区分并不明显(详情请参见 ...
- 内存压测工具Memtester
在做压力测试时,发现一个内存压测工具Memtester,可以随意设置内存占用大小,非常方便 下载地址:http://pyropus.ca/software/memtester/old-versions ...
- Http 压测工具 wrk 基本使用
Http 压测工具 wrk 基本使用 Intro wrk 是一款现代HTTP基准测试工具,能够在单个多核CPU上运行时产生显着负载.它将多线程设计与可扩展事件通知系统(如epoll和kqueue)结合 ...
- 压测工具使用(vegeta)
一.压测工具vegeta 1.介绍 Vegeta 是一个用 Go 语言编写的多功能的 HTTP 负载测试工具,它提供了命令行工具和一个开发库. 官方地址:https://github.com/tsen ...
随机推荐
- ora-12899解决方法
在使用ORACLE的过程中,会出现各种各样的问题,各种各样的错误,其中ORA-12899就是前段时间我在将数据导入到我本地机器上的时候一直出现的问题.不过还好已经解决了这个问题,现在分享一下,解决方案 ...
- swift - 闭包 -定义和使用
方法一: 1.定义 typealias OpenOrderSuccessResultBlock = ( _ dataArray:[String])->Void 2.类方法实现属性 var bac ...
- phalcon安装-遇坑php-config is not installed 解决方法
通过源码编译安装php环境,按照phalcon官方文档安装扩展,会遇到php-config is not installed的坑. 尝试通过下列命令可以解决: cd /opt/cphalcon-/bu ...
- alv界面透视功能
bdcdata_wa-fnam = 'P_MONAT-LOW'. bdcdata_wa-fval = '01'. APPEND bdcdata_ ...
- C#中委托
委托是一种安全地封装方法的类型,它与 C 和 C++ 中的函数指针类似.与 C 中的函数指针不同,委托是面向对象的.类型安全的和保险的.一个委托类型是代表与特定参数列表和返回类型的方法的引用类型.实例 ...
- ecplise自动提示失效,使用补全自动提示快捷键(Alt+/),但只显示“No Default Proposals”
在这里设置了自动提示,但是在使用的时候自动提示实现了.甚至使用补全自动提示快捷键(Alt+/),只显示“No Default Proposals”.今天在网上搜索了一下结果,主要有一下几种方法: 1. ...
- 线程 day40
操作系统线程理论 线程概念的引入背景 进程 之前我们已经了解了操作系统中进程的概念,程序并不能单独运行,只有将程序装载到内存中,系统为它分配资源才能运行,而这种执行的程序就称之为进程.程序和进程的区别 ...
- 异常处理 day 30
异常处理 一 错误和异常 二 异常处理 2.1 什么是异常处理? 2.2 为何要进行异常处理? 2.3 如何进行异常处理? 三 什么时候用异常处理 异常和错误 part1:程序中难免出现错误,而错误分 ...
- encode/decode/bytes
python3中如何将字符型转换成utf-8格式的bytes类型 str_me = '字符是我'.encode('utf-8') print(str_me) >>:b'\xe5\xad\x ...
- 8.Mysql数据类型选择
8.选择合适的数据类型8.1 CHAR与VARCHAR CHAR固定长度的字符类型,char(n) 当输入长度不足n时将用空格补齐,char(n)占用n个字节,CHAR类型输出时会截断尾部的空格,即使 ...