svchost.exe进程

进程文件: svchost or svchost.exe
进程名称: Generic Service Host Process for Win32 Services
进程类别:系统进程
位置:C:windowssystem32svchost.exe (如果你的svchost.exe进程不是在这个目录下的话,那么就要当心了)
英文描述:svchost.exe is a system process belonging to the Microsoft Windows Operating System which handles processes executed from DLLs. This program is important for the stable and secure running of your computer and should not be terminated. Note: svchost.
(注意:svchost.exe也有可能是W32.Welchia.Worm病毒,它利用Windows LSASS漏洞,制造缓冲区溢出,导致你计算机关机 。更多详细信息参考:http://www.microsoft.com/technet/security/bulletin/ms04-011.mspx,该进程的安全等级是建议立即删除 。)
出品者:Microsoft Corp.
属于:Microsoft Windows Operating System
系统进程:Yes
后台程序:Yes
网络相关:Yes
常见错误:N/A
内存使用:N/A
安全等级 (0-5): 0
间谍软件:No
广告软件:No
病毒:No
木马:No
在基于nt内核的windows操作系统家族中,不同版本的windows系统,存在不同数量的“svchost进程,用户使用“任务管理器可查看其进程数目 。一般来说,win2000有两个svchost进程,winxp中则有四个或四个以上的svchost进程(以后看到系统中有多个这种进程,千万别立即判定系统有病毒了哟),而win2003server中则更多 。这些svchost进程提供很多系统服务,如:rpcss服务(remoteprocedurecall)、dmserver服务(logicaldiskmanager)、dhcp服务(dhcpclient)等 。到了Windows Vista 系统时svchost 进程多达12个,这些svchost.exe都是同一个文件路径下C :WindowsSystem32svchost.exe ,它们分别是imgsvc、 NetworkServiceNetworkRestricted、 LocalServiceNoNetwork 、NetworkService 、LocalService 、netsvcs 、LocalSystemNetworkRestricted、 LocalServiceNetworkRestricted 、services 、rpcss、 WerSvcGroup 、DcomLaunch服务组 。如果要了解每个svchost进程到底提供了多少系统服务,可以在win2000的命令提示符窗口中输入“tlist-s命令来查看,该命令是win2000supporttools提供的 。在winxp则使用“tasklist/svc命令 。
svchost中可以包含多个服务
深入:windows系统进程分为独立进程和共享进程两种,“svchost.exe文件存在于“%systemroot%system32目录下,它属于共享进程 。随着windows系统服务不断增多,为了节省系统资源,微软把很多服务做成共享方式,交由svchost.exe进程来启动 。但svchost进程只作为服务宿主,并不能实现任何服务功能,即它只能提供条件让其他服务在这里被启动,而它自己却不能给用户提供任何服务 。那这些服务是如何实现的呢?
原来这些系统服务是以动态链接库(dll)形式实现的,它们把可执行程序指向svchost,由svchost调用相应服务的动态链接库来启动服务 。那svchost又怎么知道某个系统服务该调用哪个动态链接库呢?这是通过系统服务在注册表中设置的参数来实现 。下面就以rpcss(remoteprocedurecall)服务为例,进行讲解 。
从启动参数中可见服务是靠svchost来启动的 。
实例
以windowsxp为例,点击“开始/“运行,输入“services.msc命令,弹出服务对话框,然后打开“remoteprocedurecall属性对话框,可以看到rpcss服务的可执行文件的路径为“c:windowssystem32svchost-krpcss,这说明rpcss服务是依靠svchost调用“rpcss参数来实现的,而参数的内容则是存放在系统注册表中的 。
在运行对话框中输入“regedit.exe后回车,打开注册表编辑器,找到[hkey_local_machinesystemcurrentcontrolsetservicesrpcss]项,找到类型为“reg_expand_sz的键“Imagepath,其键值为“%systemroot%system32svchost-krpcss(这就是在服务窗口中看到的服务启动命令),另外在“parameters子项中有个名为“servicedll的键,其值为“%systemroot%system32rpcss.dll,其中“rpcss.dll就是rpcss服务要使用的动态链接库文件 。这样svchost进程通过读取“rpcss服务注册表信息,就能启动该服务了 。

推荐阅读