揭开SVCHOST.exe进程之谜

svchost.exe是nt核心系统的非常重要的进程,对于2000、xp来说,不可或缺。很多病毒、***也会调用它。所以,深入了解这个程序,是玩电脑的必修课之一。
大家对windows操作系统一定不陌生,但你是否注意到系统中“svchost.exe”这个文件呢?细心的朋友会发现windows中存在多个 “svchost”进程(通过“ctrl+alt+del”键打开任务管理器,这里的“进程”标签中就可看到了),为什么会这样呢?下面就来揭开它神秘的面纱。
发现
在基于nt内核的windows操作系统家族中,不同版本的windows系统,存在不同数量的“svchost”进程,用户使用“任务管理器”可查看其进程数目。一般来说,win2000有两个svchost进程,winxp中则有四个或四个以上的svchost进程(以后看到系统中有多个这种进程,千万别立即判定系统有病毒了哟),而win2003 server中则更多。这些svchost进程提供很多系统服务,如:rpcss服务(remote procedure call)、dmserver服务(logical disk manager)、dhcp服务(dhcp client)等。
如果要了解每个svchost进程到底提供了多少系统服务,可以在win2000的命令提示符窗口中输入“tlist -s”命令来查看,该命令是win2000 support tools提供的。在winxp则使用“tasklist /svc”命令。
svchost中可以包含多个服务
深入
windows系统进程分为独立进程和共享进程两种,“svchost.exe”文件存在于“%systemroot% system32”目录下,它属于共享进程。随着windows系统服务不断增多,为了节省系统资源,微软把很多服务做成共享方式,交由 svchost.exe进程来启动。但svchost进程只作为服务宿主,并不能实现任何服务功能,即它只能提供条件让其他服务在这里被启动,而它自己却不能给用户提供任何服务。那这些服务是如何实现的呢?
原来这些系统服务是以动态链接库(dll)形式实现的,它们把可执行程序指向 svchost,由svchost调用相应服务的动态链接库来启动服务。那svchost又怎么知道某个系统服务该调用哪个动态链接库呢?这是通过系统服务在注册表中设置的参数来实现。下面就以rpcss(remote procedure call)服务为例,进行讲解。
从启动参数中可见服务是靠svchost来启动的。
实例
以windows xp为例,点击“开始”/“运行”,输入“services.msc”命令,弹出服务对话框,然后打开“remote procedure call”属性对话框,可以看到rpcss服务的可执行文件的路径为“c:\windows\system32\svchost -k rpcss”,这说明rpcss服务是依靠svchost调用“rpcss”参数来实现的,而参数的内容则是存放在系统注册表中的。
在运行对话框中输入“regedit.exe”后回车,打开注册表编辑器,找到[hkey_local_machine systemcurrentcontrolsetservicesrpcss]项,找到类型为“reg_expand_sz”的键“magepath”,其键值为“%systemroot%system32svchost -k rpcss”(这就是在服务窗口中看到的服务启动命令),另外在“parameters”子项中有个名为“servicedll”的键,其值为“% systemroot%system32rpcss.dll”,其中“rpcss.dll”就是rpcss服务要使用的动态链接库文件。这样 svchost进程通过读取“rpcss”服务注册表信息,就能启动该服务了。
解惑
因为svchost进程启动各种服务,所以病毒、***也想尽办法来利用它,企图利用它的特性来迷惑用户,达到感染、***、破坏的目的(如冲击波变种病毒“w32.welchia.worm”)。但windows系统存在多个svchost进程是很正常的,在受感染的机器中到底哪个是病毒进程呢?这里仅举一例来说明。
假设windows xp系统被“w32.welchia.worm”感染了。正常的svchost文件存在于“c:\windows\system32”目录下,如果发现该文件出现在其他目录下就要小心了。“w32.welchia.worm”病毒存在于“c:\windows\system32wins”目录中,因此使用进程管理器查看svchost进程的执行文件路径就很容易发现系统是否感染了病毒。windows系统自带的任务管理器不能够查看进程的路径,可以使用第三方进程管理软件,如“windows优化大师”进程管理器,通过这些工具就可很容易地查看到所有的svchost进程的执行文件路径,一旦发现其执行路径为不平常的位置就应该马上进行检测和处理。

转载于:https://blog.51cto.com/wangdeshang/71546

SVCHOST.exe进程之谜相关推荐

  1. 揭开SVCHOST.exe进程之谜

    svchost.exe是nt核心 系统的非常重要的进程,对于2000.xp来说,不可或缺.很多 病毒.木马也会调用它.所以,深入了解这个程序,是玩电脑的必修课之一. 大家对windows操作系统一定不 ...

  2. php有个schost.exe_这个“SVCHOST.EXE”是什么进程?

    展开全部 耗尽CPU资源的Explored病毒清除法 出处:网易[ 2005-11-03 10:26:15 ] 作者:佚62616964757a686964616fe78988e69d83313332 ...

  3. Svchost.exe病毒

    Svchost.exe是病毒的两种情况 1.利用假冒Svchost.exe名称的病毒程序 这种方式运行的病毒并没有直接利用真正的Svchost.exe进程,而是启动了另外一个名称同样是Svchost. ...

  4. 看我出招之:svchost.exe文件删不得

    Svchost.exe文件删除不得<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office&qu ...

  5. Svchost.exe是病毒的两种情况

    1.利用假冒Svchost.exe名称的病毒程序 这种方式运行的病毒并没有直接利用真正的Svchost.exe进程,而是启动了另外一个名称同样是Svchost.exe的病毒进程,由于这个假冒的病毒进程 ...

  6. svchost.exe占系统cpu资源的100%解决办法

    症状现象描述: 机器启动运行几分钟后 svchost.exe就会占系统cpu资源的100% 拔掉网线就好了,重连上网后一会儿:svchost.exe又占cpu资源的99%: 解决方法: 假设你已经使用 ...

  7. Svchost.exe占用CPU100%全面解析与进程说明

    在win.ini文件中,在[WINDOWS]下面,"run="和"load="是可能加载"***"程序的途径,必须仔细留心它们.一般情况下, ...

  8. DropFileName = “svchost.exe“ 问题解决方案

    DropFileName = "svchost.exe" 问题解决方案 参考文章: (1)DropFileName = "svchost.exe" 问题解决方案 ...

  9. svchost.exe介绍

    Svchost.exe是微软视窗操作系统里的一个系统进程,管理通过Dll文件启动服务的其它进程,一些病毒***伪装成系统dll文件通过Svchost调用它,试图隐藏自己.每个svchost可以同时调用 ...

最新文章

  1. Spring的Java配置方式
  2. 第四范式携手工银科技 首批入驻雄安人工智能算法开放平台
  3. Modules(最小树形图)
  4. codeforces 842 D. Vitya and Strange Lesson(01字典树+思维+贪心)
  5. python3语法都相同吗_python2 与 python3 语法区别--转
  6. Lync Server 2010迁移至Lync Server 2013部署系列 Part1: 扩展AD架构
  7. 微软RPA工具Power Automate Desktop
  8. atoi、stoi、strtoi区别
  9. 京东拼多多全面封杀电子烟,淘宝仍正常销售...
  10. 【渝粤题库】广东开放大学 秘书理论与实务(1) 形成性考核
  11. 手机界的革命-云手机(华为云)
  12. springboot使用@Async实现异步操作
  13. Windows下80端口被进程System占用的解决方法
  14. 无法初始化windows sockets
  15. Axure RP 8 软件介绍
  16. b站上的计算机课程有哪些,B站课程排行榜,这届大学生最爱学什么?
  17. Microsoft ADO Data Control,version 6.0(OLEDB) 不支持此接口
  18. 微擎微信公众号消息模板
  19. Lunece介绍和简单实用
  20. contest17 CF593 div2 ooxxx ooxxx ooooo

热门文章

  1. Netbeans and Remote Host for C/C++ Developing
  2. can't find a register in class `GENERAL_REGS' while reloading `asm'
  3. python安装成功第三方库但import出问题_为什么会在pyspark在RDD中调用python第三方库失败?...
  4. 小米一键上锁工具_小米智能门锁和猫眼,可女声变男声与访客隔门沟通
  5. 微信小程序码buffer转为图片php,微信小程序将网络图片转成base64数据
  6. 3.9 YOLO算法-深度学习第四课《卷积神经网络》-Stanford吴恩达教授
  7. selinux-添加
  8. 【工具】公网临时大文件传输工具
  9. 【测试】用示波器抓取红外遥控器NEC信号
  10. 第12周学习进度总结