iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >如何进行sql server性能调优 I/O开销的深入解析
  • 785
分享到

如何进行sql server性能调优 I/O开销的深入解析

2024-04-02 19:04:59 785人浏览 薄情痞子
摘要

今天就跟大家聊聊有关如何进行SQL Server性能调优 I/O开销的深入解析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一.概述io 内存是sq

今天就跟大家聊聊有关如何进行SQL Server性能调优 I/O开销的深入解析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

一.概述

io 内存是sql server最重要的资源,数据从磁盘加载到内存,再从内存中缓存,输出到应用端,在sql server 内存初探中有介绍。在明白了sqlserver内存原理后,就能更好的分析I/O开销,从而提升数据库的整体性能。 在生产环境下数据库的sqlserver服务启动后一个星期,就可以通过dmv来分析优化。在I/O分析这块可以从物理I/O和内存I/O二方面来分析, 重点分析应在内存I/O上,可能从多个维度来分析,比如从sql server服务启动以来 历史I/O开销总量分析,自执行计划编译以来执行次数总量分析,平均I/0次数分析等。

sys.dm_exec_query_stats:返回缓存的查询计划,缓存计划中的每个查询语句在该视图中对应一行。当sql server工作负载过重时,该dmv也有可以统计不正确。如果sql server服务重启缓存的数据将会清掉。这个dmv包括了太多的信息像内存扫描数,内存空间数,cpu耗时等,具体查看msdn文档。

sys.dm_exec_sql_text:返回的 SQL 文本批处理,它是由指定sql_handle,其中的text列是查询的文本。

1.1 按照物理读的页面数排序 前50名

SELECT TOP 50 qs.total_physical_reads,qs.execution_count, qs.total_physical_reads/qs.execution_count AS [avg I/O], qs. creation_time, qs.max_elapsed_time, qs.min_elapsed_time, SUBSTRING(Qt.text,qs.statement_start_offset/2, (CASE WHEN qs.statement_end_offset=-1 THEN LEN(CONVERT(NVARCHAR(max),qt.text))*2 ELSE qs.statement_end_offset END -qs.statement_start_offset)/2) AS query_text, qt.dbid,dbname=DB_NAME(qt.dbid), qt.objectid, qs.sql_handle, qs.plan_handle from sys.dm_exec_query_stats qs CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt ORDER BY qs.total_physical_reads DESC

如下图所示:

  total_physical_reads:计划自编译后在执行期间所执行的物理读取总次数。

  execution_count :计划自上次编译以来所执行的次数。

  [avg I/O]: 平均读取的物理次数(页数)。

  creation_time:编译计划的时间。

query_text:执行计划对应的sql脚本

后面来包括所在的数据库ID:dbid,数据库名称:dbname

1.2 按照逻辑读的页面数排序 前50名

SELECT TOP 50 qs.total_logical_reads, qs.execution_count, qs.max_elapsed_time, qs.min_elapsed_time, qs.total_logical_reads/qs.execution_count AS [AVG IO], SUBSTRING(qt.text,qs.statement_start_offset/2, (CASE WHEN qs.statement_end_offset=-1  THEN LEN(CONVERT(NVARCHAR(max),qt.text)) *2 ELSE qs.statement_end_offset END -qs.statement_start_offset)/2)  AS query_text, qt.dbid, dbname=DB_NAME(qt.dbid), qt.objectid, qs.sql_handle, creation_time, qs.plan_handle from sys.dm_exec_query_stats qs CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt ORDER BY qs.total_logical_reads DESC

如下图所示:

通过上面的逻辑内存截图来简要分析下:

  从内存扫描总量上看最多的是8311268次页扫描,自执行编译后运行t-sql脚本358次,这里的耗时是毫秒为单位包括最大耗时和最小耗时,平均I/O是232115次(页),该语句文本是一个update 修改,该表数据量大没有完全走索引(权衡后不对该语句做索引覆盖),但执行次数少,且每次执行时间是非工作时间,虽然扫描开销大,但没有影响白天客户使用。

  从执行次数是有一个43188次, 内存扫描总量排名39位。该语句虽然只有815条,但执行次数很多,如里服务器有压力可以优化,一般是该语句没有走索引。把文本拿出来如下

SELECT Count(*) AS TotalCount FROM [MEM_FlagshipApply] WITH(NOLOCK) Where (((([Status] = 2) AND ([IsDeleted] = 1)) AND ([MemType] = 0)) AND ([MEMID] <> 6))

下面两图一个是分析该语句的执行计划,sqlserver提示缺少索引,另一个是i/o统计扫描了80次。

新建索引后在来看看

 CREATE NONCLUSTERED INDEX ix_1ON [dbo].[MEM_FlagshipApply] ([Status],[IsDeleted],[MemType],[MEMID])

看完上述内容,你们对如何进行sql server性能调优 I/O开销的深入解析有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网数据库频道,感谢大家的支持。

您可能感兴趣的文档:

--结束END--

本文标题: 如何进行sql server性能调优 I/O开销的深入解析

本文链接: https://www.lsjlt.com/news/68890.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何进行sql server性能调优 I/O开销的深入解析
    今天就跟大家聊聊有关如何进行sql server性能调优 I/O开销的深入解析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一.概述IO 内存是sq...
    99+
    2024-04-02
  • sql server性能调优 I/O开销的示例分析
    这篇文章主要介绍sql server性能调优 I/O开销的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.概述IO 内存是sql server最重要的资源,数据从磁盘加载到...
    99+
    2024-04-02
  • 如何进行C++代码的性能调优?
    如何进行C++代码的性能调优C++作为一种高性能的编程语言,被广泛运用在许多性能要求较高的领域,如游戏开发、嵌入式系统等。然而,在编写C++程序时,我们常常会面临性能瓶颈的挑战。为了提高程序的运行效率和响应时间,我们需要进行代码的性能调优。...
    99+
    2023-11-02
    C++ 性能调优 代码调优
  • Golang开发建议:如何进行有效的性能调优
    在Golang开发中,性能调优是非常重要的一个方面。无论你是在开发一个Web应用、一个分布式系统还是一个底层工具,提高Golang程序的性能需要进行有效的性能调优,这将直接影响到应用的响应速度和稳定性。本文将向你介绍一些关于Golang性能...
    99+
    2023-11-23
    Golang性能调优 有效性能优化 Golang开发建议
  • 如何理解SQL Server SQL性能优化中的参数化
    如何理解SQL Server SQL性能优化中的参数化,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。数据库参数化的模式数据库的...
    99+
    2024-04-02
  • Golang开发建议:如何进行高效的性能调优和优化
    Golang开发建议:如何进行高效的性能调优和优化随着互联网和大数据时代的到来,软件的性能要求也越来越高。作为一种快速、高效、并发性好的编程语言,Golang在构建高性能应用程序方面表现出色。然而,即使使用了Golang,也不意味着就能够轻...
    99+
    2023-11-22
    优化 Golang 性能调优
  • 如何使用MySQL进行日志分析和性能调优?
    如何使用MySQL进行日志分析和性能调优?导语:MySQL是一种常见且强大的关系型数据库管理系统,被广泛应用于各种网站和应用程序中。本文将介绍如何使用MySQL的日志功能进行分析,并提供一些性能调优的方法和示例代码。一、MySQL的日志功能...
    99+
    2023-10-22
    MySQL 性能调优 日志分析
  • 如何解析MySQL性能优化中的SQL优化
    如何解析MySQL性能优化中的SQL优化,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注:以 MySQL 为背景,很多内容同时适用于其他关系型...
    99+
    2024-04-02
  • web性能优化中如何进行no-cache与must-revalidate深入探究
    这期内容当中小编将会给大家带来有关web性能优化中如何进行no-cache与must-revalidate深入探究,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。引言稍微了...
    99+
    2024-04-02
  • 如何进行JSONP跨域请求原理的深入解析
    这篇文章将为大家详细讲解有关如何进行JSONP跨域请求原理的深入解析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是同源策略同源策略,它是由Netscape提出的一个著名的安全策略。现在...
    99+
    2023-06-26
  • 如何进行生产数据库性能优化的分析
    这期内容当中小编将会给大家带来有关如何进行生产数据库性能优化的分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。需求:在钉钉群个人简介页面需要显示钉钉群名称和简介,每个群...
    99+
    2024-04-02
  • C++开发建议:如何进行C++代码的性能分析
    作为一名C++开发人员,性能优化是我们不可避免的任务之一。为了提高代码的执行效率和响应速度,我们需要了解C++代码的性能分析方法,以便更好地调试和优化代码。在本文中,我们将为您介绍一些常用的C++代码性能分析工具和技术。编译选项C++编译器...
    99+
    2023-11-22
    性能分析 C++代码 开发建议
  • Python开发经验分享:如何进行有效的性能优化
    Python开发经验分享:如何进行有效的性能优化引言:随着Python在开发领域的广泛应用,越来越多的开发者开始面临性能优化的挑战。在许多情况下,提高代码的执行效率是实现更好用户体验、更高并发处理能力和更低成本的关键所在。本文将分享一些有效...
    99+
    2023-11-22
    性能优化 Python开发 效果有效
  • Golang开发经验分享:如何进行高效的性能分析
    随着计算机技术的不断发展,性能已成为了软件开发中重要的指标之一。而在Golang开发过程中,性能也是一个非常重要的方面。为了保证程序的高效率运行,必须进行性能分析和优化。下面就为大家分享一下如何进行高效的性能分析。1.基本概念在进行性能分析...
    99+
    2023-11-23
    Golang 性能分析 开发经验
  • Go 开发者必知:如何在 Linux 中进行缓存调优来提升应用性能?
    Go 是一种高效且易于使用的编程语言,它已经成为了许多开发人员的首选。在 Linux 环境下,缓存调优是一项非常重要的任务,可以帮助我们提升应用程序的性能。在本文中,我们将介绍如何在 Linux 中进行缓存调优,以提高 Go 应用程序的性能...
    99+
    2023-06-13
    面试 缓存 linux
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作