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

Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."

"Tools" / "Options" 메뉴의 "Cross Platform" / "Connection Manager"에서 리눅스 연결을 하기 위해 "Connect" 버튼을 누르는 경우 잠시 멈췄다가 다음과 같이 "Host name"과 "Port" 편집 상자에 빨간 선 테두리가 쳐지면서,

ssh_password_1.png

오류 메시지로 "Connectivity Failure. Please make sure host name and port number are correct."가 보입니다. 일단, 이 현상이 발생하면 이후 Host name이나 Port를 바꾸고 "Connect" 버튼을 눌러도 별다른 변화가 없습니다. 왜냐하면, 실제로 SSH 연결은 성공했고 끊어지지 않은 상태이므로 Connect 자체를 무시하기 때문입니다. (netstate로 확인해 보면 대상 컴퓨터와의 소켓 연결이 되어 있음을 확인할 수 있습니다.)

검색해 보면,

Unable to add SSH connection to Remote System in Visual Studio 2017
; https://social.msdn.microsoft.com/Forums/vstudio/en-US/69075cf3-a1b7-4c4c-bbac-807e46426dc8/unable-to-add-ssh-connection-to-remote-system-in-visual-studio-2017?forum=vsdebug

다음의 레지스트리 설정값이,

경로: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Lsa\FipsAlgorithmPolicy
이름: Enabled
타입: DWORD

1로 되어 있는 경우 그럴 수 있다고 합니다. 하지만 제 경우에는 그냥 0으로 설정되어 있었습니다. (테스트를 위해 1로 바꿔봤는데 ^^ 전혀 다른 "This implementation is not part of the Windows Platform FIPS validated cryptographic algorithms." 오류가 발생합니다.)




혹시나 싶어서, Visual Studio에서 Connect 버튼을 눌렀을 때 잠시 멈추게 되는 그 순간 메모리 덤프를 떠 봤습니다. 재미있게도, 거기에 "SftpClient"가 눈에 띄었습니다.

liblinux.RemoteConnectionTimeoutException: Could not connect to the remote system, connection timed out. ---> liblinux.Ssh.Common.SshOperationTimeoutException: Session operation has timed out
   at liblinux.Ssh.Session.WaitOnHandle(WaitHandle waitHandle, TimeSpan timeout)
   at liblinux.Ssh.Session.liblinux.Ssh.ISession.WaitOnHandle(WaitHandle waitHandle)
   at liblinux.Ssh.Channels.Channel.GetDataLengthThatCanBeSentInMessage(Int32 messageLength)
   at liblinux.Ssh.Channels.Channel.SendMessage(ChannelDataMessage message)
   at liblinux.Ssh.Channels.Channel.SendData(Byte[] data)
   at liblinux.Ssh.SubsystemSession.SendData(Byte[] data)
   at liblinux.Ssh.Sftp.SftpSession.SendMessage(SftpMessage sftpMessage)
   at liblinux.Ssh.Sftp.SftpSession.OnChannelOpen()
   at liblinux.Ssh.SubsystemSession.Connect()
   at liblinux.Ssh.SftpClient.OnConnected()
   at liblinux.Ssh.BaseClient.Connect()
   at liblinux.IO.RemoteFileSystemImpl.ConnectCore()
   --- End of inner exception stack trace ---
   at liblinux.IO.RemoteFileSystemImpl.ConnectCore()
   at liblinux.IO.RemoteFileSystemImpl.Connect(PasswordConnectionInfo passwordConnectionInfo)
   at liblinux.IO.RemoteFileSystemImpl.Connect()
   at liblinux.IO.RemoteFileSystemImpl.Connect(IRemoteSystemBare remoteSystem)
   at liblinux.RemoteSystem.get_FileSystem()
   at liblinux.DistributionId.GetSystemId(IRemoteSystem remoteSystem)
   at liblinux.DistributionId.GetDistributionId(IRemoteSystem remoteSystem)
   at liblinux.SystemProperties.Populate()
   at liblinux.SystemProperties..ctor(IRemoteSystem remoteSystem)
   at liblinux.UnixSystem.get_Properties()
   at liblinux.Services.RemoteCompiler.Initialize()
   at liblinux.Services.RemoteCompiler.CreateLocalSysroot()
   at Microsoft.VisualStudio.Linux.Package.Dialogs.HeaderUpdateDialog.<>c__DisplayClass17_0.<DownloadUpdate>b__0(Object _)

그렇습니다. Visual Studio의 SSH 연결 서비스가 정상 동작하려면 SFTP 서비스도 함께 열려 있어야 하는 것입니다. 그래서 대상 리눅스 시스템의 SFTP 서비스를 활성화하고 다시 시도하니 일단 등록은 되었습니다.




사실 제가 하고 싶었던 것은 Synology NAS(DS216+II) 운영체제에 Visual Studio SSH 연결을 만드는 것입니다. 아쉽게도 저렇게 연결까지는 성공했는데 그 이후의 과정에서 더 진행을 못했습니다. 바로 g++ 컴파일러를 찾지 못한다는 창이 뜨기 때문입니다.

downloading and updating headers for IntelliSense

An error has occured. Could not find the specified compiler: 'g++'. Please see %LOCALAPPDATA\Temp\vslinux_header_update_log.txt for more information.

로그 파일을 봐도 다음과 같은 오류 외에는 딱히 도움이 되는 메시지가 없습니다.

liblinux.ExceptionBase: Could not find the specified compiler: 'g++'.
   at liblinux.Services.RemoteCompiler.CalculatePathsUsingCompiler()
   at liblinux.Services.RemoteCompiler.RetrieveCompilerInformation()
   at liblinux.Services.RemoteCompiler.CreateLocalSysroot()
   at Microsoft.VisualStudio.Linux.Package.Dialogs.HeaderUpdateDialog.<>c__DisplayClass17_0.<DownloadUpdate>b__0(Object _)

liblinux.RemoteConnectionTimeoutException: Could not connect to the remote system, connection timed out. ---> liblinux.Ssh.Common.SshOperationTimeoutException: Session operation has timed out
   at liblinux.Ssh.Session.WaitOnHandle(WaitHandle waitHandle, TimeSpan timeout)
   ...[생략]...
   at liblinux.Services.RemoteCompiler.Initialize()
   at liblinux.Services.RemoteCompiler.CreateLocalSysroot()
   at Microsoft.VisualStudio.Linux.Package.Dialogs.HeaderUpdateDialog.<>c__DisplayClass17_0.<DownloadUpdate>b__0(Object _)

gcc를 설치하기 위해 Synology NAS(DS216+II)의 ipkg를 opkg로 변경했는데,

Synology NAS(DS216+II)에서 실행한 gcc의 Segmentation fault
; https://www.sysnet.pe.kr/2/0/11706

실제로 opkg 패키지 관리자에서는 g++이라는 별개의 항목으로는 패키지가 존재하지 않습니다. (대신 gcc에는 포함되어 있습니다.)

어쨌든, 저 부분을 해결하지 못해서 ^^ Synology NAS 장비에는 Visual Studio의 SSH 연결은 하지 못했습니다. (물론 일반 Putty 등의 SSH 연결은 잘 됩니다.) 혹시 이 문제를 해결하신 분은 덧글 부탁드립니다. ^^




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







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

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13667정성태7/7/20246608닷넷: 2273. C# - 리눅스 환경에서의 Hyper-V Socket 연동 (AF_VSOCK)파일 다운로드1
13666정성태7/7/20247686Linux: 74. C++ - Vsock 예제 (Hyper-V Socket 연동)파일 다운로드1
13665정성태7/6/20247863Linux: 73. Linux 측의 socat을 이용한 Hyper-V 호스트와의 vsock 테스트파일 다운로드1
13663정성태7/5/20247470닷넷: 2272. C# - Hyper-V Socket 통신(AF_HYPERV, AF_VSOCK)의 VMID Wildcards 유형파일 다운로드1
13662정성태7/4/20247477닷넷: 2271. C# - WSL 2 VM의 VM ID를 알아내는 방법 - Host Compute System API파일 다운로드1
13661정성태7/3/20247398Linux: 72. g++ - 다른 버전의 GLIBC로 소스코드 빌드
13660정성태7/3/20247504오류 유형: 912. Visual C++ - Linux 프로젝트 빌드 오류
13659정성태7/1/20247843개발 환경 구성: 715. Windows - WSL 2 환경의 Docker Desktop 네트워크
13658정성태6/28/20248217개발 환경 구성: 714. WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 - 두 번째 이야기
13657정성태6/27/20247894닷넷: 2270. C# - Hyper-V Socket 통신(AF_HYPERV, AF_VSOCK)을 위한 EndPoint 사용자 정의
13656정성태6/27/20248055Windows: 264. WSL 2 VM의 swap 파일 위치
13655정성태6/24/20247835닷넷: 2269. C# - Win32 Resource 포맷 해석파일 다운로드1
13654정성태6/24/20247787오류 유형: 911. shutdown - The entered computer name is not valid or remote shutdown is not supported on the target computer.
13653정성태6/22/20247925닷넷: 2268. C# 코드에서 MAKEINTREOURCE 매크로 처리
13652정성태6/21/20249232닷넷: 2267. C# - Linux 환경에서 (Reflection 없이) DLL AssemblyFileVersion 구하는 방법파일 다운로드2
13651정성태6/19/20248472닷넷: 2266. C# - (Reflection 없이) DLL AssemblyFileVersion 구하는 방법파일 다운로드1
13650정성태6/18/20248397개발 환경 구성: 713. "WSL --debug-shell"로 살펴보는 WSL 2 VM의 리눅스 환경
13649정성태6/18/20247947오류 유형: 910. windbg - !py 확장 명령어 실행 시 "failed to find python interpreter" (2)
13648정성태6/17/20248263오류 유형: 909. C# - DynamicMethod 사용 시 System.TypeAccessException
13647정성태6/16/20249323개발 환경 구성: 712. Windows - WSL 2의 네트워크 통신 방법 - 세 번째 이야기 (같은 IP를 공유하는 WSL 2 인스턴스) [1]
13646정성태6/14/20247741오류 유형: 908. Process Explorer - "Error configuring dump resources: The system cannot find the file specified."
13645정성태6/13/20248197개발 환경 구성: 711. Visual Studio로 개발 시 기본 등록하는 dev tag 이미지로 Docker Desktop k8s에서 실행하는 방법
13644정성태6/12/20248855닷넷: 2265. C# - System.Text.Json의 기본적인 (한글 등에서의) escape 처리 [1]
13643정성태6/12/20248294오류 유형: 907. MySqlConnector 사용 시 System.IO.FileLoadException 오류
13642정성태6/11/20248196스크립트: 65. 파이썬 - asgi 버전(2, 3)에 따라 달라지는 uvicorn 호스팅
13641정성태6/11/20248659Linux: 71. Ubuntu 20.04를 22.04로 업데이트
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...