Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 190. Visual Studio가 node.exe를 경유해 Edge.exe를 띄우는 경우 [링크 복사], [링크+제목 복사],
조회: 10657
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13403정성태8/21/202313204오류 유형: 875. The following signatures couldn't be verified because the public key is not available: NO_PUBKEY EB3E94ADBE1229CF
13402정성태8/20/202314279닷넷: 2137. ILSpy의 nuget 라이브러리 버전 - ICSharpCode.Decompiler
13401정성태8/19/202314964닷넷: 2136. .NET 5+ 환경에서 P/Invoke의 성능을 높이기 위한 SuppressGCTransition 특성 [1]
13400정성태8/10/202314340오류 유형: 874. 파이썬 - pymssql을 윈도우 환경에서 설치 불가
13399정성태8/9/202312589닷넷: 2135. C# - 지역 변수로 이해하는 메서드 매개변수의 값/참조 전달
13398정성태8/3/202316391스크립트: 55. 파이썬 - pyodbc를 이용한 SQL Server 연결 사용법
13397정성태7/23/202315802닷넷: 2134. C# - 문자열 연결 시 string.Create를 이용한 GC 할당 최소화
13396정성태7/22/202315358스크립트: 54. 파이썬 pystack 소개 - 메모리 덤프로부터 콜 스택 열거
13395정성태7/20/202314099개발 환경 구성: 685. 로컬에서 개발 중인 ASP.NET Core/5+ 웹 사이트에 대해 localhost 이외의 호스트 이름으로 접근하는 방법
13394정성태7/16/202312109오류 유형: 873. Oracle.ManagedDataAccess.Client - 쿼리 수행 시 System.InvalidOperationException
13393정성태7/16/202313452닷넷: 2133. C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법
13392정성태7/16/202312638오류 유형: 872. Oracle - ORA-01031: insufficient privileges
13391정성태7/14/202313111닷넷: 2132. C# - sealed 클래스의 메서드를 callback 호출했을 때 인라인 처리가 될까요?
13390정성태7/12/202313677스크립트: 53. 파이썬 - localhost 호출 시의 hang 현상
13389정성태7/5/202314669개발 환경 구성: 684. IIS Express로 호스팅하는 웹을 WSL 환경에서 접근하는 방법
13388정성태7/3/202315224오류 유형: 871. 윈도우 탐색기에서 열리지 않는 zip 파일 - The Compressed (zipped) Folder '[...].zip' is invalid. [1]파일 다운로드1
13387정성태6/28/202312977오류 유형: 870. _mysql - Commands out of sync; you can't run this command now
13386정성태6/27/202314862Linux: 61. docker - 원격 제어를 위한 TCP 바인딩 추가
13385정성태6/27/202313635Linux: 60. Linux - 외부에서의 접속을 허용하기 위한 TCP 포트 여는 방법
13384정성태6/26/202312929.NET Framework: 2131. C# - Source Generator로 해결하는 enum 박싱 문제파일 다운로드1
13383정성태6/26/202313532개발 환경 구성: 683. GPU 런타임을 사용하는 Colab 노트북 설정
13382정성태6/25/202312431.NET Framework: 2130. C# - Win32 API를 이용한 윈도우 계정 정보 (예: 마지막 로그온 시간)파일 다운로드1
13381정성태6/25/202313541오류 유형: 869. Fatal Python error: init_fs_encoding: failed to get the Python codec of the filesystem encoding
13380정성태6/24/202311984스크립트: 52. 파이썬 3.x에서의 동적 함수 추가
13379정성태6/23/202312718스크립트: 51. 파이썬 2.x에서의 동적 함수 추가
13378정성태6/22/202313806오류 유형: 868. docker - build 시 "CANCELED ..." 뜨는 문제
... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...