深入SQL SERVER 2000的内存管理机制(2)
作者:Ken Henderson 来源:Microsoft 发布时间:2010-04-25 10:52:00
程序内存空间调整
在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参数还是可以单独使用的
可访问大地址的应用 (Large-Address-Aware Executables)
在Windows增加支持/3GB参数以前,一个应用程序是无法访问一个带有高位设置的指针.一个32位的指针只有前31位地址空间可以被用户模式的应用程序访问.这剩余的一位不用.因此有一些聪明的开发者因为其他的目的不愿意在处理内存地址空间时浪费这一位.(举例来说:可以用来标志一个指针引用其它应用程序分配的数据类型).这样就/3GB参数就遇到一个难题,因为这种类型的程序不能方便的区分一个合法的指针引用的内存空间在2G的分界线以上与一个内存地址空间在2G以下,但它的高位已经被用做它用的指针.基本上如果一台机器用/3GB的参数启动,这种应用程序是无法运行的.为解决这种状况,微软在WIN32的PE文件Characteristics字段增加了一个新的标志位来表示一个程序是否运行在可访问大地址的(Large-Address-Aware Executables)模式.当该标志位被起用( IMAGE_FILE_LARGE_ADDRESS_AWARE ),该可执行文件头部Characteristics字段的32位被置位.通过这个可执行文件头部的标志位,应用程序可以暗示WINDOWS 它可以处理带有高位设置的指针,这样就不会带来任何异常结果.当该标志被置位并且支持这种方式启动的Windows也是通过/3GB的参数启动,这时操作系统会提供一直扩展的私有用户模式的地址空间给应用程序.你可以通过工具,比如: DumpBin 和 ImageCfg (转储可执行文件的头部)来检查一个可执行文件的该标志位.Visual C++ 通过 /LARGEADDRESSAWARE 连接器开关来表示IMAGE_FILE_LARGE_ADDRESS_AWARE,SQL SERVR已经将该标志位激活,所以你可以在支持/3GB参数的Windows 版本中使用该参数,这样操作系统回自动扩展SQL SERVER的用户内存空间.
注释:Windows在可执行文件启动时检查IMAGE_FILE_LARGE_ADDRESS_AWARE 标志位,但忽略DLL文件.DLL代码必须自动处理高位被置位的指针。
物理内存扩展
Intel 处理器自从Pentium PRO开始,以后的处理器都支持一种物理内存扩展(PAE)的内存映射模式。PAE模式提供了可以访问64GB的物理内存空间。在PAE模式中,内存管理单元(Memory Management Unit (MMU))仍然执行:页目录入口page directory entries(PDEs) 和页表入口page table entries (PTEs),但是在此之上有一个新的级别:页目录指针表。同时,在PAE模式PDEs 和PTEs是64位的(不仅仅是标准的32位),这样系统可以映射比标准转换更多的内存空间,因为PDEs 和PTEs模式的寻址宽度是标准的2倍。这并不仅仅是增加了页目录指针表。页目录指针表被用来管理这些大容量表和索引。一些特殊版本的Windows内核需要运行在PAE模式。这中内核集成在Windows 2000以及以后的版本中,在单处理器的机器中体现在Ntkrnlpa.exe文件中,在多处理器的机器中体现在Ntkrnlpamp.exe文件中。你可以向增加/3GB和/USERVA参数一样在BOOT.INI文件中加/PAE参数激活PAE模式。
猜你喜欢
- 虽然我只是把豆瓣当作一个纪录工具来用,纪录下自己看过的电影、听过的音乐、读过的书籍,我几乎不关注豆瓣上的任何影评、乐评、音衣服之类的内容,但
- Dreamweaver一直是不少网友钟情的网页设计工具,除了它强大的动态效果制作能力外,方便简洁的操作界面更是独具特色,下面我们将以最新版本
- Update 语句Update 语句用于修改表中的数据。语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值P
- 相比SQL Server 2000提供的FOR XML查询,SQL Server 2005版本对现有功能增强的基础上增加了不少新功能,最为吸
- 假设在搜索框search中输入:“asp 编程” 先得到输入框中的内容:search=request("search")
- 在使用ORACLE的过程过,我们会经常遇到一些ORACLE产生的错误,对于初学者而言,这些错误可能有点模糊,而且可能一时不知怎么去处理产生的
- 1.建立Recordset对象 代码如下:Dim objMyRst Set objMyRst=Server.C
- 在Flash播放器运行时,将不同来源的资源划分到独立的沙箱(sandbox)内,不同沙箱之间不能彼此操作数据(除非目标沙箱做过一些设置,授权
- 数据挖掘查询任务根据 Analysis Services 内置的数据挖掘模型运行预测查询。预测查询通过使用挖掘模型来创建对新数据的预测。例如
- 代码如下:<% '=================================================
- 大家都在关注视觉的盛宴,西方的美学;今天就分享下,中国最为古老的美,也是身边随处可见的美学–中国汉字书法之美;古文者,仓颉做造也。仰观奎星园
- Filed under 数据库技术Leave a commentSQL Server命令行导数据两种方式bcp和sqlcmd先说一下bcp:
- 临近下班的时候,突然想到统计热门文章的问题。以前我所知道的热门文章统计,基本有这么几种:按点击数排序 该方法最大的问题在于热门的文章会越来越
- 有关 Web 字体的话题正在增多,对 Web 设计师来说,他们并不关注技术细节,不管是 TrueType 的 Hinting 技术
- 想必大家都很喜欢用Word打字,用Excel进行计算和规划,用PowerPoint作幻灯片进行展示…,但是这只用到了Office系列产品的很
- // 格式化字符串 Fmt("{0}.[{id}].{name}",{id:1,name:'
- //设置已存在表中字段为auto_incrementALTER TABLE tablename change id id int(2) no
- 代码如下:<form action="insert.asp" method="pos
- aspImage是ServerObjects站点上非常好的一个组件,它可以使我们利用Asp实现很多对于图形的处理功能,他的功能强大,如果你需
- 下表列出 SQL Server 查询分析器提供的所有键盘快捷方式。活动 快捷方式 书签:清除所有书签。 CTRL-SHIFT-F2