Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 4개 있습니다.)

Visual Studio 설치 없이 빌드 환경 구성 - Visual Studio 2017용 Build Tools

Windows SDK로 예전에도 가능했지만,

Visual Studio없이 Visual C++ 컴파일하는 방법
; https://www.sysnet.pe.kr/2/0/2879

이제는 아예 "Build Tools"라고 공개해서 제공합니다. (How can I install the VS2017 version of msbuild on a build server without installing the IDE?)

Visual Studio 2017용 Build Tools 
; https://www.visualstudio.com/ko/thank-you-downloading-visual-studio/?sku=BuildTools&rel=15

설치 화면도 Visual Studio 2017의 UI 경험을 그대로 가져왔습니다.

build_tools_1.png

보는 바와 같이 C++, .NET, .NET Core와 관련된 빌드 도구를 전부 제공합니다. 설치 후에는 시작 메뉴를 통해 "Developer Command Prompt for VS 2017"을 실행하고 그 환경에서 msbuild.exe를 실행해 프로젝트를 빌드할 수 있습니다.

만약 제공되는 명령행이 아닌 기본 cmd.exe에서 실행하고 싶다면 다음의 경로를 PATH에 등록해 주면 됩니다.

C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\15.0\Bin

예) PATH 등록
SET PATH=C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\15.0\Bin;%PATH%

cmd.exe에서 새로운 Visual Studio 2017 Build Tools로 빌드가 될지 알고 싶다면 msbuild.exe의 위치를 파악하면 됩니다.

D:\>where msbuild.exe
C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\15.0\Bin\MSBuild.exe
C:\Windows\Microsoft.NET\Framework\v4.0.30319\MSBuild.exe
C:\Windows\Microsoft.NET\Framework\v3.5\MSBuild.exe

위와 같이 where 명령어를 통해 출력되는 msbuild.exe의 첫 번째 경로가 BuildTools이면 OK! 일단, 저 경로의 msbuild.exe가 실행되면 내부적으로 csc.exe를 이용해 C# 프로젝트를 컴파일할 때 "C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\MSBuild\15.0\Bin\Roslyn\csc.exe" 경로의 최신 C# 컴파일러를 실행해 줍니다.




설치 후, tf.exe의 경우 기존에는 다음과 같이 Visual Studio가 설치되었던 경로에 있던 것을 사용했을 텐데요.

C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE

build tools에는 이렇게 변경되었으니 역시 PATH에 등록해 두고 사용하시면 됩니다.

C:\Program Files (x86)\Microsoft Visual Studio\2017\BuildTools\Common7\IDE\CommonExtensions\Microsoft\TeamFoundation\Team Explorer

그런데, tf.exe 경로만 달라졌을 뿐인데 등록된 TFS workspace가 없다는 오류가 나옵니다.

D:\MyTestApp\Sources>tf workspaces
No workspace matching * found on this computer.

왜냐하면, 기존 버전의 tf.exe가 등록한 workspace가 이미 있기 때문인데 이를 다음의 명령으로 삭제해야 합니다.

D:\MyTestApp\Sources>tf workspace /delete /server:https://testpc.testad.com/tfs/defaultcollection THISWORKSPACENAME
A deleted workspace cannot be recovered.
Workspace 'THISWORKSPACENAME' on server 'https://testpc.testad.com/tfs/defaultcollection' has 0 pending change(s).
Are you sure you want to delete the workspace? (Yes/No) y

그런 다음 새롭게 등록해 줍니다.

tf workspace /new /s:https://testpc.testad.com/tfs/defaultcollection

위의 명령어를 입력하면 다음과 같은 창이 뜹니다.

build_tools_2.png

예전처럼 "Source Control Folder"의 위치를 팀 프로젝트 루트로 맞춰 주시고 로컬로 매핑할 폴더를 "Local Folder"에 지정해 줍니다. 그럼, 등록되어 있던 workspace에 다시 소스 코드를 새롭게 받아옵니다. ("Add Workspace" 창은 "tf workspace" 명령을 통해 언제든 띄울 수 있습니다.)

참고로, 위에서 삭제 과정을 한번 거쳤는데요, 만약 기존 workspace를 삭제하지 않고 그냥 tf workspace /new로 등록하는 경우 "Add workspace" 대화창에서 "OK" 버튼을 누르면 다음과 같은 오류가 발생합니다.

The workspace THISWORKSPACENAME;TestUser already exists on computer THISPCNAME.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/23/2017]

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

비밀번호

댓글 작성자
 



2021-05-16 05시14분
where 명령어 - 리눅스의 경우 locate, which, whereis (윈도우의 where은 which와 유사)

A 90-byte “whereis” program
; https://devblogs.microsoft.com/oldnewthing/20050120-00/?p=102308

c:\temp> type which.bat
@for %%e in (%PATHEXT%) do @for %%i in (%1%%e) do @if NOT "%%~$PATH:i"=="" echo %%~$PATH:i

c:\temp> which notepad
C:\Windows\System32\notepad.exe
정성태

... 166  167  168  169  170  171  172  173  174  175  176  177  178  [179]  180  ...
NoWriterDateCnt.TitleFile(s)
510정성태6/25/200744657디버깅 기술: 15. First-Chance Exception
508정성태6/21/200727622Team Foundation Server: 18. Team Build에 사용되는 각종 Property 값 [4]
507정성태6/11/200725212VS.NET IDE: 50. Orcas - UAC 설정 관련
506정성태6/9/200720322오류 유형: 39. VC Package not available or not registered
505정성태6/9/200719904오류 유형: 38. Visual SourceSafe - DB 잠김 오류
504정성태6/9/200725282오류 유형: 37. Visual SourceSafe - Anaylze 도중 비정상 종료
503정성태6/7/200728121VS.NET IDE: 49. Orcas - VC++ 다중 소스 동시 컴파일 옵션: /MP
502정성태6/7/200722758VS.NET IDE: 48. Orcas - VC++ 프로젝트 마이그레이션
500정성태6/4/200731335VS.NET IDE: 47. Orcas - Web Browser Debugger를 이용한 보호 모드의 ActiveX 컨트롤 디버깅
499정성태6/3/200724230VS.NET IDE: 46. Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한파일 다운로드1
498정성태5/31/200718561Windows: 26. 스마트 카드 암호 바꾸는 방법.
497정성태5/31/200721977오류 유형: 36. SQL 2005 - DB 속성창 띄울 때 오류
496정성태5/29/200719888VS.NET IDE: 45. VS.NET 2005/Orcas 솔루션 파일과 UAC
495정성태5/28/200722338VS.NET IDE: 44. Orcas와 VS.NET 2005의 혼합 개발 [1]
494정성태5/26/200726573오류 유형: 35. 비스타 탐색기 - 특정 파일을 오른쪽 마우스 클릭했을 때, 비정상 종료되는 문제
493정성태5/26/200725742오류 유형: 34. Windows Server 2008 : CA 인증서 발급 실패
492정성태5/23/200725301.NET Framework: 89. ManagedThreadId - 두 번째 이야기 [5]파일 다운로드1
491정성태5/21/200725393.NET Framework: 88. ManagedThreadId ? [4]
490정성태5/19/200733904오류 유형: 33. error MSB6003: SxS DLL 로딩 오류 [2]
489정성태5/14/200721774.NET Framework: 87. .NET 2.0에서 C# 3.0 기능 사용하기
488정성태5/14/200720379Windows: 25. Multiple Input Queues
487정성태4/24/200725853VC++: 32. VC++에서 bool이 가지는 의미 [3]
486정성태3/22/200724888Windows: 24. DreamScene과 DWM(Desktop Window Manager)의 관계 [1]
485정성태3/17/200720251오류 유형: 32. VS.NET 2005 - x64 환경에서의 mixed 디버깅 환경 구성
484정성태3/17/200719468오류 유형: 31. SQL Compact Edition 설치 후 오류
483정성태3/17/200740841오류 유형: 30. x64 환경: .NET + COM 프로젝트 실행 시 오류 - 80040154 [2]
... 166  167  168  169  170  171  172  173  174  175  176  177  178  [179]  180  ...