黑帽联盟

 找回密码
 会员注册
查看: 1735|回复: 0
打印 上一主题 下一主题

[脚本语言] MySQL实时统计脚本-计算QPS,TPS和线程连接数等

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    MySQL系统本身提供很多状态信息,很多时候我们只关心其中一部分数据信息,如TPS、QPS、连接数等
    1. #!/bin/bash

    2. mysqladmin -uroot -p'123123' extended-status -i1|awk 'BEGIN{local_switch=0;print "QPS   Commit Rollback   TPS    Threads_con Threads_run \n------------------------------------------------------- "}

    3.      $2 ~ /Queries$/            {q=$4-lq;lq=$4;}

    4.      $2 ~ /Com_commit$/         {c=$4-lc;lc=$4;}

    5.      $2 ~ /Com_rollback$/       {r=$4-lr;lr=$4;}

    6.      $2 ~ /Threads_connected$/  {tc=$4;}

    7.      $2 ~ /Threads_running$/    {tr=$4;

    8.         if(local_switch==0)

    9.                 {local_switch=1; count=0}

    10.         else {

    11.                 if(count>10)

    12.                         {count=0;print "------------------------------------------------------- \nQPS   Commit Rollback   TPS    Threads_con Threads_run \n------------------------------------------------------- ";}

    13.                 else{

    14.                         count+=1;

    15.                         printf "%-6d %-8d %-7d %-8d %-10d %d \n", q,c,r,c+r,tc,tr;

    16.                 }

    17.         }

    18. }'
    复制代码
    QPS:每秒的查询数
    TPS:每秒的事物量(commit与rollback的之和)
    通过mysqladmin间隔读取mysql的status信息,计算差值,得出统计信息。

    --结果示例
    mysql查询
    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部