AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 8234
Accepted
Jeff Leonard
Jeff Leonard
Asked: 2009-05-15 07:22:55 +0800 CST2009-05-15 07:22:55 +0800 CST 2009-05-15 07:22:55 +0800 CST

我如何知道何时对我的 SQLServer 数据库进行碎片整理?

  • 772

测量 SQLServer 数据库碎片/性能下降和确定何时对 SQLServer 数据库表进行碎片整理的最佳实践是什么?

我最感兴趣的是了解有用的指标是什么以及应该触发碎片整理的性能下降程度。

sql-server optimization defrag
  • 1 1 个回答
  • 1201 Views

1 个回答

  • Voted
  1. Best Answer
    Paul Randal
    2009-05-15T08:32:10+08:002009-05-15T08:32:10+08:00

    我相信对此会有一些有趣的答案,因为对于要查看的指标存在很多分歧。我编写了 DBCC INDEXDEFRAG、SHOWCONTIG 并为 2005 年设计了它们的替代品,另外还编写了 Books Online 内容,所以我将给出我的观点,并解释我选择的 Books Online 中的数字和 2005 年维护计划向导。

    查看索引碎片的两个最佳指标是:1) (2005) 平均碎片百分比 / (2000) 逻辑扫描碎片 2) (2005) 平均页面密度 / (2000) 每页平均可用字节数

    这些同样适用于聚集索引和非聚集索引。

    1 是衡量有多少逻辑碎片。这是当索引的叶级页面的逻辑顺序与物理顺序不匹配时。这可以防止存储引擎在范围扫描期间进行有效的预读。所以#1 影响范围扫描性能,而不是单例查找性能。

    2 在索引的叶级别测量每个页面上浪费了多少空间。浪费的空间意味着您使用更多的页面来存储记录,这意味着更多的磁盘空间来存储索引,更多的 IO 来读取索引,以及更多的内存来保存缓冲池中内存中的页面。

    门槛?我的一般经验法则是碎片少于 10%,什么都不做。10-30%,做一个 ALTER INDEX ... REORGANIZE (2005) / DBCC INDEXDEFRAG (2000)。超过 30%,执行 ALTER INDEX ... REBUILD (2005) / DBCC DBREINDEX (2000)。这些是完整的概括,您的阈值会有所不同。

    要找到您的阈值,请针对碎片级别对工作负载性能进行一些跟踪,并确定何时性能下降过多。那时你需要解决碎片问题。在碎片化生活和消除碎片化资源之间存在平衡。

    我在这里没有谈到消除碎片的两种方法之间的权衡,例如 FILLFACTOR/PADINDEX 试图减轻碎片并减少碎片整理,更改架构/访问模式以减轻碎片,或不同类型的维护计划.

    哦,顺便说一句,我总是建议不要担心少于 1000 页的索引中的碎片。这是因为索引可能主要驻留在内存中(并且因为人们要求一个数字,而我必须想出一个)。

    您可以在我的 TechNet 杂志关于数据库维护的文章中阅读更多信息,网址为http://technet.microsoft.com/en-us/magazine/cc671165.aspx,在我帮助编写的关于索引碎片整理最佳实践的 2000 年白皮书中http://technet.microsoft.com/en-us/library/cc966523.aspx和我的博客上的碎片类别下http://www.sqlskills.com/BLOGS/PAUL/category/Fragmentation.aspx。

    我想我有点过度回答了,但这是我的热门按钮之一。希望这可以帮助 :-)

    • 22

相关问题

  • 上线的第一天:如何不杀死您的网站

  • IIS 优化

  • Vanilla Powershell 是否足以成为 Windows 和 DB 服务器管理员的语言?

  • 在 SQL Server 中,何时应将 PRIMARY Data FileGroup 拆分为辅助数据文件?

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve