Microsoft MVP성태의 닷넷 이야기
오류 유형: 64. TFS 2008 SP1 설치 - MsiApplyMultiplePatches returned 0x643 [링크 복사], [링크+제목 복사],
조회: 23814
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

TFS 2008 SP1 설치 - MsiApplyMultiplePatches returned 0x643


TFS 2008 SP1을 설치하는 데 실패하였습니다. 친절하게도 실패 이후, 로그를 볼 수 있는 버튼이 보이고 그걸 누르면 아래와 같이 Internet Explorer에서 오류 로그를 확인할 수 있습니다.

[그림 1: TFS 2008 SP1 설치 오류 로그]
tfs_sp1_install_error_0x643_1.PNG

검색으로 써먹을 수 있는 문자열이라곤 "MsiApplyMultiplePatches returned 0x643"라는 메시지가 전부일 것 같습니다. 그래서 검색을 했더니, 아래와 같은 토픽이 나오네요.

KB944899 Should be Removed before Installing Visual Studio 2008 SP1
; https://devblogs.microsoft.com/setup/kb944899-should-be-removed-before-installing-visual-studio-2008-sp1

어찌 보면, 위의 내용은 Visual Studio 2008 SP1 설치에서 안된다는 것인데 그래도 TFS 2008 SP1 설치 실패에도 연관이 있는 것 같습니다. 왜냐하면, 지금 위의 상황은 Visual Studio 2008 SP1을 설치한 이후에 발생한 것이기 때문입니다.

상황을 유추해 보면,

1. KB944899로 인해 VS 2008 SP1 베타 설치에서 오류가 발생했었다.
2. 마이크로소프트는 SP1을 정식 릴리스하기 전에 내부적인 설치 순서를 바꿔서 KB944899를 나중에 설치하도록 했다.
3. 이로써, VS 2008 SP1은 정상적으로 설치되지만 TFS 2008 SP1 설치 시에 오류가 발생한다.
4. 따라서, SP1을 적용해야 하는 순서는 TFS 2008 SP1을 먼저 설치하고, VS 2008 SP1을 나중에 설치해야 한다.

뭐... 대강 이런 것 같습니다.

불행히도, 이미 Visual Studio 2008 SP1을 먼저 설치했으면 독립적으로 KB944899만을 제거하는 방법이 제어판의 "프로그램 설치/제거"에 나오지 않는다는 것입니다. 그래서, "Visual Studio 2008 SP1"을 통째로 제거한 후에 다시 TFS 2008 SP1을 설치하기 시작했습니다.

잉! 그래도 동일한 오류가 발생하네요. ^^;

그래서, 다시 위의 문서를 찬찬히 읽어보기 시작했습니다. 음... 아래에서와 같은 방법으로 레지스트리 키를 확인하는 방법을 설명해 주고 있습니다.

reg.exe query HKLM\Software\Microsoft\Updates /f KB944899 /k /s

실제로 입력해 보니, 아래와 같은 식으로 나왔습니다.

C:\>reg.exe query HKLM\Software\Microsoft\Updates /f KB944899 /k /s

HKEY_LOCAL_MACHINE\Software\Microsoft\Updates\Microsoft Visual Studio Team System 2008 Development Edition - KOR\KB944899
End of search: 1 match(es) found.

C:\>

그렇다면, Visual Studio 2008 SP1 제거 시에 위의 레지스트리 키는 여전히 남아 있었다는 이야기가 되는군요. 어쨌든, 수작업으로 삭제해 주고 다시 TFS 2008 SP1을 설치해보았습니다.

그래도... 안되네요. ^^; 역시 이번에도 실패. (괴롭당!!!)

보고 싶지 않지만, 이제 기나긴 MSI 로그 파일을 봐야 할 것 같습니다. 위의 "Installation Log" 화면에도 나오듯이 "Microsoft Visual Studio 2008 Team Foundation Server Service Pack 1_20081205_142629827-Msi1.txt" 파일을 열어서 오류가 발생한 곳을 찾아봤습니다. 다음과 같은 로그가 눈에 띄네요.

TFSQuiesce - Team Foundation Server Maintenance Tool
Copyright (c) Microsoft Corporation.  All rights reserved.

Using workflow file from location exe.
Executing workflow 'Quiesce ATDT'...
Stopping Windows Service 'TFSServerScheduler'...
Stopping Windows Service 'CoverAn'...
Stopping Windows Service 'W3SVC'...
Starting Windows Service 'W3SVC'...
Disabling SQL Jobs for databases TFSActivityLogging,TFSBuild,TFSIntegration,TFSVersionControl,TFSWorkItemTracking,TFSWorkItemTrackingAttachments,TFSWarehouse
Blocking service account from accessing database TFSActivityLogging
Microsoft.TeamFoundation.Admin.TFSQuiesce.RunningWithServiceAccountException: 
    You cannot run setup using the Team Foundation Service Account TESTDOMAIN\tfsservice
   at Microsoft.TeamFoundation.Admin.TFSQuiesce.Quiescer.ChangeServiceAccountState(XPathNavigator workflow, String action, String dbName)
   at Microsoft.TeamFoundation.Admin.TFSQuiesce.Quiescer.ProcessSqlDatabaseElement(XPathNavigator workflow, String action, String dbName)
   at Microsoft.TeamFoundation.Admin.TFSQuiesce.Quiescer.ExecuteWorkflowStep(XPathNavigator workflow, String action, String nameAttribute)
   at Microsoft.TeamFoundation.Admin.TFSQuiesce.Quiescer.ExecuteWorkflowStepWithRetry(XPathNavigator workflow, String action, String nameAttribute)
   at Microsoft.TeamFoundation.Admin.TFSQuiesce.Quiescer.RunWorkflow(String workflowName)

TFSQuiesce 관련해서 자료를 찾아보니 다음과 같은 토픽을 마이크로소프트에서 제공하고 있습니다.

Description of the TFSQuiesce Team Foundation Server component
; http://support.microsoft.com/kb/950893

즉, TFS 업데이트에 앞서 데이터를 일관성있게 유지하기 위해서 업데이트 하는 동안 TFS 서비스를 못하도록 중지하겠다는 것입니다. (물론, 업데이트 이후 다시 서비스를 살려 놓고.)

음... 그러고 보니, 지금 실행 계정이 "TESTDOMAIN\tfsservice" 입니다. 그런데, 스스로 접근하지 못하게 한다는 것이 왠지 안 맞을 것 같다는 생각이 들어서, 다른 계정으로 로그인을 해서 시도해 보았습니다. 결과는?

^^ 성공! James Brown이 "I Feel Good" 노래를 부를 때 기분이 이렇지 않았을까요? 특유의 "워우"하는 날카로운 목소리를 흉내내고 싶은 심정입니다. ^^;

정리해 보면,

  • TFS 2008 SP1을 설치할 때, 서비스 계정(문서대로 했다면 TFSService 계정)으로 로그인해서 실행하지 말라는 것.
  • KB944899 설치 기록이 없어야 한다는 것. (확실하진 않지만, 위의 "KB944899"을 삭제하기 전에 TFSService 이외의 계정으로 실행한 적이 있었는데 그래도 실패했었습니다.)

마지막으로, 설치 제거했던 Visual Studio 2008 SP1를 다시 설치해서 SP1 업데이트 완료!



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

[연관 글]






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

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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  85  86  87  88  89  [90]  ...
NoWriterDateCnt.TitleFile(s)
11685정성태9/6/201818577사물인터넷: 40. 이어폰 소리를 capacitor로 필터링파일 다운로드1
11684정성태9/6/201821200개발 환경 구성: 396. pagefile.sys를 비활성화시켰는데도 working set 메모리가 줄어드는 이유파일 다운로드1
11683정성태9/5/201818883개발 환경 구성: 395. Azure Web App의 이벤트 로그를 확인하는 방법
11682정성태9/5/201817828오류 유형: 484. Fakes를 포함한 단위 테스트 프로젝트를 빌드 시 CS1729 관련 오류 발생
11681정성태9/5/201820483Windows: 149. 다른 컴퓨터의 윈도우 이벤트 로그를 구독하는 방법 [2]
11680정성태9/2/201822690Graphics: 21. shader - _Time 내장 변수를 이용한 UV 변동 효과파일 다운로드1
11679정성태8/30/201820683.NET Framework: 792. C# COM 서버가 제공하는 COM 이벤트를 C++에서 받는 방법 [1]파일 다운로드1
11678정성태8/29/201819107오류 유형: 483. 닷넷 - System.InvalidProgramException [1]
11677정성태8/29/201816825오류 유형: 482. TFS - Could not find a part of the path '...\packages\Microsoft.AspNet.WebApi.5.2.5\.signature.p7s'.
11676정성태8/29/201827666.NET Framework: 791. C# - ElasticSearch를 위한 Client 라이브러리 제작 [1]파일 다운로드1
11675정성태8/29/201817838오류 유형: 481. The located assembly's manifest definition does not match the assembly reference.
11674정성태8/29/201819806Phone: 12. Xamarin - 기존 리모컨 기능을 핸드폰의 적외선 송신으로 구현파일 다운로드1
11673정성태8/28/201817119오류 유형: 480. Fritzing 실행 시 Ordinal Not Found 오류
11672정성태8/28/201817532오류 유형: 479. 윈도우 - 시스템 설정에서 도메인 참가를 위한 "Change" 버튼이 비활성화된 경우
11671정성태8/28/201823888사물인터넷: 39. 아두이노에서 적외선 송신기 기본 사용법파일 다운로드1
11670정성태8/28/201822137사물인터넷: 38. 아두이노에서 적외선 수신기 기본 사용법 [1]파일 다운로드1
11669정성태8/24/201820947개발 환경 구성: 394. 윈도우 환경에서 elasticsearch의 한글 블로그 검색 인덱스 구성
11668정성태8/24/201832003오류 유형: 478. 윈도우 업데이트(KB4458842) 이후 SQL Server 서비스 시작 오류
11667정성태8/24/201818723오류 유형: 477. "Use Unicode UTF-8 for worldwide language support" 옵션 설정 시 SQL Server 2016 설치 오류 [1]
11666정성태8/22/201818596사물인터넷: 37. 아두이노 - 코딩으로 대신하는 오실레이터 회로의 소리 출력파일 다운로드1
11665정성태8/22/201821312사물인터넷: 36. 오실레이터 회로 동작을 아두이노의 코딩으로 구현하는 방법파일 다운로드1
11664정성태8/22/201820980개발 환경 구성: 393. 윈도우 환경에서 elasticsearch의 한글 형태소 분석기 설치 [1]
11663정성태8/22/201823697개발 환경 구성: 392. 윈도우 환경에서 curl.exe를 이용한 elasticsearch 6.x 기본 사용법
11662정성태8/21/201817298사물인터넷: 35. 병렬 회로에서의 커패시터파일 다운로드1
11661정성태8/21/201819578사물인터넷: 34. 트랜지스터 동작 - 컬렉터-이미터 간의 저항 측정파일 다운로드1
11660정성태8/19/201818680사물인터넷: 33. 세라믹 커패시터의 동작 방식파일 다운로드1
... 76  77  78  79  80  81  82  83  84  85  86  87  88  89  [90]  ...