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/

关于VS的版本号:https://docs.microsoft.com/zh-cn/visualstudio/install/visual-studio-build-numbers-and-release-dates?view=vs-2019

我们一般用社区版就行。

如果你之前安装过,那你再次运行安装程序会看到修复和卸载

可能是我运气不好,遇到软件异常报错试了很多办法都不起作用,选了这个修复,太耗时了,远大于全新安装系统、全新下载部署的时间,如果你时间充裕那你可以试一下修复

至于卸载,可以试试,不过最后你要用清理注册表的工具清理下Visual Studio的注册表垃圾

如果是更新失败需要全新安装,你最好分4步走:

  • 运行安装文件,点卸载
  • 清理注册表垃圾
  • 把%ProgramData%MicrosoftVisualStudioPackages文件夹里的内容删除干净
  • 全新安装,务必一次性成功,不要暂停或中断

②修复

上面已经提了,尽量不选这个

③打Windows补丁:KB947821

毛用没有,不过我还是列下补丁地址吧

32位Win7 SP1/2008R2

https://www.microsoft.com/zh-cn/download/details.aspx?id=3132

https://download.microsoft.com/download/4/7/A/47A0F7B9-1F0F-41B0-AA42-00FD16337268/Windows6.1-KB947821-v34-x86.msu

64位Win7 SP1/2008R2

https://www.microsoft.com/zh-cn/download/details.aspx?id=20858

https://download.microsoft.com/download/E/8/D/E8DAA970-1036-447F-B5EA-716D4BA70EC5/Windows6.1-KB947821-v34-x64.msu

④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空间的提醒

后来我转化成中文的网页才注意到

英文文档:https://docs.microsoft.com/en-us/visualstudio/install/create-an-offline-installation-of-visual-studio?view=vs-2019

中文文档:https://docs.microsoft.com/zh-cn/visualstudio/install/create-an-offline-installation-of-visual-studio?view=vs-2019

URL里,就代表语言的en-us和zh-cn不同,其他都一样

如果你安装VS2019,强烈建议把微软官网文档认认真真读几遍,尤其里文档里彩色背景标记的注意事项,一定要多读几遍,否则看网上那些爱分享的人的简易文档极易踩坑,他们只顾自己爽,哪管别人死活,很多注意事项都不提。

你还是看微软文档比较好,我重点提几个地方:

  • 容量,35G,我在云服务器上买了40G的云盘专门用来存放VS离线安装文件
  • 证书,下载好离线安装文件后,里面有个证书目录,其中有3个证书,在安装VS之前需要分别双击导入这3个证书,按默认的下一步、下一步,直到最后,中途无需自己做其他选择,就默认到底就行。
  • 如果你已经成功安装社区版,需要联网激活下
  • 关于下载离线安装包的命令

由于VS分了很多模块,按模块安装需要知道模块名称,下载你需要的模块的离线文件即可,要不然35G的全文件下载下来也是很耗时的

https://docs.microsoft.com/zh-cn/visualstudio/install/workload-component-id-vs-community?view=vs-2019

左侧你可以切换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"

Exit mobile version