解决SQL Server虚拟内存不足情况 症状 在具有 2 GB 或更多 RAM 的计算机上,除了 MB (SQL Server 7.0) 或 MB (SQL Server ) 虚拟地址空间之外,SQL Server 在启动过程中保留剩下的所有虚拟地址空间以供缓冲池使用。另外,为了存储数据和过程缓存,SQL Server 使用缓冲池内存为来自 SQL Server 进程的大多数小于 8 KB 的其他内存请求提供服务。剩下的未保留内存准备用于不能从缓冲池得到服务的其他分配。这些分配包括、但不限于以下各项: SQL Server 创建的所有线程的堆栈和关联的线程环境块。在 SQL Server 创建了所有 个工作线程之后,这大约为 MB。 由在 SQL Server 地址空间(根据具体系统而有所不同)中运行的其他 DLL 或进程进行的分配,如: 任何链接的服务器中的 OLE DB 提供程序。 通过使用 sp_OA 系统存储过程或扩展存储过程加载的 COM 对象。 加载到地址空间中的任何映像(.exe 或 .dll),这些映像通常使用 到 MB,但是如果您使用链接的服务器、sp_OA 或扩展存储过程,则这些映像可能使用更多的空间。 进程堆和 SQL Server 可能创建的任何其他堆。在启动过程中,此空间通常为 MB,但是如果您使用链接的服务器、sp_OA 或扩展存储过程,则此空间可能更多。 来自 SQL Server 进程的大于 8 KB 的分配,例如较大查询计划、网络数据包大小配置选项接近于 8 KB 时发送和接收缓冲区等情况所需要的分配。要查看此数字,请查找在 DBCC MEMORYSTATUS 中报告的 OS Reserved 值,该值是作为 8 KB 页的数目报告的。通常,该值为 5 MB。 跟踪缓冲池中每个缓冲区状态信息的数组。该值通常约为 MB,除非 SQL Server 运行时启用了地址窗口化扩展插件 (AWE),在这种情况下,该值将会显著提高。 在拥有大量数据库的系统上,日志格式化所需的 KB 分配可能会占用所有剩余的虚拟内存。这之后的分配将失败,导致本文的“症状”一节中列出的一个或多个错误。 通过使用 -g 启动参数,您可以指示 SQL Server 保留附加的虚拟内存可用,以便这些与日志相关的分配和其他正常分配加在一起也不会用完虚拟地址空间。 下表根据数据库的数目和服务器版本列出 -g 值的一些建议初始值: DatabasesSQL Server 7.0SQL Server -gN/A -gN/A -gN/A -g-g -g-g -g-g 此表是使用列出的典型值进行计算的,并且此计算是基于没有使用链接的服务器活动、sp_OA 或扩展存储过程这一假设的。它还假设您没有使用 AWE 和 SQL 事件探查器。出现以上任意一种情况都需要您增加 -g 的值。 如果服务器上数据库的数目超过此数目,Microsoft 建议您在运行该服务器之前进行慎重的考虑,因为系统上具有如此数目的数据库所需的系统开销将占用缓冲池中的大量虚拟内存,从而可能导致系统整体性能下降。 : 打造SQL Server的安全策略
推荐整理分享解决SQL Server虚拟内存不足情况(sql server real),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:sql server 实例,虚拟sql server,虚拟sql数据库操作,sql server 实例,虚拟sql数据库操作,sql server虚表,虚拟sql server,sqlserver虚拟表,内容如对您有帮助,希望把文章链接给更多的朋友!
sql中varchar和nvarchar的区别与使用方法 问:sqlserver中的varchar和Nvarchar有什么区别啊,varchar好像是一个英文和一个汉字都站两个字节,而Nvarchar则是一个英文占一个字节,汉字占两个字节。可
将count(*)值写入另一个表中的方法 一、写入同一个数据库的另一个表中:usedb1gocreatetablet1(Itemvarchar(),Provvarchar(),Qtyint);insertintot1(item,prov,qty)select'原名','xx省',(selectcount(*)fromupdatawhereid='A
SuperSocket 信息: (SpnRegister) : Error 。解决方法 SuperSocket信息:(SpnRegister):Error。如何解决?当SQLServer在运行MicrosoftSQLServer的计算机上启动时,SQLServer程序总会尝试在ActiveDirectory中注册虚拟服务器