Microsoft MVP성태의 닷넷 이야기
닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션 [링크 복사], [링크+제목 복사],
조회: 9104
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 10개 있습니다.)
VS.NET IDE: 60. Output 경로에 매크로 상수 사용하는 방법
; https://www.sysnet.pe.kr/2/0/688

개발 환경 구성: 91. MSBuild를 이용한 닷넷 응용프로그램의 플랫폼(x86/x64)별 빌드
; https://www.sysnet.pe.kr/2/0/963

개발 환경 구성: 93. MSBuild를 이용한 닷넷 응용프로그램의 다중 어셈블리 출력 빌드
; https://www.sysnet.pe.kr/2/0/965

개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정
; https://www.sysnet.pe.kr/2/0/988

개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리
; https://www.sysnet.pe.kr/2/0/1017

개발 환경 구성: 372. MSBuild - 빌드 전/후, 배포 전/후 실행하고 싶은 Task 정의
; https://www.sysnet.pe.kr/2/0/11507

개발 환경 구성: 452. msbuild - csproj에 환경 변수 조건 사용
; https://www.sysnet.pe.kr/2/0/11985

개발 환경 구성: 580. msbuild의 Exec Task에 robocopy를 사용하는 방법
; https://www.sysnet.pe.kr/2/0/12716

개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법
; https://www.sysnet.pe.kr/2/0/13481

닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
; https://www.sysnet.pe.kr/2/0/13593




MSBuild - AccelerateBuildsInVisualStudio 옵션

딱히 부작용이 없으면서도 설정해도 괜찮은 AccelerateBuildsInVisualStudio 옵션이 있었군요. ^^

Build acceleration
; https://github.com/dotnet/project-system/blob/main/docs/build-acceleration.md

Visual Studio - FastUpToDate warning
; https://bartwullems.blogspot.com/2024/07/visual-studio-fastuptodate-warning.html

최초 등장한 것은 17.5 버전이었는데,

Visual Studio Toolbox: Accelerate your builds of SDK-style .NET projects
; https://devblogs.microsoft.com/visualstudio/vs-toolbox-accelerate-your-builds-of-sdk-style-net-projects/

당시에는 "SDK-style .NET Project" 유형만 지원했고 이후 17.8에서 Non-SDK style 유형의 닷넷 프로젝트까지 확장했습니다.

Build Acceleration for Non-SDK style .NET Projects 
; https://devblogs.microsoft.com/visualstudio/visual-studio-2022-17-8-performance-enhancements/#Acceleration

단지, 일일이 프로젝트마다 AccelerateBuildsInVisualStudio 옵션을 설정하는 것이 귀찮을 수 있으니, Directory.Build.props 파일을 솔루션 단위로 추가해,

csproj의 내용을 공통 설정할 수 있는 Directory.Build.targets / Directory.Build.props 파일
; https://www.sysnet.pe.kr/2/0/12597

한 곳에서 관리를 하는 것이 좋겠습니다.

<Project>
  <PropertyGroup>
    <AccelerateBuildsInVisualStudio>true</AccelerateBuildsInVisualStudio>
    <LangVersion>12</LangVersion>
  </PropertyGroup>
</Project>




참고로, "SDK style 프로젝트"와 "Non-SDK style 프로젝트"가 뭘까요? ^^ 간단하게 설명하면, 기존 닷넷 프레임워크 유형의 프로젝트를 생성했을 때 볼 수 있었던 csproj 템플릿이 "Non-SDK style"이고,

<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="4.0">
  <PropertyGroup>
    ...[생략]...
  </PropertyGroup>
</Project>

새롭게 .NET Core/5+ 유형의 프로젝트에서 사용하는 csproj 템플릿이,

<Project Sdk="Microsoft.NET.Sdk">

    ...[생략]...

</Project>

"SDK-style"입니다. (아마도 Project 노드에 속성으로 "Sdk"가 있어 그런 이름이 붙은 듯합니다.) 재미있게도, 기존의 Non-SDK 형식을 SDK 형식으로 바꾸는 것도 가능합니다.

일례로, (신규 생성한) .NET Framework Console 응용 프로그램의 경우,

<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
  ...[생략]...
  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
</Project>

그냥 내용을 싹 지우고 TargetFramework을 net48로 설정하는 식으로 변경하면 됩니다.

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>
        <TargetFramework>net48</TargetFramework>
        <ImplicitUsings>enable</ImplicitUsings>
        <Nullable>enable</Nullable>
        <GenerateAssemblyInfo>false</GenerateAssemblyInfo>
        <LangVersion>12</LangVersion>
    </PropertyGroup>

</Project>




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







[최초 등록일: ]
[최종 수정일: 7/8/2024]

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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
600정성태10/9/200832282디버깅 기술: 18. TFS Team Build + Source Server = 소스 코드 디버깅 [3]
603정성태10/15/200824171    답변글 디버깅 기술: 18.1. 소스 서버 구성, 그 외의 이야기
599정성태10/5/200830091디버깅 기술: 17. TFS Team Build + Symbol Server [1]
598정성태10/3/200820100VS.NET IDE: 57. VS.NET 2008 - 다중 프로젝트에서 단일 SNK를 사용하는 방법
597정성태10/2/200818798Team Foundation Server: 25. VSTS 2008의 Build Explorer
596정성태10/2/200825555오류 유형: 58. WPF : 드롭다운 유형의 ComboBox가 펼쳐지지 않는 문제
595정성태10/1/200833110디버깅 기술: 16. Watson Bucket 정보를 이용한 CLR 응용 프로그램 예외 분석 [2]
594정성태9/22/200821136.NET Framework: 104. Win32Exception 클래스 소개
591정성태7/24/200817908오류 유형: 57. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상
592정성태7/28/200817914    답변글 오류 유형: 57.1. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상 [1]
590정성태7/20/200823676.NET Framework: 103. WPF - ControlTemplate을 코드에서 다뤄보기 [1]
589정성태6/17/200820566.NET Framework: 102. COM 개체의 이벤트를 구독하는 코드 제작 [1]
588정성태6/13/200822423VC++: 35. COM 이벤트에서 반환값을 가진 콜백 정의
587정성태6/10/200827159VS.NET IDE: 56. C#에서 아쉬운 __DATE__, __TIME__ 매크로 [2]
586정성태6/4/200824792오류 유형: 56. WPF 디자이너 - The string was not recognized as a valid DateTime [2]
585정성태6/4/200832955.NET Framework: 101. WPF - ActiveX 컨트롤 호스팅하는 방법 [2]
582정성태5/16/200824797오류 유형: 55. Windowless ActiveX controls are not supported
580정성태4/24/200823898VC++: 34. 64비트 윈도우즈에서의 이벤트 후킹
579정성태4/24/200823695VC++: 33. 변환 후의 RGS 파일 내용을 얻는 방법
577정성태4/16/200824581.NET Framework: 100. XML Serializer를 이용한 값 복사 [5]
575정성태4/7/200821733오류 유형: 54. TFS Source Control - 명령을 사용할 수 없음 [2]
574정성태3/31/200820034오류 유형: 53. TFS 연결 오류 - The workspace [...] exists on computer [...]
573정성태3/25/200823775Windows: 31. TS Web Access와 UAC [1]
570정성태3/17/200823098오류 유형: 52. TFS 연결 오류 - TF31001 [2]
569정성태3/16/200824051Team Foundation Server: 24. TFS 2008로 마이그레이션 (2) [2]
566정성태2/28/200825219.NET Framework: 99. AppDomain.GetEntryAssembly()를 우회하는 방법파일 다운로드1
... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...