Microsoft MVP성태의 닷넷 이야기
글쓴 사람
홈페이지
첨부 파일
 

ASP.NET Core 프로젝트를 명령행에서 빌드하는 방법

결론부터 말하면, NuGet restore 해주고 msbuild로 다음과 같이 빌드할 수 있습니다.

dotnet restore .\aspnet_core_proj

msbuild ".\aspnet_core_proj\aspnet_core_proj.csproj" /property:Platform=x64;Configuration=Release /t:Rebuild

또한 배포 본을 얻고 싶다면 다음과 같이 publish 옵션을 이용하면 됩니다.

dotnet publish .\aspnet_core_proj




만약 위의 과정에서 dotnet restore 없이 msbuild로 (빌드 서버에서) 빌드하면 다음과 같은 오류가 발생합니다.

D:\temp>msbuild ".\aspnet_core_proj\aspnet_core_proj.csproj" /property:Platform=AnyCPU;Configuration=Release /t:Rebuild
Microsoft (R) Build Engine version 15.3.409.57025 for .NET Framework
Copyright (C) Microsoft Corporation. All rights reserved.

Build started 2018-01-03 오전 10:34:54.
Project "D:\aspnet_core_proj\aspnet_core_proj.csproj" on node 1 (Rebuild target(s)).
PreComputeCompileTypeScript:
  C:\Program Files (x86)\Microsoft SDKs\TypeScript\1.8\tsc.exe  --noEmitOnError
PrepareForBuild:
  Creating directory "bin\Release\net47\".
C:\Program Files\dotnet\sdk\2.0.2\Sdks\Microsoft.NET.Sdk\build\Microsoft.PackageDependencyResolution.targets(323,5): error : Assets file 'D:\aspnet_core_proj\obj\project.assets.json' not found. Run a NuGet package restore to generate this file. [D:\aspnet_core_proj\fullnet_mvc_core.csproj]
  Build continuing because "ContinueOnError" on the task "ReportAssetsLogMessages" is set to "ErrorAndContinue".
C:\Program Files\dotnet\sdk\2.0.2\Sdks\Microsoft.NET.Sdk\build\Microsoft.PackageDependencyResolution.targets(165,5): error : Assets file 'D:\aspnet_core_proj\obj\project.assets.json' not found. Run a NuGet package restore to generate this file. [D:\aspnet_core_proj\fullnet_mvc_core.csproj]
Done Building Project "D:\aspnet_core_proj\aspnet_core_proj.csproj" (Rebuild target(s)) -- FAILED.

...[생략]...

그리고 이렇게도 오류가 발생하는 경우가 있습니다.

D:\temp>msbuild ".\aspnet_core_proj\aspnet_core_proj.csproj" /property:Platform=AnyCPU;Configuration=Release /t:Rebuild
Microsoft (R) Build Engine version 15.3.409.57025 for .NET Framework
Copyright (C) Microsoft Corporation. All rights reserved.

Build started 2018-01-03 오전 10:54:43.
Project "D:\aspnet_core_proj\aspnet_core_proj.csproj" on node 1 (Rebu
ild target(s)).
C:\Program Files\dotnet\sdk\2.0.2\Sdks\Microsoft.NET.Sdk\build\Microsoft.PackageDependencyResolution.targets(165,5): error : Assets file 'D:\aspnet_core_proj\obj\project.assets.json' doesn't have a target for '.NETFramework,Version=v4.7/win7-x86'. Ensure that restore has run and that you have included 'net47' in the TargetFrameworks for your project. You may also need to include 'win7-x86' in your project's RuntimeIdentifiers. [D:\aspnet_core_proj\aspnet_core_proj.csproj]
Done Building Project "D:\aspnet_core_proj\aspnet_core_proj.csproj" (Rebuild target(s)) -- FAILED.


...[생략]...

위의 원인은 아래의 글에서 설명한 오류 상황과 유사합니다.

.NET Core 오류 - 0x80131620 Unable to load DLL 'libuv'
; https://www.sysnet.pe.kr/2/0/11389

즉, Platform 설정을 AnyCPU로 하면 안 되고 다음과 같이 x86 또는 x64로 명시해야 합니다.

msbuild ".\aspnet_core_proj\aspnet_core_proj.csproj" /property:Platform=x64;Configuration=Release /t:Rebuild




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]





[최초 등록일: ]
[최종 수정일: 1/4/2018 ]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer@outlook.com

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
12008정성태8/26/2019619.NET Framework: 857. UWP 앱에서 SQL Server 데이터베이스 연결 방법
12007정성태8/24/2019725.NET Framework: 856. .NET Framework 버전을 올렸을 때 오류가 발생할 수 있는 상황
12006정성태8/23/20191157디버깅 기술: 129. guidgen - Encountered an improper argument. 오류 해결 방법 (및 windbg 분석)
12005정성태8/13/20191701.NET Framework: 855. 닷넷 (및 VM 계열 언어) 코드의 성능 측정 시 주의할 점 [2]파일 다운로드1
12004정성태8/12/20191475.NET Framework: 854. C# - 32feet.NET을 이용한 PC 간 Bluetooth 통신 예제 코드
12003정성태8/12/2019856오류 유형: 564. Visual C++ 컴파일 오류 - fatal error C1090: PDB API call failed, error code '3'
12002정성태8/12/2019892.NET Framework: 853. Excel Sheet를 WinForm에서 사용하는 방법 - 두 번째 이야기
12001정성태8/10/20191142.NET Framework: 852. WPF/WinForm에서 UWP의 기능을 이용해 Bluetooth 기기와 Pairing하는 방법
12000정성태8/9/2019933.NET Framework: 851. WinForm/WPF에서 Console 창을 띄워 출력하는 방법파일 다운로드1
11999정성태8/1/2019608오류 유형: 563. C# - .NET Core 2.0 이하의 Unix Domain Socket 사용 시 System.IndexOutOfRangeException 오류
11998정성태7/30/2019721오류 유형: 562. .NET Remoting에서 서비스 호출 시 SYN_SENT로 남는 현상파일 다운로드1
11997정성태7/30/20191163.NET Framework: 850. C# - Excel(을 비롯해 Office 제품군) COM 객체를 제어 후 Excel.exe 프로세스가 남아 있는 문제파일 다운로드1
11996정성태7/25/2019971.NET Framework: 849. C# - Socket의 TIME_WAIT 상태를 없애는 방법파일 다운로드1
11995정성태7/23/2019852.NET Framework: 848. C# - smtp.daum.net 서비스(Implicit SSL)를 이용해 메일 보내는 방법
11994정성태10/22/20191065개발 환경 구성: 454. Azure 가상 머신(VM)에서 SMTP 메일 전송하는 방법파일 다운로드1
11993정성태7/22/2019657오류 유형: 561. Dism.exe 수행 시 "Error: 2 - The system cannot find the file specified." 오류 발생
11992정성태7/22/2019781오류 유형: 560. 서비스 관리자 실행 시 "Windows was unable to open service control manager database on [...]. Error 5: Access is denied." 오류 발생
11991정성태7/18/2019591디버깅 기술: 128. windbg - x64 환경에서 닷넷 예외가 발생한 경우 인자를 확인할 수 없었던 사례
11990정성태3/16/20201225오류 유형: 559. Settings / Update & Security 화면 진입 시 프로그램 종료
11989정성태7/18/2019566Windows: 162. Windows Server 2019 빌드 17763부터 Alt + F4 입력시 곧바로 로그아웃하는 현상
11988정성태7/18/2019993개발 환경 구성: 453. 마이크로소프트가 지정한 모든 Root 인증서를 설치하는 방법
11987정성태7/17/20191991오류 유형: 558. 윈도우 - KMODE_EXCEPTION_NOT_HANDLED 블루스크린(BSOD) 문제
11986정성태7/18/2019659오류 유형: 557. 드라이브 문자를 할당하지 않은 파티션을 탐색기에서 드라이브 문자와 함께 보여주는 문제
11985정성태7/17/2019675개발 환경 구성: 452. msbuild - csproj에 환경 변수 조건 사용
11984정성태7/9/20191085개발 환경 구성: 451. Microsoft Edge (Chromium)을 대상으로 한 Selenium WebDriver 사용법
11983정성태7/8/2019672오류 유형: 556. nodemon - 'mocha' is not recognized as an internal or external command, operable program or batch file.
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...