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

作者:Ken Henderson 来源:Microsoft 时间:2010-04-25 10:52:00 

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


简介

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

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

因为几乎所有的SQLSERVER内存分配都是使用虚拟内存(而不是堆的方式),大部分的内存分配的代码分解到最后都是调有Win32的VirtualAlloVirtualFree 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.

 

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

标签:SQL,SERVER,2000,内存管理,数据库
0
投稿

猜你喜欢

  • asp如何做一个只能从本站点才能访问的页面?

    2010-07-12 19:00:00
  • dir()、readdir()、scandir()和glob()四种遍历目录方法及性能分析

    2023-05-25 11:18:27
  • 用户如何有效地利用ORACLE数据字典

    2008-03-04 18:19:00
  • 修改、删除数据记录(DELETE\\UPDATE)

    2009-02-27 15:50:00
  • JavaScript获取事件对象的注意点

    2009-07-29 18:36:00
  • ASP使用fso遍历文件及文件夹列出文件名

    2008-10-27 19:32:00
  • ASP XML编程objXML.async = False

    2011-04-21 10:55:00
  • ASP 写的判断 Money 各个位值的函数

    2008-04-13 06:36:00
  • 扩展数据库系统选项实现更高的可扩展性

    2009-01-06 11:14:00
  • 把网页中的电话号码生成图片的ASP程序

    2008-11-07 16:12:00
  • SQL 注入式攻击的终极防范

    2011-04-03 11:21:00
  • MYSQL教程:表达式操作符和数据类型转换

    2009-02-27 15:51:00
  • SQLServer 2008助你轻松编写T-SQL存储过程

    2010-12-06 13:38:00
  • 制作Dreamweaver活动菜单条

    2008-10-03 20:59:00
  • MySQL时间字段究竟使用INT还是DateTime

    2010-03-09 14:46:00
  • JavaScript 各种动画渐变效果

    2008-09-02 10:38:00
  • Asp的上下午时间格式问题

    2009-04-13 16:06:00
  • asp和php页面全面封杀WVS扫描器的代码

    2011-02-28 10:43:00
  • 网页设计应急小技巧

    2011-10-05 18:52:57
  • web2.0中流行的设计元素:颜色

    2007-12-10 12:16:00
  • asp之家 网络编程 m.aspxhome.com