Похрустев немного жестким диском, красивый инсталятор показал мне совершенно некрасивое сообщение об ошибке. Вот такое:
Хм. Не поставился значит, Team Explorer и ещё пару минорных пакетов. Ну ок. Закрываем, переустанавливаем. Не помогает. Удаляем студию, перезагружаемся, устанавливаем — та же ошибка. Лезем в Гугл с вопросом об ошибке установки Visual Studio 2015 на этапе инсталляции компонента Team Explorer и понимаем, что проблема это массовая — десятки ссылок с тем же описанием:
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17
Отвечают на все эти вопросы специалисты первой линии техподдержки Microsoft, советы которых сводятся к «отключите антивирус», «проверьте чексуму образа со студией», «проверьте диск на ошибки». Ничего из этого, конечно, не помогает, о чём им и рассказывают, после чего они пропадают и больше не отвечают. Очень дружелюбная пользовательская поддержка, ничего не скажешь.
Ну что же, пора включать голову, брать в руки инструменты и разбираться. Поехали.
Итак, всё что у нас есть, это входная точка ошибки — проблема с Team Explorer. И ссылочка на лог-файл на приведённом выше скриншоте. Ну ок, давайте пойдём почитаем что там лог-файл думает о нашей ошибке.
[15FC:1A18][2015-11-26T17:30:17]i000: MUX: ExecutePackageBegin PackageId: vs_teamExplorerCore
[2118:2240][2015-11-26T17:30:17]i301: Applying execute package: vs_teamExplorerCore, action: Install, path: C:\ProgramData\Package Cache\{791295AE-3B0A-3222-9E69-26C8C106E8D1}v14.0.23102\packages\TeamExplorer\Core\vs_teamExplorerCore.msi, arguments: ' MSIFASTINSTALL="7" USING_EXUIH="1"'
[15FC:1A18][2015-11-26T17:31:06]i000: MUX: ExecuteError: Package (vs_teamExplorerCore) failed: Error Message Id: 1722 ErrorMessage: There is a problem with this Windows Installer package. A program run as part of the setup did not finish as expected. Contact your support personnel or package vendor.
[2118:2240][2015-11-26T17:31:09]e000: Error 0x80070643: Failed to install MSI package.
[2118:2240][2015-11-26T17:31:09]e000: Error 0x80070643: Failed to execute MSI package.
[15FC:1A18][2015-11-26T17:31:09]e000: Error 0x80070643: Failed to configure per-machine MSI package.
[15FC:1A18][2015-11-26T17:31:09]i000: MUX: Installation size in bytes for package: vs_teamExplorerCore MaxAppDrive: 0 MaxSysDrive: 440487936 AppDrive: 0 SysDrive: 263573504
[15FC:1A18][2015-11-26T17:31:09]i000: MUX: Return Code:0x80070643 Msi Messages:There is a problem with this Windows Installer package. A program run as part of the setup did not finish as expected. Contact your support personnel or package vendor. Result Detail:0 Restart:None
[15FC:1A18][2015-11-26T17:31:09]i000: MUX: Set Result: Return Code=-2147023293 (0x80070643), Error Message=There is a problem with this Windows Installer package. A program run as part of the setup did not finish as expected. Contact your support personnel or package vendor. , Result Detail=, Vital=True, Package Action=Install, Package Id=vs_teamExplorerCore
[15FC:1A18][2015-11-26T17:31:09]i000: Setting string variable 'BundleResult' to value '1603'
[15FC:1A18][2015-11-26T17:31:09]i319: Applied execute package: vs_teamExplorerCore, result: 0x80070643, restart: None
[15FC:1A18][2015-11-26T17:31:09]e000: Error 0x80070643: Failed to execute MSI package.
Всё, что можно понять из этого лога, это то что компонент ставился-ставился, да что-то не поставился. Бывает, мол, чего уж там. Ну, спасибо большое за информацию!
Ладно, давайте зайдём с другой стороны. Team Explorer это (как и почти всё в современных версиях Visual Studio) — VSIX (компонент, расширение). Ставится отдельно от ядра студии специальной программой VSIXInstaller.exe, которая живёт в C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE и умеет при установке этих самых VSIX-компонентов писать во временную папку (ну, ту, которая %TEMP%) логи о том, как всё прошло. Идём в %TEMP%, находим по времени ошибки из лога выше файлик, соответствующий установке Team Explorer. Вот он:
26.11.2015 17:31:01 - Microsoft VSIX Installer
26.11.2015 17:31:01 - -------------------------------------------
26.11.2015 17:31:01 - Initializing Install...
26.11.2015 17:31:01 - Extension Details...
26.11.2015 17:31:01 - Identifier : Microsoft.VisualStudio.TeamFoundation.TeamExplorer.Extensions
26.11.2015 17:31:01 - Name : Team Foundation Team Explorer Extensions
26.11.2015 17:31:01 - Author : Microsoft
26.11.2015 17:31:01 - Version : 14.0.23102
26.11.2015 17:31:01 - Description : Team Foundation extensions for Team Explorer
26.11.2015 17:31:01 - Locale : en-US
26.11.2015 17:31:01 - MoreInfoURL :
26.11.2015 17:31:01 - InstalledByMSI : False
26.11.2015 17:31:01 - SupportedFrameworkVersionRange : [0.0,2147483647.2147483647]
26.11.2015 17:31:01 -
26.11.2015 17:31:06 - SignedBy : Microsoft Corporation
26.11.2015 17:31:06 - Certificate Info : [Subject]
CN=Microsoft Corporation, OU=MOPR, OU=OPC, O=Microsoft Corporation, L=Redmond, S=Washington, C=US
[Issuer]
CN=Microsoft Code Signing PCA 2010, O=Microsoft Corporation, L=Redmond, S=Washington, C=US
[Serial Number]
33000000A81581DB462EBDD9480000000000A8
[Not Before]
05.03.2015 1:42:40
[Not After]
05.06.2016 2:42:40
[Thumbprint]
EFCF3B47C17854AB6E4C63821DE31A59B24D62B2
26.11.2015 17:31:06 - Supported Products :
26.11.2015 17:31:06 - Microsoft.VisualStudio.IntegratedShell
26.11.2015 17:31:06 - Version : [14.0]
26.11.2015 17:31:06 - Microsoft.VisualStudio.Express_All
26.11.2015 17:31:06 - Version : [14.0]
26.11.2015 17:31:06 -
26.11.2015 17:31:06 - References :
26.11.2015 17:31:06 -
26.11.2015 17:31:06 - Searching for applicable products...
26.11.2015 17:31:06 - System.TypeInitializationException: The type initializer for 'VSIXInstaller.SupportedSKUs' threw an exception. ---> System.BadImageFormatException: Could not load file or assembly 'Microsoft.VisualStudio.Settings.14.0.dll' or one of its dependencies. is not a valid Win32 application. (Exception from HRESULT: 0x800700C1)
at VSIXInstaller.SupportedSKUs.AddInstalledIsolatedShells(Version vsVersion)
at VSIXInstaller.SupportedSKUs..cctor()
--- End of inner exception stack trace ---
at VSIXInstaller.SupportedSKUs.get_SupportedSKUsList()
at VSIXInstaller.App.InitializeInstall(Boolean isRepairSupported)
at VSIXInstaller.App.OnStartup(StartupEventArgs e)
26.11.2015 17:31:06 - System.TypeInitializationException: The type initializer for 'VSIXInstaller.SupportedSKUs' threw an exception. ---> System.BadImageFormatException: Could not load file or assembly 'Microsoft.VisualStudio.Settings.14.0.dll' or one of its dependencies. is not a valid Win32 application. (Exception from HRESULT: 0x800700C1)
at VSIXInstaller.SupportedSKUs.AddInstalledIsolatedShells(Version vsVersion)
at VSIXInstaller.SupportedSKUs..cctor()
--- End of inner exception stack trace ---
at VSIXInstaller.SupportedSKUs.get_SupportedSKUsList()
at VSIXInstaller.App.OnExit(ExitEventArgs e)
Ну, тут уже побольше всякого интересного написано, конечно. Нас интересует первый момент, когда что-то пошло не так. Вот он:
26.11.2015 17:31:06 - System.TypeInitializationException: The type initializer for 'VSIXInstaller.SupportedSKUs' threw an exception. ---> System.BadImageFormatException: Could not load file or assembly 'Microsoft.VisualStudio.Settings.14.0.dll' or one of its dependencies. is not a valid Win32 application. (Exception from HRESULT: 0x800700C1)
Хм, произошла ошибка при попытке загрузить сборку Microsoft.VisualStudio.Settings.14.0.dll. Первой моей мыслью было то, что студия как-то запуталась в порядке установки своих компонентов и пытается использовать при установке что-то, что ещё не установилось куда надо. Так, есть у нас в системе такая библиотека?
Оказалось — есть. Лежит в GAC, там где ей и положено лежать:
Так, что же получается? Сборка есть, она находится там, где нужно, но не загружается. Может быть, битая? Берём IL DASM, загружаем — всё ок.
Может быть умельцы из Microsoft сумели написать такой инсталлятор, у которого иногда получается не найти сборку в GAC? Берём Process Monitor, добавляем в него фильтр на открытие файлов и снова запускаем инсталлятор студии. Доходим до ошибки, смотрим логи.
Так, инсталлятор ищет Microsoft.VisualStudio.Settings.14.0.dll и находит её ровно там, где она и должна быть — в GAC. Ок, что же не так?
Читаем ещё раз сообщение об ошибке: «System.BadImageFormatException: Could not load file or assembly 'Microsoft.VisualStudio.Settings.14.0.dll' or one of its dependencies. is not a valid Win32 application.». Так, если сама Microsoft.VisualStudio.Settings.14.0.dll есть и валидна — может быть дело в одной из её зависимостей? Возвращаемся в Process Monitor и смотрим что там загружается непосредственно после нашей сборки.
Ага, vcruntime140.dll загружается. Это redistributable-библиотека от Visual Studio 2015. Ну, она-то точно должна была поставиться на одном из первых этапов установки! Но давайте проверим, чем уже чёрт не шутит.
Проверка раз — в списке установленных программ:
Проверка два — в папке C:\Windows\SysWOW64\:
Проверка три — это, собственно, «SUCCESSS» в логе Process Monitor:
Последняя проверка — вообще железобетонный аргумент: видите, поискали, попробовали открыть, открылось успешно — значит файл найдён. Всё, подозрения снимаются, идём дальше. Так, какую-же библиотеку инсталлятор VSIX пытается подгрузить следующей по логами Process Monitor?
Как это опять vcruntime140.dll уже в другой папке?! Получается, найдя vcruntime140.dll в папке C:\Windows\SysWOW64\ и успешно её открыв (а мы знаем что так и было по логам выше!) загрузчик зависимостей всё-же почему-то счёл её недостаточно хорошей и отбросил. Как же так?! Это что — не майкрософтовская библиотека? Смотрим свойства:
Да нет, нормальная библиотека. Почему же не загрузилась? Давайте посмотрим на неё внимательнее. Для этого в составе любой версии Visual Studio есть отличная утилита dumpbin. Запускаем её с вот такими ключами:
dumpbin /headers c:\windows\SysWOW64\vcruntime140.dll
и смотрим на результаты:
Microsoft (R) COFF/PE Dumper Version 10.00.40219.01
Copyright (C) Microsoft Corporation. All rights reserved.
Dump of file c:\windows\SysWOW64\vcruntime140.dll
PE signature found
File Type: DLL
FILE HEADER VALUES
8664 machine (x64)
7 number of sections
558CE2FF time date stamp Fri Jun 26 08:28:31 2015
0 file pointer to symbol table
0 number of symbols
F0 size of optional header
2022 characteristics
Executable
Application can handle large (>2GB) addresses
DLL
....
Подождите-подождите… А почему это ты, библиотечка, 64-битная?! Ты же лежишь в папке C:\windows\SysWOW64\, где вообще-то место только 32-битным библиотекам! А ну-ка давайте посмотрим, что же тогда лежит в C:\Windows\System32?
А то же самое (кто не верит в размер — можете проверить каким-нибудь WinMerge, они идентичны). Вы уже уловили, в чём суть? Ошибка закралась в инсталятор Redistributable-компонентов, входящий в инсталятор Visual Studio 2015 — он просто ставит 64-битные версии рантайм-библиотек и в папку для 64-битных библиотек (C:\Windows\System32) и в папку для 32-битных (c:\windows\SysWOW64\). В итоге при дальнейшей попытке использования 64-битной версии всё будет ок, а вот при попытке загрузки 32-битной версии будет то, что мы увидели при установке Team Explorer — загадочные ошибки вообще без упоминания библиотеки vcruntime140.dll и Redistributable-пакета. И делай, что хочешь.
А что же мы хотим делать? А удалить x86-часть Redistributable-пакета Visual Studio 2015, скачать её отдельно с сайта Microsoft и переустановить. Сюрприз — на сайте Microsoft версия правильная, она установит 32-битную версию библиотеки в C:\windows\SysWOW64, после чего можно перезапустить установку Visual Studio 2015 и она успешно дойдёт до конца!
Happy end.
Осталось как-то объяснить начальству почему это я целый день устанавливал Visual Studio, если с этим дети в третьем классе за час справляются. В общем-то ради этой цели и была написана данная статья, а уж зачем вы её прочли — я не знаю :)
P.S. Справедливости ради следует отметить, что поиск по той же проблеме с упоминанием слов «redistributable» и «vcruntime140» всё-таки выводит на одиноко валяющийся на обочине Stackoverflow вопрос с правильным ответом (кто-то прошел тот же путь, что и я!), который в виду своей низкой оценки("+1" на момент написания статьи) не воспринимается людьми, как настоящее решение проблемы. Не будем забирать у автора того ответа пальму первенства и плодить лишние сущности, если описанная в статье проблема коснулась и вас, а предложенное решение помогло — вы можете проголосовать за этот ответ на Stackoverflow.
Комментарии (18)
mezastel
27.11.2015 01:30+11Вот такой вот бред реально бесит. Я про мучения, конечно, пост сам годный.
Ivan_83
27.11.2015 01:54+4Ацкий дебаг банальных вещей, как и всё у МС, а главное результат в /dev/null — они же не поправят: надо быть бронебойным дятлом или знать сразу кому именно писать.
xReaper
27.11.2015 02:18+4что только люди не делают без syslog/messages
mayorovp
27.11.2015 08:56+2В винде есть журнал событий. Если бы еще приложения туда хоть что-то полезное писали… :)
tangro
27.11.2015 11:35+3Да уж скорее без strace и gdb. Но под Windows набор Debug View + Process Monitor + Api Monitor + WinDbg делаёт всё то же самое и даже больше.
samodum
27.11.2015 02:45+5Переход на новую версию VS, .NET и прочего — большой риск.
У новичков всегда буря эмоций по этому поводуkinguru
01.12.2015 10:49+1Это касается любого продукта любой фирмы. JAVA поэтому и сидит на 6-7 версии и боятся переходить. Там даже несовместимость есть, чего нельзя сказать про .NET.
boombick
27.11.2015 07:26+12> он просто ставит 64-битные версии рантайм-библиотек и в папку для 64-битных библиотек (C:\Windows\System32) и в папку для 32-битных (c:\windows\SysWOW64\)
А почему папка для 64-битных приложений имеет в названии 32, а для 32-битных — 64? Где логика? И почему они обе не называются System32 и System64 например?mayorovp
27.11.2015 08:58+9Так сложилось исторически: System32 — это Главная Системная Папка, там лежат файлы «главной» разрядности, ее не стали переименовывать чтобы не порушить обратную совместимость.
WOW64 — это слой совместимости, он расшифровывается как Windows on Windows 64
AndreyDmitriev
27.11.2015 14:47Не далее как в начале недели поставил студию 2015, так отвалилась 2013, установленная на той же машине — все проекты открывались с ошибкой. Глубоко лезть не стал, так как тупой ремонт 2013й помог (запустил установщик последнего сервис-пака, он и отремонтировал).
Вообще когда я налетаю на такие грабли, я пробую ставить продукт на чистый Windows в виртуалке — у меня всегда образ голой ОС в VMWare под рукой со всеми установленными апдейтами. Не факт, что бага не в самой студии, а в одном из предшествующих продуктов (весьма популярном, судя по количеству репортов), который бросил файл в неверную папку, либо что-то в реестре поменял. Если бы это поведение воспроизводилось на голой системе, то Студию вообще никто поставить бы не мог. Судя по всему, там что-то уже было в системе, что и вызвало такое поведение. Но и инсталляшка могла бы уж проверить разрядность файла и тупо его переписать. Эх, похоже DLL-hell всё ещё с нами в полный рост.xRay
27.11.2015 17:57Да к примеру компоненты от Telerik 2015.Q2 не уживались с MS VS 2013 sp4 и IDE падала при запуске. А Telerik 2015.Q3 уже не крешат IDE.
Иногда проблему помогает решить чтение Activity.xml
MaxEdZX
27.11.2015 19:46+2Как бы мне пригодилась эта статья два дня назад! :) Проделал ровно весь тот же самый путь, заканчивая ProcessMonitor'ом и проклятиями в адрес собственной лени (видел решение с SO, но не проверил сразу, поможет или нет) и криворуких авторов инсталлятора, которые не могут починить это уже пол года. Но зато ещё раз убедился, что против русского программиста с инструментом ничто не устоит :) Репорты об этой баге почти всегда не содержат нужной диагностики (это заметно в обсуждениях на Connect): все останавливаются просто на том, что не ставится Team Explorer, только один товарищ, кажется, добрался до незагружающейся Settings.dll, а про неправильные редисты никто так и не написал.
navion
28.11.2015 00:51Сюрприз — на сайте Microsoft версия правильная
Версии идентичные, так что проблема где-то в установщике VS либо окружение вызывает баг при тихой установке.tangro
29.11.2015 00:06Более того, как я выяснил — можно было даже для уже установленного студией redistributable в панели управления нажать repair и он восстановил бы 32-битную библиотеку.
x88
Чтобы установить MS VS 2013 с последним SP нужно было качать кастомный инсталлятор, патч, и англофикатор. (И это при использовании лицензионного продукта)
xRay
А что бы обновить MS VS 2013 с sp 4 до sp 5. Потребовалось запустить веб-инсталяшку. Подождать пока она скачает и установит sp 5.
Запустить MS VS 2013 и увидеть ошибку «A problem occurred when loading the Microsoft Visual Menu» (и совет выполнить «devenv /resetsetting»).
devenv /resetsetting не помогает. Гуглинг помог найти решение «devenv.exe /setup». И оно помогло.
Получается накатка sp 5 ломает Microsoft Visual 2013.