msvcr120.dll丢失、程序无法正常启动(0xc000007b)以及vcredist的安装问题

msvcr120.dll丢失、程序无法正常启动(0xc000007b)以及vcredist的安装问题

最近想在windows 7上使用一下mysql 5.7版,在网站上https://dev.mysql.com/下载相关版本之后(MySQL Community Server,5.7.28 GA,x64,noinstall的zip包,因为还没有打算将mysql安装到系统,所以没有选择MySQL Installer for Windows)。下载完成之后,解压缩进入bin目录执行mysqld --help命令,首先就报出“无法启动此程序,因为计算机中丢失MSVCR120.dll”,在网上找到靠谱方法之后,发现是要安装“Visual C++ Redistributable Packages for Visual Studio 2013”(简称vcredist;该安装包中包含msvcr120.dll;注意,软件包分为x86和x64两个版本,32位系统安装x86版本即可,64位系统x64和x86两个版本都需要安装)。装完之后重新执行命令,msvcr120.dll丢失的错误确实没有了,但是又冒出个“应用程序无法正常启动(0xc000007b)”的错误。网上搜索后发现还是dll问题,仍然是要安装vcredist,于是我就纳闷了——我已经安装了。按照文章提示使用Dependency Walker工具来查看一下mysqld.exe(启动工具后直接打开.exe文件即可),打开后确实提示一个错误,具体而言是msvcp120.dll的版本不对。mysqld是64位版本,而该工具显示mysqld.exe载入的是一个32位版本的msvcp120.dll(在工具中,64位的文件的图标上有64位标记)。这就比较奇怪了。明明两个版本的vcredist都安装了,怎么还出现这种问题。进入c:\windows,执行dir /s ms*120*.dll,结果如下:

C:\Windows>dir /s ms*120*.dll
 驱动器 C 中的卷是 OS
 卷的序列号是 0004-6402

 C:\Windows\System32 的目录

2018/03/02  20:52           455,328 msvcp120.dll
2013/10/04  23:58           963,232 msvcr120.dll
               2 个文件      1,418,560 字节

 C:\Windows\SysWOW64 的目录

2013/10/05  02:38           455,328 msvcp120.dll
2013/10/22  13:13           970,912 msvcr120.dll
               2 个文件      1,426,240 字节

再进一步通过md5工具检查,发现两个目录下的msvcp120.dll是完全一样的(一般来说,对于64位系统,x86的dll是安装在c:\windows\sysWOW64下面,而x64的dll是安装在c:\windows\system32目录下)。很奇怪啊,不过先不管了,先试试重装。在“控制面板/程序和功能”下将vcredist 2013的两个版本都卸掉,然后再执行上面的dir命令,然后,——奇怪啊,上面的dll都还在。没办法,先手动删除这四个dll,然后重新安装vcredist 2013的两个版本的软件包,安装完之后,再用dir命令一看,傻眼了,这四个dll还是没有啊——重装大法失灵了,这下连装都装不上了。最后,因为知道vcredist有一个修复功能(在程序和功能列表里面,右键vcredist的相关条目——注意选择正确的2013版本——选择“更改”,在弹出的对话框中选择“修复”;x86和x64版本都执行这个操作),执行完之后,发现上面四个dll又回来了,而且文件有变化:

C:\Windows>dir /s ms*120.dll
 驱动器 C 中的卷是 OS
 卷的序列号是 0004-6402

 C:\Windows\System32 的目录

2013/10/04  23:58           660,128 msvcp120.dll
2013/10/04  23:58           963,232 msvcr120.dll
               2 个文件      1,623,360 字节

 C:\Windows\SysWOW64 的目录

2013/10/05  02:38           455,328 msvcp120.dll
2013/10/05  02:38           970,912 msvcr120.dll
               2 个文件      1,426,240 字节

现在看到msvcp120.dll的两个文件,在大小上就不相同了。用dependency walker工具查看,可以确认system32目录下的msvcp120.dll确实是64位的了。然后再执行mysqld --help命令就能正常执行了。

总结:搞了半天,问题实际上是两个。一是对vcredist 2013的依赖问题(mysql 5.7.28是依赖2013这个版本,其实在5.7的文档中关于安装的章节中,一开始就提到了这个依赖);二是vcredist的安装问题。不知道是安装程序的bug还是更新dll的机制不同,vcredist安装后并没有按照我们用户想象的那样,将合适的dll版本安装到合适的位置上,结果导致程序运行出现另外的问题。这个问题我看网上的文档提得不多,所以写篇博客重新提下这个问题。

参考:
[1] MySQL程序下载地址. https://dev.mysql.com/
[2] Dependency walker工具. http://dependencywalker.com/
[3] vcredist 2013下载. https://www.microsoft.com/zh-CN/download/details.aspx?id=40784
[4] vcredist的各版本. https://www.itechtics.com/microsoft-visual-c-redistributable-versions-direct-download-links/

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当电脑出现"无法启动程序,因为计算机中丢失msvcr120.dll"的错误提示时,意味着缺少了msvcr120.dll文件,该文件是由Microsoft提供的用于运行一些应用程序的重要动态链接库(Dynamic Link Library,简称DLL)。 要解决这个问题,可以尝试以下几个方法: 1. 重新安装相关程序:首先,尝试重新安装引发错误的程序。当重新安装程序时,相关依赖库文件通常会被也一同安装。这样可以确保msvcr120.dll文件被正确安装到计算机中。 2. 从其他电脑复制文件:如果您可以从其他同版本Windows的电脑中找到msvcr120.dll文件,可以将其复制到丢失文件的计算机上。请注意,复制前应备份现有的msvcr120.dll文件,以防复制出错。 3. 从网络下载msvcr120.dll文件:您可以从可靠的网站上下载msvcr120.dll文件,然后将其放置到正确的文件路径下。请务必选择可靠和受信任的来源进行下载,以避免下载到恶意软件。 4. 运行Windows更新:有时,缺少msvcr120.dll文件的问题可能是由于系统未更新导致的。在运行Windows更新后,系统会自动检查并安装缺少的文件。 需要注意的是,在尝试任何修改系统文件的操作之前,应备份计算机上的重要数据。此外,为了确保计算机的安全性,建议从可信赖的来源获取所需的DLL文件。 如果以上方法都无法解决问题,建议联系计算机技术支持专家或联系软件开发商获取进一步帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值