分享
 
 
 

深入SQL SERVER 2000的内存管理机制(一)

王朝mssql·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

深入SQL SERVER 2000的内存管理机制

http://msdn.microsoft.com/data/default.aspx?pull=/library/en-us/dnsqldev/html/sqldev_01262004.asp

Ken Henderson

Microsoft Corporation

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

简介

在本专栏中,我们将从一个开发者的角度来探索SQL SERVER 的内存管理。因此我们将讨论服务器内存管理的API和操作系统的内存管理机制,他们是如何运行的? 以这种新颖的方式来探讨SQL SERVER内存管理,可以使开发人员明白其中的前因后果,精通一个产品,我们要了解它内部是如何运行和特定的用途。

我们首先开始的研究,它包括一些Windows内存管理的基本原理。和所有的32位的Windows程序一样,SQL SERVER也是使用Windows的内存管理机制来分配、释放和通用的内存管理资源。也就是说,SQLSERVER和其他Windows程序一样通过WIN32 API函数和操作系统提供的内存管理资源交互。

因为几乎所有的SQLSERVER内存分配都是使用虚拟内存(而不是堆的方式),大部分的内存分配的代码分解到最后都是调有Win32的VirtualAllo 和VirtualFree API函数。SQL SERVER通过调用VirtualAllo函数来预留和提交虚拟内存,通过VirtualFree函数来释放内存。

虚拟内存和物理内存

在X86处理器的系列中,Windows提供所有的程序可以寻址4GB虚拟内存空间。所谓“虚拟”的意思是,这并不是传统意义上的内存,它仅仅是一段没有物理存储的隐式地址段。因为只有一个程序开始内存分配,才开始使用这些地址段和物理的分配存储空间。而且,这些物理的存储空间并不需要物理的内存(不完全),通常是磁盘空间。明确的说应该是在系统的虚拟页文件中。这就是为什么有许多程序(每个程序有4GB的虚拟内存空间)可以同时运行在只有128M的物理内存的机器上,就像每个程序自己分配真实的内存一样。Windows透明地控制从系统页文件拷贝和读取数据,因此程序可以在运行的机器上分配比物理内存更多的内存空间并且各种程序可以均等的访问该机器物理内存。

4GB的内存地址空间分为2块:用户内存空间和核心内存空间。默认每个容量为2G,你可以通过Windows NT 系列操作系统的BOOT.INI文件来改变默认空间的大小(比如:Windows NT,Windows 2000,Windows XP 和Windows Server 2003都是Windows NT 系列的产品,Windows 9x 和 Windows ME不是的)。

Figure 1. Windows partitions a process's virtual address space into the user mode (application) and kernel mode (operating system) partitions.

尽管每一个程序接受自己的虚拟内存空间,系统代码和设备驱动代码共享一个单独私有的虚拟地址空间。每个虚拟内存页都和一种特殊处理器模式关联。为了满足所有的系统页都可以被访问,处理器必须是请求模式。这个意思是说用户的程序是无法直接访问核心内存空间,系统必须切换为核心模式,这样核心模式的内存空间才可以被访问。

程序内存空间调整

在BOOT.INI文件中有一个/3GB的参数可以允许改变默认的限制(这个参数在Windows advanced server和 Windows 2000 Data Center有效),这样可以通过牺牲核心内存空间(从2G降低到1G)将用户应用程序的内存空间从2G增加到3G.在Windows的用法中,这种机制叫程序内存空间调整或叫4GT调整(4GT).你可以通过在BOOT.INI文件的[operating systems]区域的适当的行加/3GB参数来调整应用程序的内存空间.对一般的人来说可以选择配置BOOT.INI文件的[operating systems]区域的适当的行增加/3GB或不加/3GB参数来启动系统.

警告:你也可以在Windows 2000 Professional和Windows 2000 的启动文件中加/3GB的参数来启动系统,可是这样只是减少了核心内存空间到1GB但并没有增加应用程序内存空间.换句话说,这样做并没有从降低核心内存空间获得益处

注释:在WindowsXP和Windows Server 2003中提供一个新的启动参数/USERVA,可以和/3GB参数一样使用,但允许你有更加出色的控制度.你可以象/3GB 一样将/USERVA参数到BOOT.INI文件中. /USERVA参数比/3GB的优势在于,它可以允许你指定内存地址空间分配给应用程序的大小.比如: /USERVA=2500 的意思就是配置2.5G的内存地址空间预留给用户内存空间,1.5G的留给核心内存空间.特别说明/3GB参数还是可以单独使用的.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有