SQL Server内存的管理方法

以下的文章主要向大家讲述的是SQL Server内存的管理,在默认的情况下,SQL Server 2000数据库其为了平衡运行在机器上得其他一些应用程序与数据库系统内部其他组建对内存的需要,实现对系统内存的动态分配和回收。

[[12625]]498)this.style.width=498;” />

在早前的版本如7.0,你通过选项配置给SQL Server设定一个大小固定的内存;然而。除非你有具体的问题要求分配大小规定的内存,否则***是让SQL Server动态管理内存。

无论内存是以动态还是固定的方式进行分配,计算机系统为每个SQL Server实例分配的总的内存空间都可看做一个单个统一的缓冲区(unified cache),这些内存都以多种内存池(memory pool)的方式进行管理。每个内存池有各自的策略和用途,系统中的各个内部组件可以请求和授权使用池中的内存。

缓冲区管理和内存池(The Buffer Manager an Memory Pools)

SQL Server内存组件是缓冲池(buffer pool)。任何不被其他内存相关组件使用的内存都放在缓冲池中。缓冲池负责从硬盘上加载数据和索引页以供用户访问和共享数据。当其他组件申请内存时,它们向缓冲池发送一个缓冲请求。内存缓冲由若干个页组成,其中每页大小与数据或索引页大小相同(8K)。

缓冲区管理器(The buffer Manager)

SQL Server的进程(process)只能访问内存中的数据或索引页。不允许直接访问磁盘上的页。缓冲区管理器(The buffer Manager)是一个用来管理和控制物理磁盘中的页在内存中的进程。当某个进程需要访问数据或索引页时,该页必须首先在缓冲区存在。

如果访问的页在内存中不存在,则必须进行一次物理I/O访问来加载该页,这样进程就可以访问该页在内从中的拷贝了。因为物理I/O的访问是非常昂贵和耗时的,所以尽可能减少系统的物理I/O。一种解决方案就是给SQL Server提供更多内存。越多的页驻留在内存,当某个页被访问时就越有可能在内存中找到该页。

内存缓冲区的访问(Accessing Memory Buffers)

对SQL Server中进程来讲,一个数据库就像带有编号页的简单序列。数据库中的页可以用数据库编号、文件编号、页的编号来唯一标识。当一个进程访问一个页时,它向缓冲管理器发送一个请求,该请求指出要访问数据所在的数据库编号、文件编号、和页编号。

为了更快地访问内存中的数据和避免数据页的SQL Server内存扫描(memory scans),对缓冲池的页进行散列处理,以提供更快地访问。散列(Hashing)是一种同过一个散列函数把一个key映射到一个散列桶(hansh bucket)的技术。散列桶是一种内存中的数据结构,该数据结构包含一个指针数组(以链表方式实现),每个指针指向一个缓冲页(buffer page)。

A linked list chain of hash pages is built when the pointers to buffer pages do not fit on a single hash page. 散列桶的数量是SQL Server根据缓冲池大小动态进行调整。

在SQL Server中,散列值是由数据库编号、文件编号、页编号相结合生成的。散列函数生成散列值并保存在散列桶中。本质来讲,散列桶就是访问内存页的一个索引。即使在一个大的内存环境中,散列技术可以允许SQL Server快速查找内存中的具体数据页而这需要一些内存读操作。

利用散列算法也让SQL Server快速判断某个请求的页是否在内存中,而不需要一个内存缓冲区的扫描。

如果被请求的页在内存中,缓冲区管理者返回一个指向SQL Server内存缓冲区的指针,该内存缓冲区即为该进程请求的数据页。如果页不在内存中,则缓冲区管理者必须首先进行一次磁盘I/O操作把请求页读到内存缓冲区中,然后把指向该内存的指针返回给发送请求的进程。

如果请求页的进程最终对页中的任何信息进行了修改,该页就被标记为“脏页(dirty)”,当进行完成了对页的修改,缓冲区管理者会收到一个通知。缓冲区管理者协同日志和事务管理者,负责确保被修改的页写到了磁盘上。

【编辑推荐】

  1. 创建SQL Server数据库更是实在
  2. 优化SQL Server数据库的经验大盘点
  3. SQL Server 2005商业智能功能浅析
  4. SQL Server 2000数据库备份和还原的示例
  5. SQL Server 2008数据库在实际应用中的独到之处

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/225678.html<

(0)
运维的头像运维
上一篇2025-04-17 00:35
下一篇 2025-04-17 00:36

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注