1. 现象:失控的 CPU
近期我的电脑风扇狂转,系统卡顿明显。打开任务管理器,我发现 svchost.exe 和 System 进程长期霸占 CPU 榜首,总占用率居高不下。这不仅拖慢了工作节奏,电脑发热也让人不安。
此次故障的特征是典型的“多重并发”:
- 资源黑洞:主要集中在两个
svchost.exe进程(PID 1660 和 1576)。 - 定位模糊:其中 PID 1660 像个大杂烩,包含电源、即插即用、DCOM 等多个核心服务,根本看不出谁是主谋。
- 报错轰炸:系统日志里满屏都是红色的 Schannel(TLS/SSL)错误和驱动加载失败警告。
2. 第一阶段:拨开云雾——服务拆分与精准定位
2.1 起手:谁在占用?
在着手处理之前,我首先参考了微软官方的 Windows Server 高 CPU 使用率故障排除指南 来规范我的排查思路。
为了搞清楚这些 svchost.exe 肚子里到底卖的什么药,我首先以管理员身份运行 PowerShell,输入了一条监控命令:
Get-Process | Sort-Object CPU -Descending | Select-Object -First 10
我看到的返回结果(部分):
Handles NPM(K) PM(K) WS(K) CPU(s) Id SI ProcessName
------- ------ ----- ----- ------ -- -- -----------
1390 28 14832 47196 3,626.14 1660 0 svchost
125 14 4092 10600 3,613.88 1576 0 svchost
PID 1660 和 1576 的 CPU 时间(CPU(s))遥遥领先,确实是它们。
紧接着,我用命令扒开了 PID 1660 的外衣:
Get-WmiObject Win32_Service | Where-Object {$_.ProcessId -eq 1660} | Select-Object Name, DisplayName
结果显示: 这里面挤着 BrokerInfrastructure, DcomLaunch, PlugPlay, Power, SystemEventsBroker。这就难办了,必须让它们分家。
2.2 进阶:强制分家
为了抓住真凶,我决定把这些服务拆开,让它们各自跑在独立的进程里。
这里我踩了个坑:直接用了 sc config ...,结果 PowerShell 报错:
Set-Content : 找不到接受实际参数“type=”的位置形式参数。
避坑指南:在 PowerShell 里 sc 是 Set-Content 的别名。必须加后缀 sc.exe。
我随后正确执行了拆分命令(部分核心服务因权限保护无法拆分,跳过即可):
sc.exe config Power type= own
sc.exe config PlugPlay type= own
sc.exe config BrokerInfrastructure type= own
2.3 重启后的真相
重启电脑后,PID 变了,但我再次运行 Get-Process 和服务查询命令,发现了惊人的一幕:
Get-WmiObject Win32_Service | Where-Object { $_.ProcessId -in 1976, 1796, 1768, 1500 } | Select-Object ProcessId, Name, DisplayName | Format-Table -AutoSize
新的嫌疑人列表:
- PID 1768 -> Plug and Play (即插即用) -> 持续高占用
- PID 1796 -> Power (电源) -> 持续高占用
- PID 1500 -> WLAN AutoConfig (无线网络) -> 持续高占用
电源、硬件识别、无线网络,这三者同时炸锅,几乎可以断定:有一个跟网络相关的硬件驱动正在底层疯狂报错。
3. 第二阶段:深挖根因——“僵尸”驱动与 TLS 阻塞
3.1 查日志:找到元凶
我立刻去查系统日志,想看看系统到底在报怨什么:
Get-EventLog -LogName System -EntryType Error,Warning -Newest 20 | Format-Table -AutoSize
日志直接破案:
- Schannel Error 36871:“创建 TLS 客户端凭据时出现严重错误。” —— 这说明加密通道堵死了,难怪网络相关服务卡顿。
- Kernel-PnP Warning 219:“驱动程序\Driver\WUDFRd 加载失败。” —— 某个硬件驱动挂了。
- Service Control Manager Error:“等待 wZHldtJXn 服务的连接超时。” —— 乱码服务名! 这是典型的恶意软件或残留程序的特征。
结合前段时间的弹窗(提示 Sangfor 服务禁止加载),真相大白:Sangfor(深信服/EasyConnect)的残留组件在作祟。 它的虚拟网卡驱动坏了,导致系统不断尝试加载、失败、重试,引发了这一连串的 CPU 风暴。
4. 第三阶段:终极修复方案
光卸载软件已经不够了,我必须进行一次彻底的“大扫除”。
步骤 A:斩草除根(卸载与停止服务)
首先,我去控制面板(appwiz.cpl)卸载了所有深信服相关的软件。
但我担心有残留,于是加了一道保险,强制停止所有相关服务:
Stop-Service -Name "Sangfor*" -Force -ErrorAction SilentlyContinue
Set-Service -Name "Sangfor*" -StartupType Disabled -ErrorAction SilentlyContinue
为了彻底清理,我还手动去注册表 (regedit) 删除了 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services 下那个看着就烦的乱码服务 wZHldtJXn 和所有 Sangfor 开头的项。
步骤 B:重置网络堆栈
既然网络层已经乱套了,我决定把网络协议栈彻底重置一番:
netsh winsock reset
netsh int ip reset
执行反馈: 屏幕上一排排的“正在重置…完成!”,最后提示“成功地重置 Winsock 目录”。这让我心里踏实了不少。
步骤 C:修复系统完整性与证书缓存(关键一招)
针对日志里漫天的 TLS 报错,我祭出了杀手锏:
# 1. 修复系统映像(耗时较长,耐心等待)
DISM /Online /Cleanup-Image /RestoreHealth
# 2. 检查系统文件完整性
sfc /scannow
惊喜的反馈:
DISM: “[100.0%] 还原操作已成功完成。”SFC: “Windows 资源保护未找到任何完整性冲突。”
最后,我清理了那些可能已经损坏的证书缓存:
certutil -urlcache * delete
屏幕上滚动过一大串 URL,都是被清理掉的旧缓存。
5. 第四阶段:验证与复盘
5.1 重启后的终极验证
做完上述所有操作,重启计算机是必须的,否则驱动卸载不会生效。
重启后,我强忍住操作的冲动,静置电脑 2 分钟,然后开始验收:
- 观察 CPU 与任务管理器:
- 动作:打开任务管理器 (Ctrl+Shift+Esc)。
- 结果:世界安静了!CPU 总使用率回落到了 5%-10% 的正常待机水平。
svchost乖乖地排到了后面。
- 检查残留驱动:
- 动作:运行
Get-NetAdapter。 - 结果:列表中只剩下了我的 Intel 物理网卡和蓝牙,那些
Sangfor VPN虚拟网卡彻底消失了。
- 动作:运行
- 复查系统日志:
- 动作:再次运行
Get-EventLog ...。 - 结果:那让人头皮发麻的
Schannel 36871和Kernel-PnP 219全部消失。
- 动作:再次运行
5.2 补充:解决“TLS 内部错误状态 10013”
在解决完 CPU 占用主体问题后,我在事件查看器中留意到一个顽固的报错:“创建 TLS 客户端凭据时出现严重错误。内部错误状态为 10013。”
针对这个问题,我参考了 Microsoft Q&A 社区关于 TLS 10013 的讨论,并采用了志愿者审查方 JinQiao Li 提供的解决方案。该错误通常因旧版协议(SSL 3.0/TLS 1.0/1.1)配置不兼容导致。
具体修复步骤如下:
- 按
Win+R,输入control打开控制面板。 - 进入 Internet 选项 -> 切换到 高级 选项卡。
- 在“安全”列表中:
- 取消勾选:SSL 3.0, TLS 1.0, TLS 1.1。
- 仅勾选:使用 TLS 1.2(根据情况也可保留 TLS 1.3)。
- 点击应用并确定,再次重启电脑。
此操作成功消除了剩下的 TLS 安全连接错误。
5.3 避坑心得
- 别信自动更新:EasyConnect 这种 VPN 软件,版本不符时千万别点自动登录,很容易陷入死循环。建议使用geek软件卸载干净后,去电脑的软件商店下载(我也不知道为什么,这样下载的版本不会出现软件与服务器版本不符)。
- sc命令要加exe:PowerShell 里用
sc真的会怀疑人生,记得它是别名。 - 日志不会骗人:当任务管理器看不出所以然时,Event Viewer 往往直接指出了病灶。
本文记录了我的一次真实排查经历,如果你也遇到了莫名其妙的 CPU 高占用,希望这份笔记能帮你少走弯路!

317

被折叠的 条评论
为什么被折叠?



