`
xiebh
  • 浏览: 606003 次
  • 性别: Icon_minigender_1
  • 来自: 太原
社区版块
存档分类
最新评论

SQL Server内存管理

阅读更多
默认情况下,SQL Server 2000为了平衡运行在机器上其他应用程序和数据库系统内部其他组建对内存的需要,实现对系统内存的动态分配和回收。在早前的版本如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中进程来讲,一个数据库就像带有编号页的简单序列。数据库中的页可以用数据库编号、文件编号、页的编号来唯一标识。当一个进程访问一个页时,它向缓冲管理器发送一个请求,该请求指出要访问数据所在的数据库编号、文件编号、和页编号。

为了更快地访问内存中的数据和避免数据页的内存扫描(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快速判断某个请求的页是否在内存中,而不需要一个内存缓冲区的扫描。

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

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








分享到:
评论
1 楼 破浪风 2009-10-15  
 

相关推荐

    sql server 内存管理

    sql server 内存管理,合理对sql server的内存进行管理

    sql内存管理机制

    从开发者的角度来阐述了SQL SERVER 2000内存管理的内部机制

    SQLServer对于内存的管理.pdf

    SQLServer对于内存的管理.pdf

    剑儿SQL Server内存释放器 V3.3

    由于Sql Server对于系统内存的管理策略是有多少占多少,除非系统内存不够用了(大约到剩余内存为4M左右),Sql Server才会释放一点点内存。所以很多时候,我们会发现运行Sql Server的系统内存往往居高不下。这些内存...

    SQL Server内存释放器 v3.3

    由于Sql Server对于系统内存的管理策略是有多少占多少,除非系统内存不够用了(大约到剩余内存为4M左右),Sql Server才会释放一点点内存。所以很多时候,我们会发现运行Sql Server的系统内存往往居高不下。这些内存...

    SQL Server的内存为何不断增加

    当SQL Server数据库引擎运行时,其默认内存管理行为并不是获取特定的内存量,而是在不产生多余换页I/O的情况下获取尽可能多的内存。为此,数据库引擎获取尽可能多的可用内存,同时保留足够的可用内存以防操作系统...

    SQL Server 2008管理员必备指南(超高清PDF)Part3

    《SQL Server 2008管理员必备指南》按照由浅入深的逻辑共分为4部分,即管理基础、系统管理、数据管理以及优化与维护。这种分类方法不仅从理论上环环相扣,全面介绍数据库管理人员需要掌握的相关理论知识和工作技能,...

    SQL SERVER 2000 内存扩展

    它为运行Windows Server2003x64 Edition的SQL Server2000用户在64位计算架构上运行32位的SQLServer应用软件扫清了障碍。  这名代表指出,SP4是一款补丁软件包,主要解决安全性、性能、适用性问题。她说,除了补丁...

    SQL_Server_2008_R2_CPU_和_内存_最大优化_分配

    利用资源控制器,在SQL Server 2008 R2中解决方案供应商有切实可用的方法管理CPU和内存。  资源消耗是长期以来困扰使用SQL Server的解决方案供应商的基本问题之一。任何服务器,不管它是物理的还是虚拟的,供处置的...

    剑儿SQL Server内存释放器1.0

    由于Sql Server对于系统内存的管理策略是有多少占多少,除非系统内存不够用了(大约到剩余内存为4M左右),Sql Server才会释放一点点内存。所以很多时候,我们会发现运行Sql Server的系统内存往往居高不下。这些内存...

    SQLServer2008查询性能优化 2/2

    2.4.1 SQL Server内存管理 20 2.4.2 Available Bytes 23 2.4.3 Pages/sec和Page Faults/sec计数器 23 2.4.4 Buffer Cache Hit Ratio 24 2.4.5 Page Life Expectancy 24 2.4.6 Checkpoint Pages/sec 24 2.4.7 ...

    如何解决SQL Server虚拟内存不足情况

    在拥有大量数据库的系统上,日志格式化所需的 64 KB 分配可能会占用...通过使用-g启动参数,您可以指示SQL Server保留附加的虚拟内存可用,以便这些与日志相关的分配和其他正常分配加在一起也不会用完虚拟地址空间。

    SQLServer2008查询性能优化 1/2

    2.4.1 SQL Server内存管理 20 2.4.2 Available Bytes 23 2.4.3 Pages/sec和Page Faults/sec计数器 23 2.4.4 Buffer Cache Hit Ratio 24 2.4.5 Page Life Expectancy 24 2.4.6 Checkpoint Pages/sec 24 2.4.7 ...

    SQL Server 2008管理员必备指南(超高清PDF)Part1

    《SQL Server 2008管理员必备指南》按照由浅入深的逻辑共分为4部分,即管理基础、系统管理、数据管理以及优化与维护。这种分类方法不仅从理论上环环相扣,全面介绍数据库管理人员需要掌握的相关理论知识和工作技能,...

    剑儿SQL Server内存释放器 v3.3.zip

    大家都知道 sql的使用时间越长.其占用的内存数就越大.由于Sql Server对于系统内存的管理策略是有多少占多少,除非系统内存不够用了(大约到... 剑儿SQL Server内存释放器 v3.2更新内容: 修正了会员反馈的一些小错误。

    SQL Server 2008管理员必备指南(超高清PDF)Part2

    《SQL Server 2008管理员必备指南》按照由浅入深的逻辑共分为4部分,即管理基础、系统管理、数据管理以及优化与维护。这种分类方法不仅从理论上环环相扣,全面介绍数据库管理人员需要掌握的相关理论知识和工作技能,...

    监控 SQL Server 的运行状况

    Microsoft SQL Server 2005 提供了一些工具来监控数据库,包括动态管理视图(DMV)和动态管理函数(DMF)。这些工具返回的服务器状态信息可用于监控服务器实例的运行状况、诊断问题和优化性能。 动态管理视图(DMV...

    SQL server 2000使用4G以上的内存

    在安装了Windows Server 2003 32位企业版,安装了SQL Server 2000 SP4企业版。发现SQLServer.exe只使用了1.7G内存,介绍使用到4G以上内存设置方法。

    SqlServer常用管理语句

    常用Sqlserver管理语句 1.调整内存 2.关闭启用xp_cmdshell 3.收缩数据库 4.还原数据库 5.创建赋权超级帐户 6.启动停止服务 7. 设置解除独占模式 8. 链接服务器 9. 查詢數據庫聯接數

    SQLServer内存问题排查思路.docx

    对大神的SQLServer内存问题排查进行了初步整理,通过性能监视器计数与动态管理视图对SQLServer内存问题进行排查处置。

Global site tag (gtag.js) - Google Analytics