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

Microsoft Visual C++ 재배포 패키지 - 설치 로그 남기는 방법

사실, 제목에서는 "Microsoft Visual C++"이라고 제한을 두었지만 엄밀히 마이크로소프트에서 배포하는 대부분의 설치 파일에 이 방법을 사용할 수 있습니다.

원래 MSI 설치 파일에는 로그 파일을 남기는 방법이 제공되는데요. 이에 대해서는 지난번에 자세하게 소개해 드린 적이 있습니다.

MSI 설치시 로그 파일 생성하는 레지스트리 설정
; https://www.sysnet.pe.kr/2/0/416

그래서, msi 파일인 경우에는 다음과 같이 간단하게 명령행 실행을 통해 로그 파일을 남길 수 있습니다.

D:\>msiexec /lv install.log /i "setup.msi"

그런데, "Microsoft Visual C++ 2005 Redistributable Package (x64)"와 같은 경우에는 vcredist_x64.exe라고 MSI가 아닌 exe 파일로 제공되는데, 이런 경우에는 명령행 방법이 통하지 않습니다. 하지만, 위의 글에서 설명했던 레지스트리 방법을 통하면 가능합니다.

HKEY_LOCAL_MACHINE\Software\Policies\Microsoft\Windows\Installer
Reg_SZ: Logging
Value: voicewarmup

이 방법이 적용되는 이유는, vcredist_x64.exe 역시 내부적으로는 msi 파일을 압축한 것에 불과하기 때문입니다.

어디, 정말 그런지 확인해 볼까요?

우선, vcredist_x64.exe 파일을 다운로드 받아서, 명령행에서 /h 옵션을 주어 실행하면 다음과 같은 도움말을 얻을 수 있습니다.

exe_msi_log_1.png

그래서 다음과 같이 실행해 주면,

vcredist_x64.exe /c /t:c:\temp

c:\temp 폴더에는 "VCREDI~2.EXE" 파일이 생긴 것을 볼 수 있습니다. 오호~~~ 재미있군요. 2중으로 exe 파일이 감싸져 있습니다. 이에 대해서 다시 한번 실행해 주면,

"c:\temp\VCREDI~2.EXE" /c /t:c:\temp\vc2005

C:\temp\vc2005 폴더에는 다음과 같은 목록의 파일들이 생성됩니다.

exe_msi_log_2.png

보시는 것처럼, 결국 내부에는 vcredist.msi 파일로 이뤄진 것을 확인할 수 있습니다. 그렇다면 이 상태에서 다음과 같이 실행해 주면,

C:\temp\vc2005>msiexec /lv install.log /i "vcredist.msi"

그럼, c:\temp\vc2005 폴더에 install.log 파일이 생성되고 설치 시에 발생한 자세한 로그를 확인할 수 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/11/2021]

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

비밀번호

댓글 작성자
 



2012-03-08 11시41분
MSI에 포함된 파일들을 추출하는 방법

msiexec /a <name>.msi TARGETDIR=<path> /qb
정성태

... 76  [77]  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
12011정성태8/27/201926248사물인터넷: 57. C# - Rapsberry Pi Zero W와 PC 간 Bluetooth 통신 예제 코드파일 다운로드1
12010정성태8/27/201919191VS.NET IDE: 138. VSIX - DTE.ItemOperations.NewFile 메서드에서 템플릿 이름을 다국어로 설정하는 방법
12009정성태8/26/201920017.NET Framework: 858. C#/Windows - Clipboard(Ctrl+C, Ctrl+V)가 동작하지 않는다면?파일 다운로드1
12008정성태8/26/201919678.NET Framework: 857. UWP 앱에서 SQL Server 데이터베이스 연결 방법
12007정성태8/24/201918290.NET Framework: 856. .NET Framework 버전을 올렸을 때 오류가 발생할 수 있는 상황
12006정성태8/23/201921784디버깅 기술: 129. guidgen - Encountered an improper argument. 오류 해결 방법 (및 windbg 분석) [1]
12005정성태8/13/201919386.NET Framework: 855. 닷넷 (및 VM 계열 언어) 코드의 성능 측정 시 주의할 점 [2]파일 다운로드1
12004정성태8/12/201927640.NET Framework: 854. C# - 32feet.NET을 이용한 PC 간 Bluetooth 통신 예제 코드 [14]
12003정성태8/12/201919778오류 유형: 564. Visual C++ 컴파일 오류 - fatal error C1090: PDB API call failed, error code '3'
12002정성태8/12/201919140.NET Framework: 853. Excel Sheet를 WinForm에서 사용하는 방법 - 두 번째 이야기 [5]
12001정성태8/10/201924341.NET Framework: 852. WPF/WinForm에서 UWP의 기능을 이용해 Bluetooth 기기와 Pairing하는 방법 [1]
12000정성태8/9/201923748.NET Framework: 851. WinForm/WPF에서 Console 창을 띄워 출력하는 방법파일 다운로드1
11999정성태8/1/201918003오류 유형: 563. C# - .NET Core 2.0 이하의 Unix Domain Socket 사용 시 System.IndexOutOfRangeException 오류
11998정성태7/30/201920139오류 유형: 562. .NET Remoting에서 서비스 호출 시 SYN_SENT로 남는 현상파일 다운로드1
11997정성태7/30/201920411.NET Framework: 850. C# - Excel(을 비롯해 Office 제품군) COM 객체를 제어 후 Excel.exe 프로세스가 남아 있는 문제 [2]파일 다운로드1
11996정성태7/25/201923408.NET Framework: 849. C# - Socket의 TIME_WAIT 상태를 없애는 방법파일 다운로드1
11995정성태7/23/201927149.NET Framework: 848. C# - smtp.daum.net 서비스(Implicit SSL)를 이용해 메일 보내는 방법 [2]
11994정성태7/22/201921827개발 환경 구성: 454. Azure 가상 머신(VM)에서 SMTP 메일 전송하는 방법파일 다운로드1
11993정성태7/22/201916513오류 유형: 561. Dism.exe 수행 시 "Error: 2 - The system cannot find the file specified." 오류 발생
11992정성태7/22/201918627오류 유형: 560. 서비스 관리자 실행 시 "Windows was unable to open service control manager database on [...]. Error 5: Access is denied." 오류 발생
11991정성태7/18/201915683디버깅 기술: 128. windbg - x64 환경에서 닷넷 예외가 발생한 경우 인자를 확인할 수 없었던 사례
11990정성태7/18/201917935오류 유형: 559. Settings / Update & Security 화면 진입 시 프로그램 종료
11989정성태7/18/201916780Windows: 162. Windows Server 2019 빌드 17763부터 Alt + F4 입력시 곧바로 로그아웃하는 현상
11988정성태7/18/201919295개발 환경 구성: 453. 마이크로소프트가 지정한 모든 Root 인증서를 설치하는 방법
11987정성태7/17/201925218오류 유형: 558. 윈도우 - KMODE_EXCEPTION_NOT_HANDLED 블루스크린(BSOD) 문제 [1]
11986정성태7/17/201916959오류 유형: 557. 드라이브 문자를 할당하지 않은 파티션을 탐색기에서 드라이브 문자와 함께 보여주는 문제
... 76  [77]  78  79  80  81  82  83  84  85  86  87  88  89  90  ...