Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

The trust relationship between this workstation and the primary domain failed. - 네 번째 이야기

어느 순간부터 이런 오류가 발생하면서 AD 로그인이 안 됩니다.

The trust relationship between this workstation and the primary domain failed. - 세 번째 이야기
; https://www.sysnet.pe.kr/2/0/12721

재미있는 건, 다시 로그인하라고 뜨는 창에서 정상적으로 입력을 하면 또 로그인이 되긴 합니다. 도대체 무슨 문제일까요? ^^;

그런데, 좀 이상한 점이 있습니다. 2대의 AD 서버(예를 들어, TESTAD1, TESTAD2)에는 모두 DNS 서버가 설치돼 있었는데요, 위의 문제가 발생하는 서버는 네트워크 설정에서 주 DNS 서버가 TESTAD1로 설정돼 있다는 점입니다. 즉, TESTAD2가 주 DNS 서버로 설정된 PC에서는 AD 로그인이 아주 매끄럽게 진행됩니다.

일례로, 아래는 (TESTAD2를 주 DNS로 설정한) 정상적인 상황에서의 진단 결과인데요,

C:\Users\Administrator> nltest /sc_query:testad.com
Flags: 30 HAS_IP  HAS_TIMESERV  Authentication Service: Netlogon
Trusted DC Name \\TESTAD2.testad.com
Trusted DC Connection Status Status = 0 0x0 NERR_Success
The command completed successfully

PS C:\Users\Administrator> Test-ComputerSecureChannel
True

PS C:\Users\Administrator> Get-WmiObject Win32_ComputerSystem | Select Domain7

Domain
------
testad.com

C:\Users\Administrator> nslookup testad.com
Server:  UnKnown
Address:  192.168.100.60

Name:    testad.com
Addresses:  192.168.100.60
          192.168.100.50

C:\WINDOWS\system32> gpupdate
Updating policy...

Computer Policy update has completed successfully.
User Policy update has completed successfully.

그렇지 않은 상황에서는 이런 식의 오류가 발생했습니다.

PS C:\Users\Administrator> Reset-ComputerMachinePassword
Reset-ComputerMachinePassword: Cannot reset the secure channel password for the computer account in the domain. Operation failed with the following exception: The user name or password is incorrect.
.

PS C:\Users\Administrator> Test-ComputerSecureChannel -Repair -Credential (Get-Credential)

PowerShell credential request
Enter your credentials.
User: testad\testusr
Password for user testad\testusr: ***************

Test-ComputerSecureChannel: Cannot reset the secure channel password for the computer account in the domain. Operation failed with the following exception: A local error has occurred.

C:\Windows\system32> nltest /sc_query:testad.com
Flags: 0
Trusted DC Name
Trusted DC Connection Status Status = 1311 0x51f ERROR_NO_LOGON_SERVERS
The command completed successfully

// 또는 ERROR_ACCESS_DENIED

C:\WINDOWS\System32> nltest /sc_query:testad.com
Flags: 0 Authentication Service: Netlogon
Trusted DC Name
Trusted DC Connection Status Status = 5 0x5 ERROR_ACCESS_DENIED
The command completed successfully

C:\Windows\system32> gpupdate
Updating policy...

Computer policy could not be updated successfully. The following errors were encountered:

The processing of Group Policy failed because of lack of network connectivity to a domain controller. This may be a transient condition. A success message would be generated once the machine gets connected to the domain controller and Group Policy has successfully processed. If you do not see a success message for several hours, then contact your administrator.
User Policy could not be updated successfully. The following errors were encountered:

The processing of Group Policy failed because of lack of network connectivity to a domain controller. This may be a transient condition. A success message would be generated once the machine gets connected to the domain controller and Group Policy has successfully processed. If you do not see a success message for several hours, then contact your administrator.

To diagnose the failure, review the event log or run GPRESULT /H GPReport.html from the command line to access information about Group Policy results.

C:\Windows\system32> nslookup testad.com
Server:  UnKnown
Address:  192.168.100.50

*** UnKnown can't find testad.com: Non-existent domain




그리하여, DNS 서버에 문제가 있을 것 같은 TESTAD1에 로그인해서 "DNS Manager" 콘솔을 실행했는데 이런 오류가 발생합니다.

DNS
---------------------------
The server TESTAD1 could not be contacted.

The error was:

Access was denied.

Would you like to add it anyway?

분명히 서비스 관리자에 보면 DNS 서비스가 "Running" 상태로 떠 있는데도 불구하고 저런 오류가 발생하는 것입니다. 게다가 "DNS Manager" 콘솔에 추가된 해당 서버를 우클릭해도 "Configure a DNS Server" 메뉴가 비활성화돼 있어 더 할 수 있는 방법이 없습니다.

혹시나 싶어 TESTAD2 서버로부터 AD 정보를 동기화하려고 했더니 이런 오류까지 발생합니다.

Replicate Now
---------------------------
The following error occurred during the attempt to contact the Domain Controller TESTAD2:

The target principal name is incorrect.

또는, "Active Directory Sites and Services" MMC를 이용해 "Replicate configuration from the selected DC" 또는 "Replcate configuration to the selected DC" 메뉴를 선택하면 이런 식으로 오류 메시지가 나옵니다.

Replicate Now
---------------------------
The following error occurred during the attempt to contact the Domain Controller TESTAD2:

The RPC server is unavailable.

This condition may be caused by a DNS lookup problem. For information about troubleshooting common DNS lookup problems, please see the following Microsoft Web site:

http://go.microsoft.com/fwlink/?LinkId=5171

명령행으로 직접 실행해도 마찬가지인데요,

C:\Windows\System32> repadmin /syncall /AdeP
Syncing all NC's held on TESTAD1.
Syncing partition: DC=DomainDnsZones,DC=testad,DC=com
CALLBACK MESSAGE: Error contacting server CN=NTDS Settings,CN=TESTAD2,CN=Servers,CN=Default-First-Site-Name,CN=Sites,CN=Configuration,DC=testad,DC=com (network error): -2146893022 (0x80090322):
    The target principal name is incorrect.
CALLBACK MESSAGE: Error contacting server CN=NTDS Settings,CN=TESTAD1,CN=Servers,CN=Default-First-Site-Name,CN=Sites,CN=Configuration,DC=testad,DC=com (network error): -2146893022 (0x80090322):
    The target principal name is incorrect.

SyncAll exited with fatal Win32 error: 8440 (0x20f8):
    The naming context specified for this replication operation is invalid.

즉, 이 모든 것은 AD 동기화가 제대로 되지 않아 발생한 문제였던 것입니다.




우선, 저 문제를 직접적으로는 해결할 수 없었고 Domain Admins에 해당하는 계정을 별도로 하나 더 생성해 봤는데요, 이후 문제가 있던 TESTAD1 서버에 (RDP가 아닌 콘솔로) 새롭게 생성한 AD 계정으로 로그인 시도를 해봤습니다. 일단 로그인은 성공한 듯하지만 검은 화면에서 더 이상 진행이 안됐습니다. 재미있는 건, 이 상태에서 RDP로 이전 Domain Admins 계정으로 로그인했더니 그 세션에서는 repadmin 명령어가 잘 동작했습니다.

안전을 위해, TESTAD1과 TESTAD2 모두에서 "repadmin /syncall /AdeP" 명령어를 실행한 다음 "TESTAD1" AD 서버에 새롭게 생성했던 로그인 계정까지 동기화가 되는 것을 확인한 다음 (필요 없는 절차일 듯하지만) 재부팅하는 걸로 마무리했습니다.




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







[최초 등록일: ]
[최종 수정일: 6/7/2025]

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

비밀번호

댓글 작성자
 




... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13140정성태10/11/202216797C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/202214500.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/202217401.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/202215471.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/202215557.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/202216260.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기 [1]
13134정성태10/4/202212879오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
13133정성태10/4/202214332Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]
13132정성태10/3/202214397스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현
13131정성태10/3/202218197.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/202214267.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/202214930.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
13128정성태9/23/202217790C/C++: 158. Visual C++ - IDL 구문 중 "unsigned long"을 인식하지 못하는 #import [1]파일 다운로드1
13127정성태9/22/202216249Windows: 210. WSL에 systemd 도입
13126정성태9/15/202216457.NET Framework: 2049. C# 11 - 정적 메서드에 대한 delegate 처리 시 cache 적용
13125정성태9/14/202216781.NET Framework: 2048. C# 11 - 구조체 필드의 자동 초기화(auto-default structs)
13124정성태9/13/202216934.NET Framework: 2047. Golang, Python, C#에서의 CRC32 사용
13123정성태9/8/202216886.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가
13122정성태8/26/202217354.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원
13121정성태8/23/202212983C/C++: 157. Golang - 구조체의 slice 필드를 Reflection을 이용해 변경하는 방법
13120정성태8/19/202217333Windows: 209. Windows NT Service에서 UI를 다루는 방법 [3]
13119정성태8/18/202216464.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법
13118정성태8/18/202213378.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]
13117정성태8/17/202217635.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)파일 다운로드1
13116정성태8/4/202218064.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/202218719.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...