• 【性能诊断】二、单功能场景的性能分析(fiddler、SQL Profiler)


    Fiddler

        fiddler是最强大最好用的Web调试工具之一,它能记录所有客户端和服务器的http和https请求,允许你监视,设置断点,甚至修改输入输出数据。 使用Fiddler无论对开发还是测试来说,在诊断分析问题时,都有很大的帮助。

    下载地址:http://www.telerik.com/download/fiddler

    工作原理和使用说明可参考:http://www.cnblogs.com/TankXiao/archive/2012/02/06/2337728.html

    image

     

    当然我们如果仅开发WEB系统,使用浏览器自身的开发者工具也可以看到http的请求响应时间。不再赘述。

    image

    SQL Profiler

         对于企业应用系统,绝大部分单功能的性能问题出现在数据库的SQL脚本执行上,所以当我们发现fiddler中有响应时间较长的http请求时,往往做的第一件事就是跟踪出该功能执行的SQL,找出响应时间最长的SQL脚本,直接执行该SQL,分析IO、执行计划。一般来说,逻辑IO是SQL性能的主要因素。

         如果数据库使用的是sqlserver,这个工作会比较简单,,我们可以使用sqlserver Profiler直接使用缺省设置即可(但sqlserver本身其实很复杂,即使是这简单的Profiler工具,在深入使用的时候也有很大的学问,以后有机会我会再针对sqlserver起一个专题)。

          使用Oracle数据库的话,可以借助性能视图找出性能较差的SQL。sqlserver也有大量的动态性能视图,不过sqlserver的图形界面工具做的如此优秀,以至于我们只有在整体性能下降等复杂场景下才使用它。

     

         在此我们仅以Oracle为例,列出常用的一些性能视图的SQL脚本。当然如果我们的业务系统本身提供了获取SQL脚本的功能或机制更好。

    --.查找前十条性能差的sql(磁盘读取较大,缺少索引或语句不合理)
    SELECT *
      FROM (SELECT PARSING_USER_ID EXECUTIONS,
                   SORTS,
                   COMMAND_TYPE,
                   DISK_READS,
                   sql_text
              FROM v$sqlarea
             ORDER BY disk_reads DESC)
     WHERE ROWNUM < 10;
    
    SELECT sql_text, hash_value, executions, buffer_gets, disk_reads, parse_calls
     FROM V$SQLAREA
    WHERE buffer_gets > 10000000 OR disk_reads > 1000000
    ORDER BY buffer_gets + 100 * disk_reads DESC;
    -- 最近10分钟最消耗CPU的SQL语句: 
    select sql_text 
    from (
            select sql_id,count(*) as cn
            from v$active_session_history 
            where sample_time > sysdate - 10/24/60 
                and session_type <> 'BACKGROUND'
                and SESSION_STATE = 'ON CPU'
            group by sql_id
            order by cn desc
        ) ash, v$sql s
    where ash.sql_id=s.sql_id;
    
    
    -- 最近10分钟最消耗IO的SQL语句:
    select sql_text 
    from (
            select sql_id,count(*) as cn
            from v$active_session_history 
            where sample_time > sysdate - 10/24/60 
                and session_type <> 'BACKGROUND'
                and WAIT_CLASS='User I/O'
            group by sql_id
            order by cn desc
        ) ash, v$sql s
    where ash.sql_id=s.sql_id;

    在plsql中查看SQL的执行计划时,我一般增加IO和CPU耗费两项。

    image

     

    在sqlplus等工具中,可以使用如下命令查看执行计划与IO

    --1
    explain plan for 
            select count(1) from emp a where a.dept_no=5;
    select * from table(dbms_xplan.display());
    
    --2
    set autotrace traceonly exp;
  • 相关阅读:
    [Linux]Vmwaer创建CENTOS7虚拟机[转]
    [游记]二访金陵
    [Android]ADB调试: SecurityException: Injecting to another application requires INJECT_EVENTS permission
    [操作系统]记一次未尽的三星 Galaxy A6s(SM-G6200)刷机过程
    [网络]NAT与内网穿透技术初探【待续】
    结构化系统建模之程序流程图|系统流程图|数据流图
    UML系统建模之用例视图
    [Linux]常用命令之【mkdir/touch/cp/rm/ls/mv】
    [Linux]监控外部用户登录及外部主机连接情况
    [Java SE]Unicode解码
  • 原文地址:https://www.cnblogs.com/zhaoguan_wang/p/4569234.html
Copyright © 2020-2023  润新知