Buffer Pool--内存总结1
物理地址空间是处理器用来访问位于总线上的所有部件的集合。
在32位处理器上,地址总线为32位,寻址空间为4GB。
在使用PAE的32位服务器上,地址总线为36位,寻址空间为64GB。
在64位的处理器上生产商将地址总线限制为44位,寻址空间为2TB。
在32位系统上,系统中运行的每个进程有共计4GB的虚拟地址空间(VAS),用来存放应用程序所使用的程序代码和数据。4GB的VAS由内核模式和用户模式共享,用户模式地址空间和内核模式地址空间各占2GB,如果激活/3GB或者/USERUA选项后,用户模式地址空间占3GB。
在X64系统上,系统为进程分配8TB的VAS
在IA64系统上,系统为进程分配7TB的VAS
不同的操作系统版本,所支持的最大物理内存不一样。
虚拟地址空间只是虚拟内存,不是物理内存,而且它只是空间,不是实际内存。
虚拟内存管理器(Virtual Memory Manager VMM)负责所有的物理内存,将物理内存在所有需要内存的进程间共享,当进程请求内存或者需要加载数据是,OS接受请求,将进程中一块虚拟内存空间和实际物理内存相互关联起来。
虚拟内存管理器可以将内存中数据取走并存放到页面文件中,直到进程试图访问该段数据时重新将数据从页面中加载到物理内存中并完成虚拟内存和物理内存之间的映射。
如果进程再次使用数据而数据需要从页面文件中重新载入,该操作被称为Hard page Fault(硬页面错误)
当物理内存缺乏而多个进程争用有限内存时,会导致数据频繁地从物理内存中换入和换出,从而导致系统响应速度变慢,性能下降。
通过修改Boot.ini文件来打开/3GB选项或/UserVA选项。
/UserVA选项是Windows Server 2003中新增加的。
当/3GB选项被打开时,操作系统会受限于最多使用16GB的物理内存,故如果服务器拥有16GB或更多内存时,不要使用3GB选项
PAE--physical Address Extensions
PAE是Intel引入一种突破32位地址总线的方式,将地址总线物理扩展到36位,从而允许32位操作系统最多使用64GB内存。
在Datacentrt版本的OS中,如果硬件允许热内存交换,即使不在Boot.ini文件中激活PAE,仍然会运行PAE内核
在拥有多于4GB的服务器上,则激活PAE选项。
AWE--Address Windowing Extensions
AWE是一位Windows API,允许32位进程映射其虚拟地址空间以外的内存,使得进程可以使用物理内存来存储数据,但是在使用数据时,必须将它映射到进程中的VAS中。AWE的思想类似于Windows中的页面文件,由于AWE中的数据存放在内存中,内存到内存的数据传递更快。
Enable AWE option for SQL SERVER
1.Use sp_configure to set the value as 1 for the option 'awe enabled'
2.Grant the right of 'Lock Page in Memory' to the service account.
To enable AWE
exec sp_configure 'show advanced options', 1
RECONFIGURE
exec sp_configure 'awe enabled', 1
RECONFIGURE
To enable the lock pages in memory option
1.On the Start menu, click Run. In the Open box, type gpedit.msc. The Group Policy dialog box opens.
2.On the Group Policy console, expand Computer Configuration, and then expand Windows Settings.
3.Expand Security Settings, and then expand Local Policies.
4.Select the User Rights Assignment folder.
The policies will be displayed in the details pane.
5.In the pane, double-click Lock pages in memory.
6.In the Local Security Policy Setting dialog box, click Add.
7.In the Select Users or Groups dialog box, add an account with privileges to run sqlservr.exe.
User could not set AWE option on 64-Bit SQL Server, but if the service account have the right of 'Lock Pages in Memory', SQL Server will use AWE to access buffer pool memory automaticlly.
即使在64位系统上,SQL SERVER依然可以通过AWE来提升性能。
Buffer Pool--内存总结1的更多相关文章
- 14.6.3.3 Making the Buffer Pool Scan Resistant
14.6.3.3 Making the Buffer Pool Scan Resistant 相比使用一个严格的LRU算法,InnoDB 使用一个技术来最小化数据总量 带入到buffer pool 而 ...
- 谁占用了我的Buffer Pool
原文:谁占用了我的Buffer Pool 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/11/buffer-pool.aspx 我在做SQL S ...
- MySQL · 引擎特性 · InnoDB Buffer Pool
前言 用户对数据库的最基本要求就是能高效的读取和存储数据,但是读写数据都涉及到与低速的设备交互,为了弥补两者之间的速度差异,所有数据库都有缓存池,用来管理相应的数据页,提高数据库的效率,当然也因为引入 ...
- 谁占用了我的Buffer Pool?--【转】
转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/11/buffer-pool.aspx 我在做SQL Server 7.0技术支持的时候有客户问我 ...
- 查看Buffer Pool使用情况--[转]
----源自:微软官方博客论坛 我的SQL Server buffer pool很大,有办法知道是哪些对象吃掉我的buffer Pool内存么?比方说,能否知道是哪个数据库,哪个表,哪个index占用 ...
- InnoDB缓存---InnoDB Buffer Pool
InnoDB Buffer Pool 定义 对于InnoDB存储引擎,不管用户数据还是系统数据都是以页的形式存储在表空间进行管理的,其实都是存储在磁盘上的. 当InnoDB处理客户端请求,需要读取某页 ...
- 【大白话系统】MySQL 学习总结 之 缓冲池(Buffer Pool) 如何支撑高并发和动态调整
如果大家对我的 [大白话系列]MySQL 学习总结系列 感兴趣的话,可以点击关注一波. 一.上节回顾 在上节< 缓冲池(Buffer Pool) 的设计原理和管理机制>中,介绍了缓冲池整体 ...
- 【MySQL】InnoDB 内存管理机制 --- Buffer Pool
InnoDB Buffer Pool 是一块连续的内存,用来存储访问过的数据页面 innodb_buffer_pool_size 参数用来定义 innodb 的 buffer pool 的大小 是 M ...
- SQL Server 2014新特性探秘(2)-SSD Buffer Pool Extension
简介 SQL Server 2014中另一个非常好的功能是,可以将SSD虚拟成内存的一部分,来供SQL Server数据页缓冲区使用.通过使用SSD来扩展Buffer-Pool,可以使得大量随 ...
- 理解innodb buffer pool
今天组里有个同事说可以查看innodb buffer pool每个表和索引占的大小,为此我搜了下,还真有方法,记录下. innodb buffer pool有几个目的: 缓存数据--众所周知,这个占了 ...
随机推荐
- [译]作为一个web开发人员,哪些技术细节是在发布站点前你需要考虑到的
前日在cnblogs上看到一遍文章<每个程序员都必读的12篇文章>,其中大多数是E文的. 先译其中一篇web相关的”每个程序员必知之WEB开发”. 原文: http://programme ...
- OpenMP 旅行商问题,静态调度
▶ <并行程序设计导论>第六章中讨论了旅行商,分别使用了 MPI,Pthreads,OpenMP 来进行实现,这里是 OpenMP 的代码,分为静态调度(每个线程分分配等量的搜索人物)和动 ...
- react之echarts数据更新
react之echarts数据更新 在使用setState更新数据时,如果要将图标更新,需要做一些简单的封装,代码如下: import React, { Component } from 'react ...
- VB.Net条形码编程的方法
一.条形码的读取用过键盘口式的扫条码工具的朋友就知道,它就如同在鍵盘上按下数字鍵一样,基本不需任何编程和处理.但如果你使用的是其它接口的话,可能你就要为该设备编写通讯代码了.以下有一段简单的25针串口 ...
- 想取得刚才nextval()的值时,放心大胆的用currval()吧,currval()的返回值并不会因为nextval()的并发访问而混乱
以前写sql的时候总是担心current()得到的值并不会绝对等于我上一次nextval()取得的值;因为可能其他线程并发访问nextval(). 先说结论吧:当你拿到一个数据库连接,先nextval ...
- apache ant 修改java版本 方法之一
通常apache ant是和eclipse软件绑定在一起的.尝试了一些方法不行,想到了一个笨的方法,分享一下: ①打开ant 编译时的配置界面 ②.切换到classPath选项卡,选择ant home ...
- 【转】关于BeanUtils.copyProperties的用法和优缺点
一.简介: BeanUtils提供对Java反射和自省API的包装.其主要目的是利用反射机制对JavaBean的属性进行处理.我们知道,一个JavaBean通常包含了大量的属性,很多情况下,对Jav ...
- node.js和npm离线安装
离线安装node.js和npm 1.下载官方安装包并拷贝到离线机器上. 官方下载地址:https://nodejs.org/en/download/ 2.解压文件: tar-xJf node-v8.9 ...
- etcd 命令行
比较重要的配置 -name 节点名称,默认是UUID-data-dir 保存日志和快照的目录,默认为当前工作目录-addr 公布的ip地址和端口. 默认为127.0.0.1:2379-bind-add ...
- PLSQL Developer工具的使用
1.运行 2.字体大小 导入csv文件. 任何工具都有失败的可能, 这个时候,也失败了. 当然还有另一种可能,文件被人为改过了,括号改过了,就即使使用下面的kettle工具也没用了.这时可以导出文件对 ...