在软件上,将操作系统从Windows 2000升级到Windows Server 2003;在硬件上,将服务器中的内存由原来的512MB增加到1GB(1024MB) 在升级后的开始几个星期之内,服务。如何设置SQLServer数据库内存?更多详情请大家跟着小编一起来看看吧!

如何设置SQLServer数据库内存

如何设置SQLServer数据库内存(1)

在软件上,将操作系统从Windows 2000升级到Windows Server 2003;在硬件上,将服务器中的内存由原来的512MB增加到1GB(1024MB)。 在升级后的开始几个星期之内,服务器在使用中表现良好。但是不久后就发现,在服务器上同时运行的其他应用程序却出现了异常,不时地报出内存分配不足的警告。

经过几次跟踪后发现,原来是SQL Server吞去了大部分内存所致。被SQL Server占用的内存由升级前的不到400MB一下子增加到现在的900MB,并且有不断增长的趋势。 通过查找原因才知道这是SQL Server 缓冲池的预期行为。

默认情况下,在启动 SQL Server之后,SQL Server会根据操作系统报告的物理内存数来动态增大或缩小高速缓冲存储器的容量。只要可用物理内存大小保持在4MB到10MB之间,SQL Server 缓冲池就会继续增大(保留可用物理内存在4MB到10MB之间是为了避免操作系统因为缺少内存而频繁地换页)。

如果物理可用内存变得较少的时候,则SQL Server会将一些内存释放给操作系统。 为了使运行在服务器上的应用程序都能达到比较满意的效果,同时也为了能给其他应用程序分配足够的内存,需要采取措施限制SQL Server 的内存使用量。我们可以通过设置SQL Server 数据库引擎使用的内存的上下限来达到此目的。

其具体步骤是: 1。打开企业管理器,展开服务器组。 2。单击该服务器,点击鼠标右键,单击属性菜单。 3。在弹出的对话框中单击内存选项卡。 内存设置方法有两种: 1。设置min server memory和max server memory 在一个范围段内。

比如,我们将它设置成最小0MB,最大255MB。这种方法在为一台服务器中运行多个应用程序分配内存时非常有用。 2。设置 min server memory 和 max server memory 为同一数值。 比如,可以将它最大和最小值都设置成255MB。

这样的设置方法与窗口中的另一个选项“使用固定的内存大小” 相一致。 虽然内存最小值和最大值设置是高级选项,但在设置完毕之后,最好还是先将SQL Server服务停止后再重新运行,以便SQL Server能更好地对内存进行合理安排。

以上是我对于这个问题的解答,希望能够帮到大家。

如何设置SQLServer数据库内存

如何设置SQLServer数据库内存(2)

如果能在实例级别为同一SQL服务器上的不同实例限制其能够使用的最大和最小内存,就能降低这种情况对其他应用系统的影响。具体的操作如下:(一)实例的最大和最小内存设置右击数据库,选择属性,如图。为实例设置合适的最大和最小内存,如图。(二)为操作系统预留足够的内存假如一台8GB的服务器,我们可以限制数据库使用的内存上限不超过6GB,剩下的2GB留给操作系统使用。(三)配置lock pages in memory查看SQL进程的启动账户,如图。在组策略里设置启动SQL Server的账户拥有锁定内存页的权限。如图。在下图的添加用户或组界面,添加SQL server的服务启动账户,如图。