zoukankan      html  css  js  c++  java
  • super-smack压测工具

    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.支持多个客户端。

  • 相关阅读:
    数值的整数次方
    二进制中1的个数
    SpingBoot 启动自动给MongoDB建库
    Java 依赖冲突的解决办法
    Http协议
    你被限流了吗?
    LeetCode 783. 二叉搜索树节点最小距离
    Leetcode 687. 最长同值路径
    LeetCode 784. 字母大小写全排列
    LeetCode 面试题 08.06. 汉诺塔问题
  • 原文地址:https://www.cnblogs.com/hurry-up/p/6626555.html
Copyright © 2011-2022 走看看