Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 23.1. [추가]: MSI 설치 동작 원리 [링크 복사], [링크+제목 복사],
조회: 17121
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

최근에 다시 MSI 를 해보면서 재미있는 점을 발견했습니다.
그러니까,,, MSI 의 경우에는 레지스트리 설정을 하나의 DB 로 보관하는 것 같습니다.

그 예로, COM 개체 등록을 위한 DllRegisterServer API 호출이 셋업 프로젝트의 빌드시에 호출되어지고, 실제로 MSI 파일이 클라이언트에서 설치될 때는 전혀 실행되지 않는 다는 점입니다.

즉,,, MSI 는 MSI 파일 자체가 만들어지는 시점에 클라이언트에 셋업되어야 할 레지스트리 설정까지 모두 확보해 놓는다는 것이죠.
따라서, DllRegisterServer API 는 의미가 있지만, DllUnregisterServer API 는 절대로 호출되지 않는 다는 특이한 점이 있습니다. MSI 설치 제거시에도 물론 DllUnregisterServer API 는 호출되지 않습니다.

MSI 설치시에는 미리 확보해 둔 레지스트리 설정을 셋업하고, 제거시에는 해당 시점의 레지스트리 설정만을 상대로 제거한다는 원칙이 적용됩니다.

보통의 경우, 문제가 되지 않지만, DLL 이 등록되는 시점(DllRegisterServer 호출시)에 부가적으로
if ( OS 가 윈도우즈 NT 이상인 경우 ) then
      1. NT 환경의 레지스트리 설정
else
      2. 98 환경의 레지스트리 설정
end if
위와 같은 로직을 넣게 되면.... 문제가 된다는 것이죠. 해당 MSI 파일을 빌드하게 되는 개발자 컴퓨터가 Windows NT 라면, 그렇게 해서 생성된 MSI 파일을 Windows 98 컴퓨터에서 설치를 한다 해도 NT 환경의 레지스트리 설정만 셋업되게 되는 것입니다.

결과적으로 MSI 설치시에는, COM 개체의 경우, 클라이언트 환경에 따른 설정작업을 DllRegisterServer API 에 넣어두어서는 안됩니다. .NET 이 설치되어 있다는 가정을 한다면 이런 경우, Custom Actions 을 위한 Install 용 어셈블리를 만들어서, Install() / Uninstall() 등의 메서드를 재정의한 것을 지정하면 되지만,,, 클라이언트에 .NET 이 설치되었다는 가정을 할 수 없는 경우에는 쓸 수 없습니다.








[최초 등록일: ]
[최종 수정일: 3/31/2005]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12590정성태4/9/202116900.NET Framework: 1033. C# - .NET 4.0 이하에서 Console.IsInputRedirected 구현 [1]
12589정성태4/8/202118129.NET Framework: 1032. C# - Environment.OSVersion의 문제점 및 윈도우 운영체제의 버전을 구하는 다양한 방법 [1]
12588정성태4/7/202119860개발 환경 구성: 565. PowerShell - New-SelfSignedCertificate를 사용해 CA 인증서 생성 및 인증서 서명 방법
12587정성태4/6/202121138개발 환경 구성: 564. Windows 10 - ClickOnce 배포처럼 사용할 수 있는 MSIX 설치 파일 [1]
12586정성태4/5/202118007오류 유형: 710. Windows - Restart-Computer / shutdown 명령어 수행 시 Access is denied(E_ACCESSDENIED)
12585정성태4/5/202116977개발 환경 구성: 563. 기본 생성된 kubeconfig 파일의 내용을 새롭게 생성한 인증서로 구성하는 방법
12584정성태4/1/202118159개발 환경 구성: 562. kubeconfig 파일 없이 kubectl 옵션만으로 실행하는 방법
12583정성태3/29/202119049개발 환경 구성: 561. kubectl 수행 시 다른 k8s 클러스터로 접속하는 방법
12582정성태3/29/202118453오류 유형: 709. Visual C++ - 컴파일 에러 error C2059: syntax error: '__stdcall'
12581정성태3/28/202118410.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
12580정성태3/28/202116265오류 유형: 708. SQL Server Management Studio - Execution Timeout Expired.
12579정성태3/28/202116874오류 유형: 707. 중첩 가상화(Nested Virtualization) - The virtual machine could not be started because this platform does not support nested virtualization.
12578정성태3/27/202117317개발 환경 구성: 560. Docker Desktop for Windows 기반의 Kubernetes 구성 (2) - WSL 2 인스턴스에 kind가 구성한 k8s 서비스 위치
12577정성태3/26/202118946개발 환경 구성: 559. Docker Desktop for Windows 기반의 Kubernetes 구성 - WSL 2 인스턴스에 kind 도구로 k8s 클러스터 구성
12576정성태3/25/202116988개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/202115567개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 [1]
12574정성태3/23/202121099.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/202118516개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/202117812.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/202115827오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202121132개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202121494개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/202114824오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/202116878개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/202116701개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
12565정성태3/17/202113487오류 유형: 704. curl.exe 실행 시 dll not found 오류
... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...