zoukankan      html  css  js  c++  java
  • 集腋成裘-11-sql性能优化

    SQL Nexus是一个用于将SQL Trace数据、性能监视日志及T-SQL输出整合进一个单独的SQL Server数据库的工具。

    先决条件

    开始使用SQL Nexus之前,注意下面要做的事项:

    • 安装Microsoft Report Viewer for SQL Server 2016 MSI控件,以便使用工具自带的客户端报表查看整合的报告;
    • 安装Microsoft RML Utilities for SQL Server,以便SQL Nexus导入SQL Traces;
    • 安装Microsoft System CLR Types for SQL Server 2016;
    • 核实安装.NET Framework 4.7

    一:问题定位

    1:通过SQLserver自带的工具SQL Server Profiler

    2:选择要监控的事件

     

    3:导出执行的脚本,将任务置于后台执行,提高效率

    4:执行导出的脚本,目的是开启监控

    /****************************************************/
    /* Created by: SQL Server 2012  Profiler          */
    /* Date: 2019/01/16  21:18:17         */
    /****************************************************/
    
    
    -- Create a Queue
    declare @rc int
    declare @TraceID int
    declare @maxfilesize bigint
    set @maxfilesize = 5 
    
    -- Please replace the text InsertFileNameHere, with an appropriate
    -- filename prefixed by a path, e.g., c:MyFolderMyTrace. The .trc extension
    -- will be appended to the filename automatically. If you are writing from
    -- remote server to local drive, please use UNC path and make sure server has
    -- write access to your network share
    
    exec @rc = sp_trace_create @TraceID output, 0, N'd:alogTrace', @maxfilesize, NULL 
    if (@rc != 0) goto error
    
    -- Client side File and Table cannot be scripted
    
    -- Set the events
    declare @on bit
    set @on = 1
    exec sp_trace_setevent @TraceID, 10, 9, @on
    exec sp_trace_setevent @TraceID, 10, 2, @on
    exec sp_trace_setevent @TraceID, 10, 10, @on
    exec sp_trace_setevent @TraceID, 10, 6, @on
    exec sp_trace_setevent @TraceID, 10, 11, @on
    exec sp_trace_setevent @TraceID, 10, 12, @on
    exec sp_trace_setevent @TraceID, 10, 13, @on
    exec sp_trace_setevent @TraceID, 10, 14, @on
    exec sp_trace_setevent @TraceID, 10, 15, @on
    exec sp_trace_setevent @TraceID, 10, 16, @on
    exec sp_trace_setevent @TraceID, 10, 17, @on
    exec sp_trace_setevent @TraceID, 10, 18, @on
    exec sp_trace_setevent @TraceID, 12, 1, @on
    exec sp_trace_setevent @TraceID, 12, 9, @on
    exec sp_trace_setevent @TraceID, 12, 11, @on
    exec sp_trace_setevent @TraceID, 12, 6, @on
    exec sp_trace_setevent @TraceID, 12, 10, @on
    exec sp_trace_setevent @TraceID, 12, 12, @on
    exec sp_trace_setevent @TraceID, 12, 13, @on
    exec sp_trace_setevent @TraceID, 12, 14, @on
    exec sp_trace_setevent @TraceID, 12, 15, @on
    exec sp_trace_setevent @TraceID, 12, 16, @on
    exec sp_trace_setevent @TraceID, 12, 17, @on
    exec sp_trace_setevent @TraceID, 12, 18, @on
    exec sp_trace_setevent @TraceID, 13, 1, @on
    exec sp_trace_setevent @TraceID, 13, 9, @on
    exec sp_trace_setevent @TraceID, 13, 11, @on
    exec sp_trace_setevent @TraceID, 13, 6, @on
    exec sp_trace_setevent @TraceID, 13, 10, @on
    exec sp_trace_setevent @TraceID, 13, 12, @on
    exec sp_trace_setevent @TraceID, 13, 14, @on
    
    
    -- Set the Filters
    declare @intfilter int
    declare @bigintfilter bigint
    
    exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Server Profiler - 45caddf4-8520-4a3a-88c9-1afd4251fc0b'
    -- Set the trace status to start
    exec sp_trace_setstatus @TraceID, 1
    
    -- display trace id for future references
    select TraceID=@TraceID
    goto finish
    
    error: 
    select ErrorCode=@rc
    
    finish: 
    go
    开启监控(Trace)的脚本

    5:检查步骤4执行的效果。

    --查看所有的trace
    select * from sys.traces
    --设置trace的状态 0代表停止,1代表开启,2代表删除,第一个参数代表traceid
    --sp_trace_setstatus 2,0
    --go
    --sp_trace_setstatus 2,1
    --go
    --sp_trace_setstatus 2,2
    View Code

     二、使用sqlnexus统计数据

    1:连接服务器,为了方便把一中5的日志记录创建到该服务器的数据库

     2:导入文本

    3:主要看以下几个指标

     三、提取并且优化sql

    (1)sql语句参数化,或将其修改为存储过程。

     理由1:未参数化的sql除非每次执行的语句完全一致否则每一次执行都将会先去执行编译,下面将展示此过程

     --步骤1:在Manage studio当中打开统计功能
    SET STATISTICS IO ON --展示IO读写
    SET STATISTICS TIME ON --展示执行时间
    GO
    --步骤2:执行sql语句
    declare @P0001 nvarchar(124)
    set @P0001 = N'select  top 1 ID,UserId,IosToken,AndroidToken from IOS_UserToken  where AndroidToken=@AndroidToken or IosToken=@AndroidToken'
    declare @P0002 nvarchar(26)
    set @P0002 = N'@AndroidToken varchar(100)'
    declare @P0003 varchar(100)
    set @P0003 = 'f02b23dd0c59a143e979616b1023411f6f350cb814be7c30989e8987aadcd9c4'
    exec sp_executesql @P0001, @P0002, @AndroidToken = @P0003
    View Code

     四、临时紧急处理

    熔断:服务调用的一种雪崩现象,通过截断对依赖服务的调用来保证调用端的可用性。

    (1) 控制资源申请:控制cpu的消耗,既单个脚本占用cpu的核数,防止某一个长时间操作占用大量cpu。设置标准:qps高的情况下将cpu执行数往低设置,当qps低的情况下将cpu并行数据往高处设置,最高不要超过8。

    限流:通过限制对服务的调用访问来保证服务端的可用性。

    降级:通过放弃对非核心服务的调用,来保证核心服务的可用性。

    扩容:通过增加服务的数量来保证服务的可用性。

    五、查看数据库死锁问题(模板换一下)

  • 相关阅读:
    1257: [CQOI2007]余数之和
    BZOJ1036[ZJOI2008]树的统计——树链剖分+线段树
    BZOJ4822[Cqoi2017]老C的任务——树状数组(二维数点)
    BZOJ4196[Noi2015]软件包管理器——树链剖分+线段树
    BZOJ4034[HAOI2015]树上操作——树链剖分+线段树
    BZOJ5415[Noi2018]归程——kruskal重构树+倍增+堆优化dijkstra
    BZOJ2120&2453数颜色——线段树套平衡树(treap)+set/带修改莫队
    BZOJ2141排队——树状数组套权值线段树(带修改的主席树)
    初探莫比乌斯反演及欧拉反演
    BZOJ1146[CTSC2008]网络管理——出栈入栈序+树状数组套主席树
  • 原文地址:https://www.cnblogs.com/YK2012/p/10270560.html
Copyright © 2011-2022 走看看