bitscn.com
序的名称,单击“停止”按钮,这时出现确认操作对话框;
④选择“是”确认操作,然后关闭对话框完成设置。
3?优化虚拟内存
在对windows nt虚拟内存进行设置时需要合理确定各个驱动器分页文件的“起始大小”和“最大值”两个参数,它们用于指定分页文件的起始空间和最大空间。下面对这两个参数作一些解释:
起始大小:指初始创建该分页文件时的文件大小,单位为mb,根据缺省设置,这个值被设置为系统中的物理内存的大小。
最大值:指出该分页文件的最大尺寸,单位为mb。
(1)分页文件的设置原则:
①分页文件起始大小应保留缺省设置,一般情况下请不要改动;
②分页文件理想的最大尺寸为系统物理内存尺寸的2.5倍至4倍。需要说明的是:如果系统工作时不需要大量内存,请选择靠近下限的值,即用系统物理内存的2.5倍作为这个尺寸的起始值;如果系统工作时需要大量内存,请选择靠近上限的值。
(2)windows nt虚拟内存设置步骤:
①从“控制面板”中双击“系统”图标;
②在“系统特性”对话框中单击“性能”标签;
③在虚拟内存对话框中单击“更改”按钮,这时出现“虚拟内存”对话框,上端的驱动器框逐一列出了 windows nt所有页面文件的大小;
④在驱动器列表中,选择需要设置分页文件的驱动器盘符,在“驱动器页面文件大小”对话框中列出了 “起始大小”和“最大值”两个参数栏,填入按照上面的原则确定的数值;
⑤单击“设置”确认以上操作,然后依次单击“确定”按钮退出各个对话框,完成设置。
(3)win95/98虚拟内存设置。
win95/98虚拟内存设置方法、步骤和原则与windows nt 4.0的设置大致相同,请参照上面windows nt的设置。
4?注意事项
(1)合理确定分页文件的最大值,根据系统需求随时进行调整,使用过多虚拟内存将导致整个系统处理性能的下降。设置虚拟内存最大值的目的是使用户不必在windowsnt的交换文件上消耗过多的磁盘空间,通常情况下如果超过了系统需要的最佳值后,生成交换文件的磁盘空间就被浪费了。
(2)尽可能设立专用硬盘配置内存交换区,或将交换空间放到主硬盘的另一个分区,同时应将主硬盘的交换文件大小降至16mb,这样主硬盘(分区)仅用来放置操作系统和应用程序,就可以减少交换次数,防止频繁交换耗费大量 cpu时间。
(3)虚拟内存技术的确改善了windows nt系统的性能,但也受到机器硬盘空间大小、硬盘速度、处理器 (cpu)速度的影响,从理想角度出发,要提高计算机的性能就必须减少交换操作的次数,但是没有一个windowsnt计算机不发生交换,这就要求计算机要有足够的物理内存,以保持最少的交换操作。
三、优化microsoft sql server数据库内存配置
内存是影响microsoft sql server系统性能的一个重要因素,sql server数据库安装时将为具有32mb物理内存的机器缺省配置16mb可用内存,16mb物理内存的机器缺省配置4mb可用内存。应在microsoft sql server数据库安装后进行内存选项(memory)设置,最大配置值为2gb。
为了确定sql server系统最适宜的内存需求,可以从总的物理内存中减去windows nt4.0需要的内存以及其它一些内存需求后综合确定,理想的情况是给sql server分配尽可能多的内存,而不产生页面调度。
1?根据物理内存合理规划sql server可用内存
在大多数的生产环境中,服务器配备的物理内存是64mb~128mb,偶尔也有256mb的,只要配置恰当是完全可以满足sql server的内存需求的。下表是笔者关于sql server内存分配的建议规划,供参考。
物理内存 分配给sql server 设置值(单位:2kb)
8mb 4mb 2048
16mb 8mb 4096
32mb 16~18mb 8192~9216
48mb 28~34mb 14336~17408
64mb 40~46mb 20480~23552
128mb 100~108mb 51200~55296
256mb 216~226mb 110592~115712
512mb 464~472mb 237568~241664
以下是sql server内存选项(memory)设置方法
(1)从microsoft sql server程序集中启动sql enterprise manager;
(2)从server manager窗口中选择“server”菜单选项;
(3)在“server”菜单中选择“configurations”选项;
(4)在“server configuration”对话框中选择”configuration”标签,configuration窗口显示配置选项列表;
(5)选中“memory”项目,在“current”栏填入新值;
(6)停止并重新启动sqlserver服务,使设置生效。
2?合理扩充虚拟内存、增大sql server可用内存
当sql server系统确实需要扩大可用内存时,应在磁盘空间充足的情况下扩充供虚拟内存,并相应增大 sql server可用内存。具体做法是,系统管理员首先扩充服务器的虚拟内存,然后再参考上表增大sql server可用内存,关键是要根据系统的负载情况综合决定是否扩充内存、优化配置。
3?使用tempinram
sql server使用tempdb临时数据库作为一些查询连接操作时排序或创建临时表的工作空间。将tempdb创建在ram中可以使系统操作性能有较大提高,而且因为tempdb在每次重启动服务器时都重建,这样即使有非正常的关闭也是较为安全的,例如停电故障。要将tempdb创建在ram中,可以使用sp_configure进行设置,具体用法请参阅有关资料。
由于tempdbinram使用的内存是由系统从内存体单独分配的,与sql server的内存选项设置的可用内存池是分开的,使用tempdbin ram将减少整个系统的可用内存,应根据sql server和服务器运行情况进行配置,否则就可能适得其反,影响系统性能。另外,适当增加tempdb数据库空间,即使不使用tempdbin ram,也可以提高数据库的运行速度。
4?注意事项
(1)建议在生产环境中sql server不要设置小于32mb内存,而且数据库服务器上尽量不要运行其它应用程序;
(2)扩充供虚拟内存、增大sql server可用内存,应考虑物理内存使用状况和磁盘空间许可情况;
(3)在可能的情况下,要为系统留有部分额外的内存,这样在服务器上打开一个服务或添加一个进程且不改变sql server内存配置时,不致于使nt服务器的运行速度受到影响(变得很慢),一般认为最小为2mb最大为20mb。
四、巧用内存配置,解决统计服务器问题
一单位的统计服务器投入使用后,运行速度较慢,经排查原因,发现sqlserver中的内存选项(memory)仅为安装缺省值――16mb(而服务器有128mb的物理内存),在将内存值调整为100mb时却误将其改成了 1000mb,使得sql server服务不能启动,统计数据库打不开,也就不能再次进入sql enterprise manager修改内存设置了。由于近期未备份业务数据,不到万不得已不能重装sqlserver数据库,就试图用命令行参数命令来重新启动sql server服务,但均不能奏效,陷入了困境。我们经过仔细分析提出:既然sql server可用内存设置值远远大于物理内存,造成sqlserver服务不能启动,何不扩充虚拟内存呢?经设法将机器虚拟内存扩充至1000mb并重新启动,sql server数据库成功启动,问题迎刃而解。
五、结束语
目前,大多数单位投入使用的microsoft sql server数据库服务器的物理内存一般都在64mb以上,如农业银行省、市分行的统计服务器配备128mb物理内存,只要按照上面提出的方法合理规划、优化nt和sql server的内存配置,使设置尽可能达到最优,应用系统就一定能够充分发挥设计功能、满足业务需求。
bitscn.com
