Когда я пытаюсь собрать свое приложение, которое зависит от openssl3, с помощью conan, я получаю следующую ошибку, когда conan пытается собрать openssl3:
> conan install . --build=missing --profile:build=default_windows_x64_release --profile=default_windows_x64_debug
...
openssl/3.0.8: Generating aggregated env files
openssl/3.0.8: Generated aggregated env files: ['conanbuild.bat', 'conanrun.bat']
openssl/3.0.8: Calling build()
openssl/3.0.8: RUN: C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe ./Configure "VC-conan-Debug-Windows-x86_64-msvc-191" no-shared --prefix=/ --libdir=lib --openssldir = "C:\Users\username\.conan2\p\b\opens4a3ff4f862506\p\res" no-unit-test threads PERL=C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe no-tests --debug enable-fips no-md2 zlib --with-zlib-include = "C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include" --with-zlib-lib = "C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/lib/zlib.lib"
conanvcvars.bat: Activating environment Visual Studio 15 - amd64 - winsdk_version=None - vcvars_ver=14.1
[vcvarsall.bat] Environment initialized for: 'x64'
Configuring OpenSSL version 3.0.8 for target VC-conan-Debug-Windows-x86_64-msvc-191
Using os-specific seed configuration
Created configdata.pm
Running configdata.pm
Created makefile.in
Created makefile
Created include\openssl\configuration.h
**********************************************************************
*** ***
*** OpenSSL has been successfully configured ***
*** ***
*** If you encounter a problem while building, please open an ***
*** issue on GitHub <https://github.com/openssl/openssl/issues> ***
*** and include the output from the following command: ***
*** ***
*** perl configdata.pm --dump ***
*** ***
*** (If you are new to OpenSSL, you might want to consult the ***
*** 'Troubleshooting' section in the INSTALL.md file first) ***
*** ***
**********************************************************************
openssl/3.0.8: RUN: nmake
conanvcvars.bat: Activating environment Visual Studio 15 - amd64 - winsdk_version=None - vcvars_ver=14.1
[vcvarsall.bat] Environment initialized for: 'x64'
Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation. All rights reserved.
"C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "-I." -Mconfigdata "util\dofile.pl" "-omakefile" "include\crypto\bn_conf.h.in" > include\crypto\bn_conf.h
...
"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe" / depend
Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation. All rights reserved.
"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe" / _build_sw
Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation. All rights reserved.
"cl" /Zi /Fdossl_static.pdb /MTd /Zl /Gs0 /GF /Gy -MTd -Zi -Ob0 -Od -FS -MTd -Zi -Ob0 -Od -FS -I"." -I"include" -I"apps\include" -D"L_ENDIAN" -D"OPENSSL_PIC" -D"OPENSSLDIR=\"C:\\Users\\username\\.conan2\\p\\b\\opens4a3ff4f862506\\p\\res\"" -D"ENGINESDIR=\"\\lib\\engines-3\"" -D"MODULESDIR=\"\\lib\\ossl-modules\"" -D"OPENSSL_BUILDING_OPENSSL" -D"ZLIB" -D"OPENSSL_SYS_WIN32" -D"WIN32_LEAN_AND_MEAN" -D"UNICODE" -D"_UNICODE" -D"_CRT_SECURE_NO_DEPRECATE" -D"_WINSOCK_DEPRECATED_NO_WARNINGS" -D"DEBUG" -D"_DEBUG" -I"C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include" -c /Foapps\lib\libapps-lib-app_libctx.obj "apps\lib\app_libctx.c"
Microsoft (R) C/C++ Optimizing Compiler Version 19.16.27051 for x64
Copyright (C) Microsoft Corporation. All rights reserved.
app_libctx.c
C:\Users\username\.conan2\p\b\opens4a3ff4f862506\b\src\include\openssl/crypto.h(25): fatal error C1083: Cannot open include file: 'stdlib.h': No such file or directory
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\cl.EXE"' : return code '0x2'
Stop.
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe"' : return code '0x2'
Stop.
openssl/3.0.8: ERROR:
Package 'df45d737e7817e09557f98b927968632469772f8' build failed
openssl/3.0.8: WARN: Build folder C:\Users\username\.conan2\p\b\opens4a3ff4f862506\b\build-debug
ERROR: openssl/3.0.8: Error in build() method, line 520
self._make()
while calling '_make', line 513
self._run_make()
while calling '_run_make', line 490
self.run(" ".join(command), env = "conanbuild")
ConanException: Error 2 while executing
Я подозреваю, что это происходит потому, что MSVS неправильно устанавливает все включения и пути. Я так думаю, потому что когда я выполняю «set INCLUDE» в командной строке разработчика для VS 2017, я получаю следующее:
>set include
INCLUDE=C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\ATLMFC\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include;C:\PROGRA~1\IBM\SQLLIB\INCLUDE;C:\PROGRA~1\IBM\SQLLIB\LIB
С другой стороны, когда я вручную добавляю недостающие включения в командную строку разработчика, например:
set INCLUDE=%INCLUDE%;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\winrt;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\shared;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\um;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\UnitTest\include;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\ucrt;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include;C:\3coreserver\commlib2a\openssl\windows\vs2012\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\PlatformSDK\include;C:\Program Files (x86)\Windows Kits\10\Source\10.0.16299.0\ucrt;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\src;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\crt\src;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\atl;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\mfcm;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\mfc;
Я получаю другую ошибку:
legacyprov.c
cmd /C ""cl" /Zs /showIncludes /Zi /Fddso.pdb /Gs0 /GF /Gy -MTd -Zi -Ob0 -Od -FS -MTd -Zi -Ob0 -Od -FS -I"include" -I"providers\implementations\include" -I"providers\common\include" -D"OPENSSL_BUILDING_OPENSSL" -D"ZLIB" -D"OPENSSL_SYS_WIN32" -D"WIN32_LEAN_AND_MEAN" -D"UNICODE" -D"_UNICODE" -D"_CRT_SECURE_NO_DEPRECATE" -D"_WINSOCK_DEPRECATED_NO_WARNINGS" -D"DEBUG" -D"_DEBUG" -I"C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include" "providers\legacyprov.c" > providers\legacy-dso-legacyprov.d 2>&1"
"C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "util\mkrc.pl" legacy > providers\legacy.rc
"rc" /foproviders\legacy-dso-legacy.res "providers\legacy.rc"
Microsoft (R) Windows (R) Resource Compiler Version 10.0.10011.16384
Copyright (C) Microsoft Corporation. All rights reserved.
"C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "util\mkdef.pl" --type dso --ordinals util\providers.num --name legacy --OS windows > providers\legacy.def
IF EXIST providers\legacy.dll.manifest DEL /F /Q providers\legacy.dll.manifest
cmd /C ""link" -debug /dll -debug -debug @C:\Users\username\AppData\Local\Temp\2\nm17C5.tmp || (DEL /Q legacy.* providers\legacy.* & EXIT 1)"
Microsoft (R) Incremental Linker Version 14.16.27051.0
Copyright (C) Microsoft Corporation. All rights reserved.
providers\legacy-dso-legacyprov.obj
/out:providers\legacy.dll
providers\liblegacy.lib
providers\libcommon.lib
libcrypto.lib
C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/lib/zlib.lib ws2_32.lib gdi32.lib advapi32.lib crypt32.lib user32.lib
/def:providers\legacy.def providers\legacy-dso-legacy.res
LINK : fatal error LNK1104: cannot open file 'ws2_32.lib'
Could Not Find C:\Users\username\.conan2\p\b\opensdbeefee112c1f\b\src\legacy.*
NMAKE : fatal error U1077: 'cmd' : return code '0x1'
Stop.
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe"' : return code '0x2'
Stop.
У меня установлен Microsoft SDK (10.0.16299.0) для VS 2017, но пути включения и библиотеки не установлены по умолчанию.
Я не понимаю, как это исправить, пожалуйста, помогите.
Редактировать 1. Некоторые версии:
>python --version
Python 3.10.10
>conan --version
Conan version 2.4.1
>cmake --version
cmake version 3.25.1
CMake suite maintained and supported by Kitware (kitware.com/cmake).
Редактировать 2. Что я уже пытался исправить:
В качестве альтернативы: github.com/CristiFati/Prebuilt-Binaries/tree/master/OpenSSL/…
У меня не получилось воспроизвести. Я только что попробовал на своей машине conan install --requires=openssl/3.0.8 -s compiler.version=191 --build=missing
, и все получилось правильно. Возможно, ваша установка VS2017 не завершена? Я использовал последнюю версию Конана 2.4. Было бы лучше подать заявку на github.com/conan-io/conan/issues и предоставить дополнительную информацию.
@drodri, вполне вероятно, что мой MSVS сломан. Я уже пытаюсь переустановить его, но это займет довольно много времени из-за моей рабочей политики. Но переустановка MSVS 2017 звучит как обходной путь, а не исправление, и я хотел бы найти постоянное решение, например, установить некоторые переменные env, изменить свойства реестра или каким-то образом настроить конфигурацию MSVS 2017. Кстати, я тоже использую conan 2.4, упомяну об этом в своем вопросе.
То, что вы только что описали, — это обходные пути, и переустановка — это исправление.
Я согласен с @user207421, похоже, ваш VS2017 был сломан, cannot open file 'ws2_32.lib'
системная библиотека VS является сильным показателем. Я не думаю, что попытка определить env-vars или реестр — это правильное решение, а скорее хак, и правильное решение — убедиться, что установка VS2017 правильна.
@user207421 user207421, я попытался переустановить MSVS 2017. Это не решило проблему.
Я отвечаю на свой вопрос, так как нашел основную причину и временное решение.
В моем случае причина этой проблемы заключается в том, что у меня нет прав на чтение реестра Windows с помощью команды reg query
и у моего пользователя не включен regedit из-за политик безопасности, установленных на моем рабочем месте.
Объяснение:
Microsoft Visual Studio настраивает среду разработки, вызывая сценарий vcvarsall.bat, который зависит от сценария winsdk.bat, который использует команду reg query
для установки некоторых переменных среды разработки, необходимых для сборки некоторых пакетов (openssl 3.0.8 в моем случае).
РЕАЛЬНЫМ решением было бы получить хотя бы доступ только для чтения к реестру Windows.
Поскольку это может быть недостижимо, я нашел обходной путь:
winsdk.bat
вашей Microsoft Visual Studio (он должен быть где-то в C:\Program Files (x86)\Microsoft Visual Studio\2017\*\Common7\Tools\vsdevcmd\core\winsdk.bat
, в моем случае *
был Professional
, но это также может быть Community
или что-то еще, в зависимости от установленной версии MSVS)notepad winsdk.bat
)reg query
. Эти 2 функции: GetWin10SdkDirHelper
и GetUniversalCRTSdkDirHelper
.call :GetWin10SdkDirHelper HKLM\SOFTWARE\Wow6432Node > nul 2>&1
set WindowsSdkDir=C:\Program Files (x86)\Windows Kits\10\
echo "debug 1" %WindowsSdkDir%
...
call :GetUniversalCRTSdkDirHelper HKLM\SOFTWARE\Wow6432Node > nul 2>&1
set UniversalCRTSdkDir=C:\Program Files (x86)\Windows Kits\10\
echo "debug 2" %UniversalCRTSdkDir%
В вашем конкретном случае путь к Windows SDK может быть другим. Я убедился, что в моей системе для этих конкретных записей реестра сначала установлены эти значения, но вы можете попробовать указать путь к вашему Windows 10 SDK и посмотреть, работает ли он.
Для этого обходного пути требуются определенные права администратора, которые позволяют вам изменять winsdk.bat
, поэтому он может вам не подойти.
Существует также второй обходной путь — установка переменных dev env вручную.
Откройте «Командную строку разработчика для VS 2017» и введите следующие команды (ваши версии Windows SDK могут отличаться, но идея та же):
set INCLUDE=%INCLUDE%;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\ucrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\shared;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\um;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\winrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\cppwinrt
set LIB=%LIB%;C:\Program Files (x86)\Windows Kits\10\lib\10.0.22621.0\ucrt\x86;C:\Program Files (x86)\Windows Kits\10\lib\10.0.22621.0\um\x86
set PATH=%PATH%;C:\Program Files (x86)\Windows Kits\10\bin\10.0.22621.0\x86;C:\Program Files (x86)\Windows Kits\10\bin\x86
После этого запустите conan build.
Предупреждение: этот обходной путь не является постоянным, и вам придется устанавливать эти переменные env каждый раз, когда вам нужно собрать пакеты, для которых требуется Windows SDK.
Как ты устанавливал из MS VStudio или что ты из него устанавливал?