服务器内存使用率与负载之间的关系
CPU使用率:显示的是程序在运行期间实时占用的CPU百分比
CPU负载:显示的是一段时间内正在使用和等待使用CPU的平均任务数。CPU使用率高,并不意味着负载就一定大。举例来说:如果我有一个程序它需要一直使用CPU的运算功能,那么此时CPU的使用率可能达到100%,但是CPU的工作负载则是趋近于“1”,因为CPU仅负责一个工作嘛!如果同时执行这样的程序两个呢?CPU的使用率还是100%,但是工作负载则变成2了。所以也就是说,当CPU的工作负载越大,代表CPU必须要在不同的工作之间进行频繁的工作切换。
引起CPU100%十大原因
对于Vagaa占用系统资源过高而导致系统缓慢和死机的问题,一直以来都是大家提问的热门,据Vagaa官方的解释是和冲突导致的,其实这只是一方面的原因。我想在此谈点儿自己的看法,抛出一块儿砖,希望能引来大家的玉,一起探讨。
说到冲突呢,其实是Kad网络和某些IE插件有冲突,其中的首恶就是,只要是应用Kad网络的p2p软件都会发生,不光是Vagaa。这些都好解决,只要把没用的IE插件都卸载了就行了。
据我分析,造成CPU100%的原因还有几个。当下载的一个文件有问题时,Vagaa可能会不断的尝试修复,造成系统资源大量占用。解决方法是删除那个有问题的文件。
1、防杀毒软件造成 故障
由于新版的 KV 、金山、 瑞星 都加入了对网页、 插件 、邮件的随机监控,无疑增大了系统负担。
处理方式:基本上没有合理的处理方式,尽量使用最少的监控服务吧,或者,升级你的硬件配备。
2、驱动没有经过认证,造成CPU资源占用100%
大量的测试版的驱动在网上泛滥,造成了难以发现的故障原因。 处理方式:尤其是 显卡驱动
特别要注意,建议使用 微软认证 的或由官方发布的驱动,并且严格核对型号、版本。
3、 病毒、木马 造成
大量的蠕虫病毒在系统内部迅速复制,造成CPU占用资源率据高不下。解决办法:用可靠的杀毒软件
彻底清理系统内存和本地硬盘,并且打开系统设置软件,察看有无异常启动的程序。经常性更新升
级杀毒软件和防火墙,加强防毒意识,掌握正确的防杀毒知识。
4、控制面板— 管理工具 —服务—RISING REALTIME MONITOR SERVICE 点鼠标右键,改为手动。
5、开始->运行->msconfig->启动,关闭不必要的启动项,重启。
6、查看“ svchost ”进程。
svchost exe 是Windows XP系统 的一个核心进程。 svchostexe 不单单只出现 在Window s XP中,
在使用 NT 内核的 Windows系统 中都会有svchostexe的存在。一般在 Windows 2000 中 svchostexe
进程 的数目为2个,而 在Windows XP中svchostexe进程的数目就上升到了4个及4个以上。
7、查看 网络连接 。主要是网卡。
8、查看网络连接
当安装了Windows XP的计算机做服务器的时候,收到端口 445 上的连接请求时,它将分配内存和少量
地调配 CPU资源来为这些连接提供服务。当负荷过重的时候,CPU占用率可能过高,这是因为在工作项
的数目和响应能力之间存在固有的权衡关系。你要确定合适的 MaxWorkItems 设置以提高系统响应能力。如果设置的值不正确,服务器的响应能力可能会受到影响,或者某个用户独占太 多系统 资源。
要解决此问题,我们可以通过修改注册表来解决:在 注册表编辑器 中依次展开
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\lanmanserver ]
分支,在右侧窗口中 新建 一个名为“maxworkitems”的 DWORD值 。然后双击该值,
在打开的窗口中键入下列数值并保存退出:
如果计算机有512MB以上的内存,键入“1024”;如果计算机内存小于 512 MB,键入“256”。
9、看看是不是Windows XP使用鼠标右键引起CPU占用100%
前不久的报到说在资源管理器里面使用鼠标右键会导致CPU资源100%占用,我们来看看是怎么回事?
征兆:
在资源管理器里面,当你右键点击一个目录或一个文件,你将有可能出现下面所列问题:
任何文件的拷贝操作在那个时间将有可能停止相应
网络连接速度将显著性的降低
所有的流输入/输出操作例如使用Windows Media Player 听音乐将有可能是音乐失真成因:
当你在资源管理器里面右键点击一个文件或目录的时候,当快捷 菜单显示 的时候,
CPU占用率将增加到100%,当你关闭快捷菜单的时候才返回正常水平。
解决方法:
方法一:关闭“为菜单和工具提示使用过渡效果”
1、点击“开始”--“控制面板”
2、在“控制面板”里面双击“显示”
3、在“显示”属性里面点击“外观”标签页
4、在“外观”标签页里面点击“效果”
5、在“效果”对话框里面,清除“为菜单和工具提示使用过渡效果”前面的复选框接着点击两次
“确定”按钮。
方法二:在使用鼠标右键点击文件或目录的时候先使用鼠标左键选择你的目标文件或目录。
然后再使用鼠标右键弹出快捷菜单。
CPU占用100%解决办法
一般情况下CPU占了100%的话我们的电脑总会慢下来,而很多时候我们是可以通过做 一点点
的改动就可以解决,而不必问那些大虾了。
当机器慢下来的时候,首先我们想到的当然是任务管理器了,看看到底是哪个程序占了较搞的比例,
如果是某个大程序那还可以原谅,在关闭该程序后只要CPU正常了那就没问题;如果不是,
那你就要看看是什幺程序了,当你查不出这个进程是什幺的时候就去google或者 baidu 搜。
有时只结束是没用的,在 xp下 我们可以结合msconfig里的启动项,把一些不用的项给关掉。
在2000下可以去下个winpatrol来用。
一些常用的软件,比如浏览器占用了很搞的CPU,那幺就要升级该软件或者干脆用别的同类软件代替,
有时软件和系统会有点不兼容,当然我们可以试下xp系统下给我们的那个兼容项,右键点该 exe文件
选兼容性。
svchostexe有时是比较头痛的,当你看到你的某个svchostexe占用很大CPU时你可以去下个aports
或者fport来检查其对应的程序路径,也就是什幺东西在掉用这个svchostexe,
如果不是c:\Windows\ system32 (xp)或c:\winnt\system32(2000)下的,那就可疑。
升级杀毒软件杀毒吧。
右击 文件导致100%的CPU占用我们也会遇到,有时点右键停顿可能就是这个问题了。
官方的解释:先点左键选中,再右键(不是很理解)。非官方:通过在桌面点右键-属性-外观-效果,
取消”为菜单和工具提示使用下列过度效果(U)“来解决。还有某些杀毒软件对文件的监控也会有所影响,可以 关闭杀毒软件 的文件监控;还有就是对网页,插件,邮件的监控也是同样的道理。
一些驱动程序有时也可能出现这样的现象,最好是选择微软认证的或者是官方发布的驱动来装,
有时可以适当的升级驱动,不过记得最新的不是最好的。
CPU降温软件 ,由于软件在运行时会利用所以的CPU空闲时间来进行降温,
但Windows不能分辨普通的CPU占用和 降温软件 的降温指令 之间的区别 ,
因此CPU始终显示100%,这个就不必担心了,不影响正常的系统运行。
在处理较大的 word文件 时由于word的拼写和语法检查会使得CPU累,
只要打开word的工具-选项-拼写和语法把”检查拼写和检查语法“勾去掉。
单击 avi视频 文件后CPU占用率高是因为系统要先扫描该文件,并检查文件所有部分,
并建立索引;解决办法:右击保存视频文件的文件夹-属性-常规-高级,去掉为了快速搜索,允许索引服务编制该文件夹的索引的勾。
CPU占用100%案例分析
1、 dllhost进程造成CPU使用率占用100%
特征:服务器正常CPU消耗应该在75%以下,而且CPU消耗应该是上下起伏的,出现这种问题的服务器,
CPU会突然一直处100%的水平,而且不会下降。查看任务管理器,可以发现是DLLHOSTEXE消耗了所有的CPU空闲时间,管理员在这种情况下,只好重新启动IIS服务,奇怪的是,重新启动IIS服务后一切正常,但可能过了一段时间后,问题又再次出现了。
直接原因:
有一个或多个ACCESS数据库在多次读写过程中损坏,微软的 MDAC 系统在写入这个损坏的ACCESS文件时,
ASP线程处于BLOCK状态,结果其它线程只能等待,IIS被死锁了,全部的CPU时间都消耗在DLLHOST中。
解决办法:
安装“一流信息监控拦截系统”,使用其中的“首席文件检查官IIS健康检查官”软件,
启用”查找死锁模块”,设置:
--wblock=yes
监控的目录,请指定您的主机的文件所在目录:
--wblockdir=d:\test
监控生成的日志的文件保存位置在安装目录的log目录中,文件名为:logblockhtm
停止IIS,再启动“首席文件检查官IIS健康检查官”,再启动IIS,
“首席文件检查官IIS健康检查官”会在logblockhtm中记录下最后写入的ACCESS文件的。
过了一段时间后,当问题出来时,例如CPU会再次一直处100%的水平,可以停止IIS,
检查logblockhtm所记录的最后的十个文件,注意,最有问题的往往是计数器类的ACCESS文件,例如:”COUNT MDB ”,”COUNTASP”,可以先把最后十个文件或有所怀疑的文件删除到回收站中,再启动IIS,看看问题是否再次出现。我们相信,经过仔细的查找后,您肯定可以找到这个让您操心了一段时间的文件的。
找到这个文件后,可以删除它,或下载下来,用ACCESS2000修复它,问题就解决了。
2、 svchostexe造成CPU使用率占用100%
在winini文件中,在[Windows]下面,“run=”和“load=”是可能加载“木马”程序的途径,
必须仔细留心它们。一般情况下,它们的等号后面什幺都没有,如果发现后面跟有路径与文件名不是你熟悉的启动文件,你的计算机就可能中上“木马”了。当然你也得看清楚,因为好多“木马”,如“AOL Trojan木马”,它把自身伪装成commandexe文件,如果不注意可能不会发现它不是真正的系统启动文件。
在systemini文件中,在[BOOT]下面有个“shell=文件名”。正确的文件名应该是“explorerexe”
,如果不是“explorerexe”,而是“shell= explorerexe 程序名”,
那幺后面跟着的那个程序就是“木马”程序,就是说你已经中“木马”了。
在注册表中的情况最复杂,通过regedit命令打开注册表编辑器,
在点击至:“HKEY-LOCAL-MACHINE\Software\Microsoft\Windows\CurrentVersion\Run”目录下,
查看键值中有没有自己不熟悉的自动启动文件,扩展名为EXE,
这里切记:有的“木马”程序生成的文件很像系统自身文件,
想通过伪装蒙混过关,如“Acid Battery v10木马”,它将注册表“HKEY-LOCAL-MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run”下的Explorer 键值改为Explorer=“C:\Windows\expiorerexe”,“木马”程序与真正的Explorer之间只有“i”与“l”的差别。当然在注册表中还有很多地方都可以隐藏“木马”程序,如:“HKEY-CURRENT-USER\Software\Microsoft\Windows\CurrentVersion\Run”、“HKEY-USERS\\Software\Microsoft\Windows\CurrentVersion\Run”的目录下都有可能,最好的办法就是在“HKEY-LOCAL-MACHINE\Software\Microsoft\Windows\CurrentVersion\Run”下找到“木马该病毒也称为“Code Red II(红色代码2)”病毒,与早先在西方英文系统下流行“红色代码”病毒有点相反,在国际上被称为VirtualRoot(虚拟目录)病毒。该蠕虫病毒利用Microsoft已知的溢出漏洞,通过80端口来传播到其它的Web页服务器上。受感染的机器可由黑客们通过Http Get的请求运行scripts/rootexe来获得对受感染机器的完全控制权。
当感染一台服务器成功了以后,如果受感染的机器是中文的系统后,该程序会休眠2天,
别的机器休眠1天。当休眠的时间到了以后,该蠕虫程序会使得机器重新启动。
该蠕虫也会检查机器的月份是否是10月或者年份是否是2002年,如果是,
受感染的服务器也会重新启动。当Windows NT系统启动时,
NT系统会自动搜索C盘根目录下的文件explorerexe,
受该网络蠕虫程序感染的服务器上的文件explorerexe也就是该网络蠕虫程序本身。
该文件的大小是8192字节,VirtualRoot网络蠕虫程序就是通过该程序来执行的。
同时,VirtualRoot网络蠕虫程序还将cmdexe的文件从Windows NT的system目录拷贝到别的目录,
给黑客的入侵敞开了大门。它还会修改系统的注册表项目,通过该注册表项目的修改,
该蠕虫程序可以建立虚拟的目录C或者D,病毒名由此而来。值得一提的是,
该网络蠕虫程序除了文件explorerexe外,其余的操作不是基于文件的,
而是直接在内存中来进行感染、传播的,这就给捕捉带来了较大难度。
”程序的文件名,再在整个注册表中搜索即可。
我们先看看微软是怎样描述svchostexe的。在微软知识库314056中对svchostexe有如下描述
:svchostexe 是从动态链接库 (DLL) 中运行的服务的通用主机进程名称。
其实svchostexe是Windows XP系统的一个核心进程。svchostexe不单单只出现在Windows XP中,
在使用NT内核的Windows系统中都会有svchostexe的存在。一般在Windows 2000中svchostexe进程的数目为2个,而在Windows XP中svchostexe进程的数目就上升到了4个及4个以上。所以看到系统的进程列表中有几个svchostexe不用那幺担心。
svchostexe到底是做什幺用的呢
首先我们要了解一点那就是Windows系统的中的进程分为:独立进程和共享进程这两种。
由于Windows系统中的服务越来越多,为了节约有限的系统资源微软把很多的系统服务做成了共享模式。
那svchostexe在这中间是担任怎样一个角色呢
svchostexe的工作就是作为这些服务的宿主,即由svchostexe来启动这些服务。
svchostexe只是负责为这些服务提供启动的条件,其自身并不能实现任何服务的功能
,也不能为用户提供任何服务。
svchostexe通过为这些系统服务调用动态链接库(DLL)的方式来启动系统服务。
svchostexe是病毒这种说法是任何产生的呢
因为svchostexe可以作为服务的宿主来启动服务,所以病毒、
木马的编写者也挖空心思的要利用svchostexe的这个特性来迷惑用户达到入侵、破坏计算机的目的。
如何才能 辨别 哪些是正常的svchostexe进程,而哪些是 病毒进程 呢
svchostexe的键值是在
“HKEY_LOCAL_MACHINE\Software\Microsoft\Windows NT\CurrentVersion\Svchost”,如图1所示。
图1中每个键值表示一个独立的svchostexe组。
微软还为我们提供了一种察看系统正在运行在svchostexe列表中的服务的方法。
以Windows XP为例:在“运行”中输入:cmd,然后在命令行模式中输入:tasklist /svc。
系统列出如图2所示的服务列表。图2中红框包围起来的区域就是svchostexe启动的服务列表。
如果使用的是Windows 2000系统则把前面的“tasklist /svc”命令替换为:“tlist -s”即可。
如果你怀疑计算机有可能被病毒感染,svchostexe的服务出现异常的话通过搜索
svchostexe文件 就可以发现异常情况。一般只会找到一个在
:“C:\Windows\System32”目录下的svchostexe程序。
如果你在其它目录下发现svchostexe程序的话,那很可能就是中毒了。
还有一种确认svchostexe是否中毒的方法是在任务管理器中察看进程的执行路径。
但是由于在Windows系统自带的任务管理器不能察看进程路径,所以要使用第三方的进程察看工具。
上面简单的介绍了svchostexe进程的相关情况。总而言之,
svchostexe是一个系统的核心进程,并不是病毒进程。
但由于svchostexe进程的特殊性,所以病毒也会千方百计的入侵svchostexe。
通过察看svchostexe进程的执行路径可以确认是否中毒。
3、 Servicesexe造成CPU使用率占用100%
症状
在基于 Windows 2000 的计算机上,Servicesexe 中的 CPU 使用率可能间歇性地达到100 %,
并且计算机可能停止响应(挂起)。出现此问题时,
连接到该计算机(如果它是文件服务器或域控制器)的用户会被断开连接。
您可能还需要重新启动计算机。如果 Esentdll 错误地处理将文件刷新到磁盘的方式,
则会出现此症状。
解决方案
Service Pack 信息
要解决此问题,请获取最新的 Microsoft Windows 2000 Service Pack。有关其它信息,
请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
260910 如何获取最新的 Windows 2000 Service Pack
修复程序信息
Microsoft 提供了受支持的修补程序,但该程序只是为了解决本文所介绍的问题。
只有计算机遇到本文提到的特定问题时才可应用此修补程序。
此修补程序可能还会接受其它一些测试。因此,如果这个问题没有对您造成严重的影响,
Microsoft 建议您等待包含此修补程序的下一个 Windows 2000 Service Pack。
要立即解决此问题,请与“Microsoft 产品支持服务”联系,以获取此修补程序。
有关“Microsoft 产品支持服务”电话号码和支持费用信息的完整列表,
请访问 Microsoft Web 站点:
注意 :特殊情况下,如果 Microsoft 支持专业人员确定某个特定的更新程序能够解决您的问题
,可免收通常情况下收取的电话支持服务费用。对于特定更新程序无法解决的其它支持问题和事项,
将正常收取支持费用。
下表列出了此修补程序的全球版本的文件属性(或更新的属性)。
这些文件的日期和时间按协调通用时间 (UTC) 列出。查看文件信息时,它将转换为本地时间。
要了解 UTC 与本地时间之间的时差,请使用“控制面板”中的“日期和时间”工具中的 时区 选项卡。
状态
Microsoft 已经确认这是在本文开头列出的 Microsoft 产品中存在的问题。
此问题最初是在 Microsoft Windows 2000 Service Pack 4 中更正的。
4、正常软件造成CPU使用率占用100%
首先,如果是从开机后就发生上述情况直到关机。
那幺就有可能是由某个随系统同时登陆的软件造成的。
可以通过运行输入“msconfig”打开“系统实用配置工具”,进入“启动”选项卡。接着,
依次取消可疑选项前面的对钩,然后重新启动电脑。反复测试直到找到造成故障的软件。
或者可以通过一些优化软件如“优化大师”达到上述目的。另:如果键盘内按键卡住也可能造成开机就出现上述问题。
如果是使用电脑途中出项这类问题,
可以调出任务管理器(WINXP CTRL+ALT+DEL WIN2000 CTRL+SHIFT“ESC),进入”进程“选项卡,
看”CPU“栏,从里面找到占用资源较高的程序(其中SYSTEM IDLE PROCESS是属于正常,
它的值一般都很高,它的作用是告诉当前你可用的CPU资源是多少
,所以它的值越高越好)通过搜索功能找到这个进程属于哪个软件。然后,
可以通过升级、关闭、卸载这个软件或者干脆找个同类软件替换,问题即可得到解决。
5、病毒、木马、间谍软件造成CPU使用率占用100%
出现CPU占用率100% 的故障经常是因为病毒木马造成的,比如震荡波病毒。应该首先更新病毒库,
对电脑进行全机扫描 。接着,在使用反间谍软件Ad—Aware,检查是否存在间谍软件。
论坛上有不少朋友都遇到过svchostexe占用CPU100%,这个往往是中毒的表现。
svchostexe Windows中的系统服务是以动态链接库(DLL)的形式实现的,
其中一些会把可执行程序指向svchostexe,由它调用相应服务的动态链接库并加上相应参数来启动服务
。正是因为它的特殊性和重要性,使它更容易成为了一些病毒木马的宿主。
6、 explorerexe进程造成CPU使用率占用100%
在systemini文件中,在[BOOT]下面有个“shell=文件名”。
正确的文件名应该是“explorerexe”,如果不是“explorerexe”,
而是“shell= explorerexe 程序名”,那幺后面跟着的那个程序就是“木马”程序,
就是说你已经中“木马”了。
在注册表中的情况最复杂,通过regedit命令打开注册表编辑器,
在点击至:“HKEY-LOCAL-MACHINE\Software\Microsoft\Windows\CurrentVersion\Run”目录下,
查看键值中有没有自己不熟悉的自动启动文件,扩展名为EXE,
这里切记:有的“木马”程序生成的文件很像系统自身文件,想通过伪装蒙混过关,
如“Acid Battery v10木马”,
它将注册表“HKEY-LOCAL-MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run”下的
Explorer 键值改为Explorer=“C:\Windows\expiorerexe”,
“木马”程序与真正的Explorer之间只有“i”与“l”的差别。
当然在注册表中还有很多地方都可以隐藏“木马”程序,
如:“HKEY-CURRENT-USER\Software\Microsoft\Windows\CurrentVersion\Run”
、“HKEY-USERS\\Software\Microsoft\Windows\CurrentVersion\Run”的目录下都有可能,
最好的办法就是在“HKEY-LOCAL-MACHINE\Software\Microsoft\Windows\CurrentVersion\Run”
下找到“木马”程序的文件名,再在整个注册表中搜索即可。
7、超线程导致CPU使用率占用100%
这类故障的共同原因就是都使用了具有超线程功能的P4 CPU。
我查找了一些资料都没有明确的原因解释。据一些网友总结超线程似乎和天网防火墙有冲突
,可以通过卸载天网并安装其它防火墙解决,也可以通过在BIOS中关闭超线程功能解决。
8、AVI视频文件造成CPU使用率占用100%
在Windows XP中,单击一个较大的AVI视频文件后,可能会出现系统假死现象,
并且造成exploereexe进程的使用率100%,这是因为系统要先扫描该文件,并检查文件所有部分,
建立索引。如果文件较大就会需要较长时间并造成CPU占用率100%。
解决方法:右键单击保存视频文件的文件夹,选择”属性—>常规—>高级“,去掉”为了快速搜索,
允许索引服务编制该文件夹的索引“前面复选框的对钩即可。
9、杀毒软件CPU使用率占用100%
现在的杀毒软件一般都加入了,对网页、邮件、个人隐私的即时监空功能,
这样无疑会加大系统的负担。比如:在玩游戏的时候,会非常缓慢。
关闭该杀毒软件是解决得最直接办法。
10、处理较大的Word文件时CPU使用率过高
上述问题一般还会造成电脑假死,这些都是因为WORD的拼写和语法检查造成的,
只要打开WORD的“工具—选项”,进入“拼写和语法”选项卡,将其中的“键入时检查拼写”和
“键入时检查语法”两项前面的复选框中的钩去掉即可。
11、网络连接导致CPU使用率占用100%
系统将分配内存和少量CPU资源来为这些连接提供服务,当负荷过重,就会出现上述情况。
要解决这个问题可以通过修改注册表来解决,打开注册表,
找到HKEY—LOCAL—MACHNE\SYSTEM\CurrentControlSet\Services\lanmanserver,
在右面新建一个名为";maxworkitems";的DWORD值然后双击该值,
如果你的电脑有512以上内存,就设置为";1024";,如果小于512,就设置为256
一些不完善的驱动程序也可以造成CPU使用率过高
经常使用待机功能,也会造成系统自动关闭硬盘DMA模式。这不仅会使系统性能大幅度下降,
系统启动速度变慢,也会使是系统在运行一些大型软件和游戏时CPU使用率100%,产生停顿。
还有一个如果你浏览网页什么出现CPU100%而且出现波浪型的症状
一、服务器硬盘空间:
服务器的磁盘空间应该保持一定的空闲容量。一般情况下,文件时的空间使用率不超过85%。当磁盘空间低于可控制下限时,用户应该马上进行相应处理,避免磁盘空间被占满后关键服务不能正常运行的情况发生。在可视化管理见面中,磁盘空间的使用情况会根据这只的阈值显示不同的颜色。
二、服务器cpu利用率
1服务器cpu的利用率,可针对系统的每个cpu分别分析其相应的利用率;
2服务器当前进程列表所占用的cpu利用率,cpu使用时间;
3显示服务器cpu性能(分进程显示)实时变化情况和历史变化趋势;
4服务器cpu阈值告警,当服务器cpu负载过大/小,能产生报警;
5服务器进程cpu占用阈值告警,当进程占用cpu过大/小,能产生报警;
三、服务器内存利用率
1服务器内存的利用率;
2服务器当前进程列表所占用的内存利用情况,内存利用率;
3显示服务器内存利用率(分进程显示)实时变化情况和历史变化趋势;
4服务器内存利用率阈值告警,当服务器内存利用率过高,能产生报警;
5服务器进程内存利用率阈值告警,当进程占用内存过高,能产生报警;
经常使用MSSQL的朋友都会发现一个小小的网站在运行若干天后MSSQL就会把服务器上所有的内存都吃光,此时你不得不重新启动一下服务器或mssql来释放内存,有人认为是 MSSQL有内存泄露问题,其实不然,微软给我们了明确说明:在您启动SQL Server 之后,SQL Server内存使用量将会持续稳定上升,即使当服务器上活动很少时也不会下降。另外,任务管理器和性能监视器将显示计算机上可用的物理内存稳定下降,直到可用内存降到 4 至 10 MB 为止。
仅仅出现这种状态不表示内存泄漏。此行为是正常的,并且是 SQL Server 缓冲池的预期行为。
默认情况下,SQL Server 根据操作系统报告的物理内存加载动态增大和收缩其缓冲池(缓存)的大小。只要有足够的内存可用于防止内存页面交换(在 4 至 10 MB 之间),SQL Server缓冲池就会继续增大。像在与SQL Server 分配内存位于相同计算机上的其他进程一样,SQL Server 缓冲区管理器将在需要的时候释放内存。SQL Server每秒可以释放和获取几兆字节的内存,从而使它可以快速适应内存分配变化。
更多信息
您可以通过服务器内存最小值和服务器内存最大值配置选项设置 SQL Server数据库引擎使用的内存(缓冲池)量的上下限。在设置服务器内存最小值和服务器内存最大值选项之前,请查阅以下 Microsoft 知识库文章中标题为'内存'一节中的参考信息:319942 HOW TO:Determine Proper sql server(WINDOWS平台上强大的数据库平台) Configuration Settings(确定正确的 sql server(WINDOWS平台上强大的数据库平台) 配置设置)
请注意,服务器内存最大值选项只限制 SQL Server 缓冲池的大小。服务器内存最大值选项不限制剩余的未保留内存区域,sql server(WINDOWS平台上强大的数据库平台) 准备将该区域分配给其他组件,例如扩展存储过程、COM 对象、以及非共享 DLL、EXE 和 MAPI 组件。由于前面的分配SQL Server专用字节超过服务器内存最大值配置是很正常的。有关此未保留内存区域中分配的其他信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:316749 PRB:在使用大量数据库时可能没有足够的虚拟内存
下面我们就来实战如何限制MSSQL内存使用:
第一步:打开企业管理器双击进入要修改的MSSQL
第二步:在左侧MSSQL上点击右键,选择属性,弹出SQL Server属性(配置)对话框(最好打上SQL SP4补丁)
第三步:点击内存选项卡 在这里,你会看到MSSQL默认设置为使用最大内存,也就是你所有的内存,根据你的需要,设置它的最大值(一般为物理内存-128M)和最小值(一般为最大内存的1/4)吧
第五步:设置完毕,重启MSSQL服务,配置即可生效!
我的电脑”→属性→高级→性能→设置→高级→虚拟内存→更改→选择虚拟内存(页面文件)存放的分区→自定义大小→确定最大值和最小值→设置成物理内存的15--3倍最佳。这是我网上求教来的处理方法,你的CPU使用率这么低,按理来说绝对是正常的。不放心的话,把系统日志调出来看下吧。另外说一句,不影响使用,是没有问题的。再有问题私信我
0条评论