Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 190. Visual Studio가 node.exe를 경유해 Edge.exe를 띄우는 경우 [링크 복사], [링크+제목 복사],
조회: 8631
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Visual Studio가 node.exe를 경유해 Edge.exe를 띄우는 경우

희한하군요, 2대의 컴퓨터에 설치한 Visual Studio에서 웹 브라우저의 디버깅 결과가 다른 문제가 발생했습니다. 가만 살펴보니 문제가 있는 PC에서만 아래의 화면처럼 비주얼 스튜디오에서 띄우는 Edge 브라우저와, 일반적으로 사용자가 띄우는 웹 브라우저가 다릅니다.

vs_launch_browser_1.png

실제로 Spy++을 이용해 확인해 보면, 문제가 없는 PC의 경우 msedge.exe가 explorer.exe를 부모로 둔 프로세스를 가리키는 반면, 문제가 발생한 PC, 즉 환경이 다른 Edge를 띄우는 것은 devenv.exe -> node.exe -> msedge.exe 이런 순서로 부모/자식이 맺어진 Edge가 떴습니다.

2가지 모두 동일하게 "C:\Program Files (x86)\Microsoft\Edge\Application\msedge.exe" 실행 파일이긴 했지만, 실행 시 전달된 명령행 인자가 다음과 같이 다른 것이 문제였습니다.

[일반 Edge]
--profile-directory=Default --restart

[Node.exe 부모를 둔 Edge]
// edge.exe
--disable-background-networking --disable-background-timer-throttling --disable-backgrounding-occluded-windows --disable-breakpad --disable-client-side-phishing-detection --disable-default-apps --disable-dev-shm-usage --disable-renderer-backgrounding --disable-sync --metrics-recording-only --no-first-run --no-default-browser-check --user-data-dir=C:\Users\testusr\AppData\Local\Microsoft\VisualStudio\17.0_03677d2c\WebTools\90107F59_873DEEDD about:blank --remote-debugging-pipe


저렇게 --disable... 옵션 등이 있으니 디버깅 결과가 다른 것은 이제 이해가 되는군요. ^^; 그렇다면 문제는, 어떻게 하면 비주얼 스튜디오가 node.exe를 경유하지 않고 edge를 띄우느냐입니다.

이상한 것은, 제 경우에 Visual Studio를 로그인해서 사용하기 때문에 모든 설정은 동기화돼 있는데요, 같은 프로젝트를 디버깅하는 데 저런 결과가 나오니 좀 당황스럽습니다. 일단, 원인 파악을 위해 edge의 부모인 node.exe의 명령행을 봤는데요,

// node.exe
"C:\Program Files\Microsoft Visual Studio\2022\Enterprise\MSBuild\Microsoft\VisualStudio\NodeJs\node.exe" "c:\program files\microsoft visual studio\2022\enterprise\common7\ide\commonextensions\microsoft\jsdiagnostics\debugger\debugAdapter\src\vsDebugServer.js"


vsDebugServer.js가 왠지 의심스럽습니다. 실제로 "Debugging" / "General" 속성에 들어가 "Enable JavaScript debugging for ASP.NET (Chrome, Edge and IE)" 설정을 보니 node.exe를 경유한 시스템에서는 켜져 있고, 그렇지 않은 곳에서는 꺼져 있었습니다.

vs_launch_browser_2.png

확인을 위해 해당 옵션을 끄고 비주얼 스튜디오를 종료 후 다시 프로젝트를 로드해 디버깅했더니 동일한 Edge 웹 브라우저가 떴습니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/10/2024]

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