㈠ sql server awe怎么设置
由于32位Windows用户进程有4GB的虚拟地址空间。其中2GB给核心态,剩下2GB给用户态。这两部分严格分开。Windows不会因为其中某一块
内存地址空间用尽而将另外一块的空间让出。
由于SQLSERVER的绝大部分指令都运行在用户态下,就是说SQLSERVER的内存基本上使用用户态地址空间资源。现在的情况是2GB地址空间资源
对于SQLSERVER来说严重阻碍了SQLSERVER有效利用硬件资源
所以SQLSERVER引入了AWE address windowsing extensions(地址空间扩展)。这是允许32位应用程序分配64GB物理内存,并把视图或窗口
映射到2GB虚拟地址空间的机制。
使用AWE,使得一个应用程序能够访问最多达64GB的物理内存!!!
在SQL2000的企业版,SQL2005/2008的企业版和标准版都支持这个技术,也能够享受这个技术带来的好处
开启这个功能的语句,执行完之后,重启SQLSERVER服务即可
1 EXEC sys.sp_configure @configname = 'AWE Enabled', -- varchar(35)
2 @configvalue = 1 -- int
3 RECONFIGURE
4 GO
AWE具体实现图
有几点需要注意的:
(1)开启这个功能需要SQLSERVER启动帐户在Windows上的lock pages in memory权限。没有这个权限,AWE就不能成功被开启。
启动的SQLSERVER这时候只能使用2GB的地址空间。
所以DBA要确认一下SQLSERVER的errorlog里有没有相关的信息
成功开启:server Address Windowing Extensions enabled
消息
Address Windowing Extensions is enabled. This is an informational message only; no user action is required.
开启失败:Cannot use Address Windowing Extensions because lock memory privilege was not granted
(2)这个功能是在应用层面有意识地使用,而不是在Windows层面实施的。也就是说SQLSERVER在申请内存时,通过特殊API调用申请到的,
如果SQLSERVER不调用这个功能,就还会在普通的2GB虚拟地址空间申请内存。在SQLSERVER中不是所有的内存申请都会调用AWE技术,
只有先reserve,再commit的内存调用,SQLSERVER才使用AWE让他们使用到扩展的内存。其他方式申请的内存只能使用普通的2GB地址空间。
正因为这样,AWE不能称为解决SQLSERVER地址空间不足的最终解决方案。使用64位的服务器,虚拟地址空间可以达到8TB,
大于现在绝大多数的单个服务器的物理内存数。在64位下运行的SQLSERVER,其性能往往比在32位上有比较明显的提高。
最后附上各个版本Windows上支持的最大内存数
配置 应用虚拟地址空间大小 最大物理内存数 是否支持AWE/locked pages support
32位SQLSERVER 2GB 64GB YES
32位SQLSERVER + /3GB boot.ini参数 3GB 16GB YES
32位SQLSERVER 应用在x64位操作系统(WOW) 4GB 64GB YES
32位SQLSERVER 应用在IA64操作系统(WOW) 2GB 2GB NO
64位SQLSERVER 应用在x64操作系统 8TB 2TB YES
64位SQLSERVER 应用在IA64操作系统 7TB 2TB YES
㈡ sql server2008r2 安装需要多大
机子上除了SQLSERVER2008R2没有跑其他的东西 最大内存设置的是2147483647MB 最小内存0MB 没有勾选Use AWE to allocate memory 现在使用了23.8G
㈢ sqlserver2008r2x64最大内存限制是否需要设定设置多少为宜
机子上除了SQLSERVER2008R2没有跑其他的东西最大内存设置的是2147483647MB最小内存0MB没有勾选UseAWEtoallocatememory现在使用了23.8G
㈣ sql server 2008 r2 启用awe后 内存的管理
会自动释放的。内存缓存一些查询,tempdb,存储等。不是把所有数据放到内存里面。你才10G,那100G,1T的怎么办。这涉及SQL内存管理方面。我也是粗浅的了解了一点。
㈤ sql server2008占用进程内存太大,超过正常使用内存,什么 原因
SQL Server的内存一直上不去。从Task Schele中看到SQL Server只使用了88MB内存,实际这台机器有12GB的内存,可用内存有超过8GB。 当时我以为是开启了AWE导致的,所以连接到他的服务器看了一下。但是数据库为2005企业版64位,所以不用开启AWE。而且即使开启了,也会被忽略。 使用下面的脚本查询了一下SQL Server内存使用: select physical_memory_in_use_kb,locked_page_allocations_kb,*fromsys.dm_os_process_memory 看到实际使用的内存有2GB,远远超出任务管理器看到的。(也可以通过Perfmon的Total server memory(MB)查看)。 当时觉得很奇怪,查看了SQL Server错误日志发现了类似下面的信息: 2009-06-0412:21:08.16 Server Large Page Extensions enabled. 2009-06-04 12:21:08.16 Server Large Page Granularity: 2097152 2009-06-04 12:21:08.21 Server Large Page Allocated: 32MB 猜测这台期间开启了Lock Pages In memory功能,之后得到确认。因为开启Lock Pages In memory之后,SQL Server会使用AWE APIs锁定内存页,所以这部分的内存使用不会显示在Working Set中。 So in summary the AWE APIs for 32bit and 64bit SQL Server systems are used for different purposes. In 32bit it is really to extend memory access beyond 4Gb or to enable the AWE feature. For 64bit systems, it is to possibly gain performance and to “lock pages” for the buffer pool. 到现在这个问题就比较明朗了,其实SQL Server还是正常工作的。一般查询SQL Server的使用还是建议使用DMV或者Perfmon,直接查看Working Set信息可能不准。 另外说一下,当时看到上面Large Page的信息,以为是数据库开启了LargePage,但是使用DBCC TRACSTATUS查看没有开启834 Trace Flag,所以大数据功能是没有启用的。只有开启834 Trace Flag数据库才会真正启用Large Page。 启用Large page在数据库错误日志会看到类似信息: 2009-06-0414:20:40.03 Server Using large pages for buffer pool. 关于Lock Pages In memory/working set机制我找到了两篇文章,大家有兴趣可以参考: Funwith Locked Pages, AWE, Task Manager, and the Working Set WhySQL Server is using so LESS memory
㈥ sql2008数据库内存一直增加
有没有设置SQL Server最大使用的内存量?如果不设置,SQL Server通常有多少用多少。
依次运行如下命令,将最大内存设置为20G,当然可以根据你实际上的内存来做调整
另外这里限制的内存只是SQL Server缓冲池的大小,SQL Server其它功能也是要占用内存的。还有64bit的是不需要开启AWE的。
EXEC sp_configure 'show advanced options',1
RECONFIGURE
EXEC sp_configure 'max server memory (MB)',20480
RECONFIGURE
㈦ 如何配置 awe enabled 选项 (SQL Server Management Studio)求解答
请不要在新的开发工作中使用该功能,并尽快修改当前还在使用该功能的应用程序。
在 SQL Server 中,利用地址窗口化扩展插件 (AWE),可以使可访问的物理内存量超出对配置的虚拟内存设置的限制。
如果已启用此选项,当 SQL Server 实例启动时,SQL Server 错误日志中将写入消息“Address Windowing Extensions enabled”。
使用 AWE 前,必须首先配置 Microsoft Windows“锁定内存页”策略。有关详细信息,请参阅
若要使 32 位操作系统支持 4 GB 以上的物理内存,则必须向 boot.ini 文件添加/pae参数并重新启动计算机。
㈧ sql如何开启awe
为 SQL Server 启用 AWE 内存
SQL Server 2008 R2 其他版本 SQL Server 2008 SQL Server 2005
2(共 3)对本文的评价是有帮助 - 评价此主题
下一版本的 Microsoft SQL Server 将删除该功能。请不要在新的开发工作中使用该功能,并尽快修改当前还在使用该功能的应用程序。
地址窗口化扩展插件 (AWE) 可以使 32 位操作系统访问大量内存。AWE 由操作系统公开,并且在 Microsoft Windows 2000 Server 和 Windows Server 2003 中的实现方式稍有不同。AWE 是使用 awe enabled 选项启用的。
㈨ sql server 2008 怎样设置内存
在安装有SQLServer数据库的计算机上,我们在使用数据库的过程中,有时候会在任务管理器里发现sqlservr.exe这个进程的内存和CPU占用率较高。
接下来我们来看一下,如何解决上面这个问题,需要设置SQLServer数据库的内存配置。登录数据库,这里使用的是SQLServer2008,右键点击最上方的服务器名,在弹出的菜单中,点击【属性】
打开服务器属性窗口。默认显示的是第一项【常规】内容,点击第二项【内存】进行内存配置。
点击【内存】后,打开服务器内存选项配置界面。这里的【使用AWE分配内存】可以对内存进行扩展支持,我们要做的是更改下方的最大服务器内存。这个数值根据自己服务器内存大小来做适当设置。
个人建议设置本机内存的一半或稍微高一点,如机器内存为2G,那么我们这里填写1000。需要注意的是内存设置调小以后,在数据库执行较复杂SQL语句的时候,可能会比较慢,出现这种情况,我们再适当上调最大内存配置大小。
㈩ sql server 2008 判断是否启动awe
你好
SQL Server 2008 的Standard版本所支持的最大内存是操作系统最大值
一般预留2G给操作系统 如果没有其他服务剩下的内存都可以给sql server。