원격 디버깅 세션 제어
원격 세션이 시작되면 디버깅 서버 또는 디버깅 클라이언트에 명령을 입력할 수 있습니다. 클라이언트가 여러 개 있는 경우 해당 클라이언트 중에서 명령을 입력할 수 있습니다. ENTER 키를 누르면 명령이 디버깅 서버로 전송되고 실행됩니다.
한 사용자가 명령을 입력할 때마다 모든 사용자에게 명령 자체와 해당 출력이 표시됩니다. 이 명령이 디버깅 클라이언트에서 발행된 경우, 다른 모든 사용자들은 명령 전에 어떤 사용자가 이 명령을 발행했는지를 식별할 수 있는 표시를 보게 됩니다. 디버깅 서버에서 실행된 명령에는 이 접두사가 없습니다.
한 사용자가 명령을 실행하면 KD 또는 CDB를 통해 연결된 다른 사용자에게 새 명령 프롬프트가 표시되지 않습니다. 반면, WinDbg 사용자는 디버거 엔진이 실행 중인 경우에도 디버거 명령 창의 아래쪽 패널에 프롬프트가 지속적으로 표시됩니다. 이 두 가지 모두 경보의 원인이 되어서는 안됩니다. 모든 사용자는 언제든지 명령을 입력할 수 있으며 엔진은 받은 순서대로 이러한 명령을 실행합니다.
WinDbg 인터페이스를 통해 수행된 작업도 디버깅 서버에서 실행됩니다.
사용자 간 통신
새 디버깅 클라이언트가 세션에 연결할 때마다 다른 모든 사용자에게는 이 클라이언트가 연결되었다는 메시지가 표시됩니다. 클라이언트의 연결이 끊어지면 메시지가 표시되지 않습니다.
.clients(디버깅 클라이언트 나열) 명령은 현재 디버깅 세션에 연결된 모든 클라이언트를 나열합니다.
.echo(Echo Comment) 명령은 한 사용자의 메시지를 다른 사용자로 보내는 데 유용합니다.
WinDbg 작업 영역
WinDbg를 디버깅 클라이언트로 사용하는 경우 해당 작업 영역은 그래픽 인터페이스를 통해 설정된 값만 저장합니다. 디버거 명령 창을 통해 변경한 내용은 저장되지 않습니다. 디버거 명령 창은 디버깅 서버뿐만 아니라 모든 클라이언트의 입력을 허용하므로 로컬 클라이언트의 변경 내용만 반영됩니다.
파일 경로
기호 경로, 실행 파일 이미지 경로 및 확장 DLL 경로는 모두 디버깅 서버의 Windows용 디버깅 도구 설치 폴더에 상대적인 파일 경로로 해석됩니다.
WinDbg가 디버깅 클라이언트로 사용될 때, 자체 로컬 소스 경로도 가지고 있습니다. 모든 원본 관련 명령은 로컬 컴퓨터의 원본 파일에 액세스합니다. 따라서 원본 명령을 사용하는 모든 클라이언트 또는 서버에서 적절한 경로를 설정해야 합니다.
이 다중 경로 시스템을 사용하면 디버깅 클라이언트가 원본 파일을 실제로 다른 클라이언트 또는 서버와 공유하지 않고도 원본 관련 명령을 사용할 수 있습니다. 이는 사용자 중 한 명이 액세스할 수 있는 개인 또는 기밀 원본 파일이 있는 경우에 유용합니다.
디버깅 서버 취소
.endsrv(End Debugging Server) 명령을 사용하여 디버깅 서버를 종료할 수 있습니다. 디버거에서 여러 디버깅 서버를 설정한 경우 일부 서버는 취소하고 다른 서버는 실행 상태로 둘 수 있습니다.
서버를 종료하면 이후 클라이언트가 서버에 연결되지 않습니다. 현재 서버를 통해 연결된 클라이언트는 차단되지 않습니다.
디버거 종료 및 세션 종료
서버를 종료하지 않고 한 디버깅 클라이언트에서 종료하려면 해당 특정 클라이언트에서 명령을 실행해야 합니다. 이 클라이언트가 KD 또는 CDB인 경우 Ctrl+B 키를 사용하여 종료합니다. 스크립트를 사용하여 KD 또는 CDB를 실행하는 경우 .remote_exit(디버깅 클라이언트 종료)사용합니다. 이 클라이언트가 WinDbg인 경우
전체 세션을 종료하고 디버깅 서버를 종료하려면 q(종료) 명령을 사용합니다. 이 명령은 모든 서버 또는 클라이언트에서 입력할 수 있으며 모든 사용자에 대해 전체 세션을 종료합니다.
중요하다
원격 디버깅을 사용할 때 추가적인 중요한 보안 고려 사항이 있습니다. 보안 모드를 사용하도록 설정하는 방법에 대한 자세한 내용은 원격 디버깅 동안