Visual Studio 2019 惨痛 踩坑 经历 0x80070490 0x80040154
- 2020 年 3 月 29 日
- 筆記
我并不是程序员,用VS2019也就最近一个月的事,前段时间用VS2019跑腾讯云的API Explorer工具里的6种SDK时用它搞PythonSDK Node.jsSDK .NETSDK来着。后来莫名其妙VS软件出了问题,老是报错 (异常来自 HRESULT:0x80070490),但是用CMD命令行调试程序是正常的,用VS软件调试软件就报这个错:
System.Runtime.InteropServices.COMException: 找不到元素。 (异常来自 HRESULT:0x80070490) (内部异常 #0) System.Runtime.InteropServices.COMException (0x80070490): 找不到元素。 (异常来自 HRESULT:0x80070490)
网上找了一圈,耗费了好几天验证修复方案,此处我省略一万个fu*k。
先说下经验总结:不论是Visual Studio 2017/2019的安装、更新、卸载、下载离线文件等,不要暂停,必须一次性成功,如果暂停了,建议重装系统从新来一遍。尤其是更新,未更新完成之前不要重启机器!!!我这次出问题就是VS更新导致的,可能更新了一半手动重启了。
汇总下网上关于0x80070490报错的方案:
①卸载重装
②修复
③打Windows补丁
④运行InstallCleanup.exe
⑤缺VC库,安装VC库
⑥IIS可能坏了,卸载重装IIS
⑦离线安装
接下来我挨个说下里面的坑
①卸载重装
https://visualstudio.microsoft.com/zh-hans/downloads/
我们一般用社区版就行。
如果你之前安装过,那你再次运行安装程序会看到修复和卸载
可能是我运气不好,遇到软件异常报错试了很多办法都不起作用,选了这个修复,太耗时了,远大于全新安装系统、全新下载部署的时间,如果你时间充裕那你可以试一下修复
至于卸载,可以试试,不过最后你要用清理注册表的工具清理下Visual Studio的注册表垃圾
如果是更新失败需要全新安装,你最好分4步走:
- 运行安装文件,点卸载
- 清理注册表垃圾
- 把%ProgramData%MicrosoftVisualStudioPackages文件夹里的内容删除干净
- 全新安装,务必一次性成功,不要暂停或中断
②修复
上面已经提了,尽量不选这个
③打Windows补丁:KB947821
毛用没有,不过我还是列下补丁地址吧
32位Win7 SP1/2008R2
https://www.microsoft.com/zh-cn/download/details.aspx?id=3132
64位Win7 SP1/2008R2
https://www.microsoft.com/zh-cn/download/details.aspx?id=20858
④I最坑的就是运行%programfiles(x86)%Microsoft Visual StudioInstallerresourcesapplayoutInstallCleanup.exe
执行了installcleanup就没办法正常卸载了,但一开始我并不知道这一点
执行后还是报错,但是报错信息发生变化了
从 0x80070490 变成了 0x80040154
当时那个报错文件的位置是:C:UsersAdministratorAppDataLocalTemp2VsProjectFault_5beda864-f2de-4bfe-a84f-58ab85643b30.failure.txt
Line 4: System.AggregateException: 发生一个或多个错误。 —> System.Runtime.InteropServices.COMException: 检索 COM 类工厂中 CLSID 为 {177F0C4A-1CD3-4DE7-A32C-71DBBB9FA36D} 的组件失败,原因是出现以下错误: 80040154 没有注册类 (异常来自 HRESULT:0x80040154 (REGDB_E_CLASSNOTREG))。
Line 34: —> (内部异常 #0) System.Runtime.InteropServices.COMException (0x80040154): 检索 COM 类工厂中 CLSID 为 {177F0C4A-1CD3-4DE7-A32C-71DBBB9FA36D} 的组件失败,原因是出现以下错误: 80040154 没有注册类 (异常来自 HRESULT:0x80040154 (REGDB_E_CLASSNOTREG))。
再强调一遍:installcleanup一执行,你就没法正常点卸载按钮了,无法正常卸载就只能手动删除,谁这么牛逼能快速、干净地删完VS?本来还有个卸载,执行了InstallCleanup后,卸载按钮就找不到了,你要想节省点时间,重装系统从头来过会比较省时间。千万别再浪费时间测试其他方案了。
⑤缺VC库,安装VC库
网上还说缺VC库,我安装了最全最新的VC库也还是不起作用。在网上搜“微软常用运行库合集”或“2020 VisualCppRedist_AIO_x86_x64”下载安装即可。
Windows平台很多软件都依赖VB、VC库,比如Windows安装PHP环境,如果你不安装VC库,你的PHP源码就没法正常解析。微软自己的很多软件安装过程中都自动安装VC库,所以我们平常很少需要单独安装VC库,但第三方软件不一样,需要我们自己安装下软件依赖的VC库。
我目前用的20200317版,http://www.opdown.com/soft/212262.html
安装过程中杀毒软件可能会拦截,请信任之。
⑥IIS可能坏了
思路:卸载IIS、暂时先不重装IIS
近来我直接在IIS里调试网站是正常的,我不觉得是IIS的问题,另外,console代码调试也用不到IIS,但仍然报错0x80070490就很奇怪了 2008R2的IIS是7.5
VS2019带的IIS是IIS10 Express,有可能是IIS10 .0 Express出问题了
卸载了系统自带的IIS和VS2019带的IIS10.0 Express,没再安装,通过VS2019调试console代码仍然报错HRESULT:0x80070490,通过CMD命令行调试是正常的。
总之,就不是IIS的事。我IIS一直是好的,最近对VS2019干过的操作就是硬盘剩余空间不足,我把存放VS2019 package的将近5GB的文件夹C:ProgramDataMicrosoftVisualStudioPackages里的内容给删了
从报错信息看,最开头的几行如下
System.AggregateException: 发生一个或多个错误。 —> System.Runtime.InteropServices.COMException: 找不到元素。 (异常来自 HRESULT:0x80070490)
在 Microsoft.VisualStudio.Setup.Configuration.ISetupConfiguration.GetInstanceForCurrentProcess()
其中的“异常来自 HRESULT:0x80070490”经常在IIS场景中碰到,大不了重装下IIS,此外最关键的就是Microsoft.VisualStudio.Setup.Configuration.ISetupConfiguration
VisualStudio.Setup.Configuration顾名思义跟VS的安装配置有关,正好我把存放VS安装包的文件夹清理,是否重新下载一份放到原位置就可以了?
通过以上分析,这个报错我觉得跟VS的更新有关。
这让我想起来,我安装VS2019用了段实际,给我推送过几次更新,第一次的我安装后系统盘剩余空间越来越小,第二次推送的我点了下,但是没有安装,然后用了段实际,剩余空间不够用了,我就把存放安装包的文件夹删掉了,然后过了不久发现报错HRESULT:0x80070490。
⑦离线安装
第一步,把安装文件下载到机器,需要35G的空间,要不然会中途失败,然后你重新开始的耗时是全新下载的N倍,因为它下载过程中要校验进度、校验已经存在的文件是否完好,一两个文件检验就算了,是若干G甚至一二十G的N多个文件校验……
就这个35G空间的事,网上那些爱分享的人可没一个提及,微软官网文档倒是提了,你如果没仔细看不容易注意到,可能是我运气不好或者英语不好吧
我第一次搜到的文档是英文的,没有第一眼注意到至少35G空间的提醒
后来我转化成中文的网页才注意到
URL里,就代表语言的en-us和zh-cn不同,其他都一样
如果你安装VS2019,强烈建议把微软官网文档认认真真读几遍,尤其里文档里彩色背景标记的注意事项,一定要多读几遍,否则看网上那些爱分享的人的简易文档极易踩坑,他们只顾自己爽,哪管别人死活,很多注意事项都不提。
你还是看微软文档比较好,我重点提几个地方:
- 容量,35G,我在云服务器上买了40G的云盘专门用来存放VS离线安装文件
- 证书,下载好离线安装文件后,里面有个证书目录,其中有3个证书,在安装VS之前需要分别双击导入这3个证书,按默认的下一步、下一步,直到最后,中途无需自己做其他选择,就默认到底就行。
- 如果你已经成功安装社区版,需要联网激活下
- 关于下载离线安装包的命令
由于VS分了很多模块,按模块安装需要知道模块名称,下载你需要的模块的离线文件即可,要不然35G的全文件下载下来也是很耗时的
左侧你可以切换VS的版本,不同版本的VS对应的模块可能不太一样,上面URL是社区版的模块
我用的社区版的这几个模块
- Visual Studio 核心编辑器(Visual Studio Community 2019 随附)Microsoft.VisualStudio.Workload.CoreEditor
- ASP.NET 和 Web 开发 Microsoft.VisualStudio.Workload.NetWeb
- Python 开发 Microsoft.VisualStudio.Workload.Python
- Node.js 开发 Microsoft.VisualStudio.Workload.Node
- .NET 桌面开发 Microsoft.VisualStudio.Workload.ManagedDesktop
- 使用 C++ 的桌面开发 Microsoft.VisualStudio.Workload.NativeDesktop
- 通用 Windows 平台开发(UWP) Microsoft.VisualStudio.Workload.Universal
- 独立组件:适用于 Visual Studio 的 GitHub 扩展 Component.GitHub.VisualStudio
命令1:下载离线文件
vs_setup.exe –layout e:vslayout –add Microsoft.VisualStudio.Workload.CoreEditor –add Microsoft.VisualStudio.Workload.NetWeb –add Microsoft.VisualStudio.Workload.Python –add Microsoft.VisualStudio.Workload.Node –add Microsoft.VisualStudio.Workload.ManagedDesktop –add Microsoft.VisualStudio.Workload.NativeDesktop –add Microsoft.VisualStudio.Workload.Universal –add Component.GitHub.VisualStudio –includeRecommended –lang zh-CN
实例中的vs_setup.exe是我自己重命名的,刚下载的文件名字很长,你可以重命名成简单的名字,layout的路径也可以自定义
刚回车如上图
自动下载的第一个文件夹就是证书,里面有3个证书
整体来说,在云服务器上下载挺快的,15:04刚回车,15:14就已经快75%的下载进度了,10分钟下载了3/4,后来到95%进度时卡住了一段时间。如果中途你看到卡住不动了,其实没卡住,你要保持耐心,最多1个小时就下载完了。如果你下载的是完整版,我实测了下,差不多得花20个小时以上。
下载完以后在layout目录有几个json文件,如果你用通过–add新增其他的模块或者就想去掉几个-add模块,你执行命令之前得删掉这几个json文件。
{ "installChannelUri":".ChannelManifest.json", "channelUri":"https://aka.ms/vs/16/release/channel", "installCatalogUri":".Catalog.json", "channelId":"VisualStudio.16.Release", "productId":"Microsoft.VisualStudio.Product.Community", "add":[ "Component.GitHub.VisualStudio;includeRecommended", "Microsoft.VisualStudio.Workload.CoreEditor;includeRecommended", "Microsoft.VisualStudio.Workload.ManagedDesktop;includeRecommended", "Microsoft.VisualStudio.Workload.NativeDesktop;includeRecommended", "Microsoft.VisualStudio.Workload.NetWeb;includeRecommended", "Microsoft.VisualStudio.Workload.Node;includeRecommended", "Microsoft.VisualStudio.Workload.Python;includeRecommended", "Microsoft.VisualStudio.Workload.Universal;includeRecommended" ], "addProductLang":[ "zh-CN" ] }
【命令解析】
–layout e:vslayout是指定离线文件存放位置,每一个Workload都必须用–add隔离
–includeRecommended顾名思义就是推荐安装,你知道完整安装VS2019需要多大空间吗?140GB,不算离线文件的35GB,耗费180G空间,很多很多时间。
我一般选–includeRecommended这个参数,要不然太大,硬盘放不下,我的SSD硬盘只有256G(实际要打个(1000/1024)^3的折扣),平时就没多少空间可用。另外就是太费时间了。
命令2:进入离线文件目录进行安装
cd /d 离线文件目录
执行如下命令之前先考虑下你要不要换默认安装路径
另外就是必须在执行命令之前导入之前说的3个证书
vs_setup.exe –add Microsoft.VisualStudio.Workload.CoreEditor –add Microsoft.VisualStudio.Workload.NetWeb –add Microsoft.VisualStudio.Workload.Python –add Microsoft.VisualStudio.Workload.Node –add Microsoft.VisualStudio.Workload.ManagedDesktop –add Microsoft.VisualStudio.Workload.NativeDesktop –add Microsoft.VisualStudio.Workload.Universal –add Component.GitHub.VisualStudio –includeRecommended
参数安装示例:https://docs.microsoft.com/zh-cn/visualstudio/install/command-line-parameter-examples?view=vs-2019
你自己可以指定安装位置,–path这个参数很重要
安装这些大概需要23GB吧,选下载完安装
你这里会困惑,既然都有离线文件了,为什么还要选下载中安装或下载完安装
原因是VS有个安装包的默认存放位置,会把离线文件夹里的文件拿到这个存放位置,算从本地离线包位置下载到那个默认包存放位置
总结:如果你安装失败了或者遇到异常了,建议你卸载后清理注册表然后重装,重装的时候可以用–path指定3个路径-path install="C:VS" –path cache="C:VScache" –path shared="C:VSshared"
注意:微软文档也有不对的地方,如果你按文档示例里同时指定–path install="C:VS" 和–path cache="C:VScache"会报错“根安装路径不能与包缓存路径重叠”,同时指定–path install="C:VS"和–path shared="C:VSshared"会报错“根安装路径不能与共享安装路径重叠”。因此我们换个位置,用–path install="C:VS" –path cache="C:VS_cachecache" –path shared="C:VS_sharedshared"