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/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值