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)
13430정성태10/30/20232666닷넷: 2153. C# - 사용자가 빌드한 ICU dll 파일을 사용하는 방법
13429정성태10/27/20232940닷넷: 2152. Win32 Interop - C/C++ DLL로부터 이중 포인터 버퍼를 C#으로 받는 예제파일 다운로드1
13428정성태10/25/20233014닷넷: 2151. C# 12 - ref readonly 매개변수
13427정성태10/18/20233199닷넷: 2150. C# 12 - 정적 문맥에서 인스턴스 멤버에 대한 nameof 접근 허용(Allow nameof to always access instance members from static context)
13426정성태10/13/20233360스크립트: 59. 파이썬 - 비동기 호출 함수(run_until_complete, run_in_executor, create_task, run_in_threadpool)
13425정성태10/11/20233169닷넷: 2149. C# - PLinq의 Partitioner<T>를 이용한 사용자 정의 분할파일 다운로드1
13423정성태10/6/20233147스크립트: 58. 파이썬 - async/await 기본 사용법
13422정성태10/5/20233284닷넷: 2148. C# - async 유무에 따른 awaitable 메서드의 병렬 및 예외 처리
13421정성태10/4/20233346닷넷: 2147. C# - 비동기 메서드의 async 예약어 유무에 따른 차이
13420정성태9/26/20235517스크립트: 57. 파이썬 - UnboundLocalError: cannot access local variable '...' where it is not associated with a value
13419정성태9/25/20233189스크립트: 56. 파이썬 - RuntimeError: dictionary changed size during iteration
13418정성태9/25/20233884닷넷: 2146. C# - ConcurrentDictionary 자료 구조의 동기화 방식
13417정성태9/19/20233423닷넷: 2145. C# - 제네릭의 형식 매개변수에 속한 (매개변수를 가진) 생성자를 호출하는 방법
13416정성태9/19/20233235오류 유형: 877. redis-py - MISCONF Redis is configured to save RDB snapshots, ...
13415정성태9/18/20233728닷넷: 2144. C# 12 - 컬렉션 식(Collection Expressions)
13414정성태9/16/20233485디버깅 기술: 193. Windbg - ThreadStatic 필드 값을 조사하는 방법
13413정성태9/14/20233683닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
13412정성태9/14/20236961닷넷: 2142. C# 12 - 인라인 배열(Inline Arrays) [1]
13411정성태9/12/20233460Windows: 252. 권한 상승 전/후 따로 관리되는 공유 네트워크 드라이브 정보
13410정성태9/11/20234979닷넷: 2141. C# 12 - Interceptor (컴파일 시에 메서드 호출 재작성) [1]
13409정성태9/8/20233836닷넷: 2140. C# - Win32 API를 이용한 모니터 전원 끄기
13408정성태9/5/20233802Windows: 251. 임의로 만든 EXE 파일을 포함한 ZIP 파일의 압축을 해제할 때 Windows Defender에 의해 삭제되는 경우
13407정성태9/4/20233558닷넷: 2139. C# - ParallelEnumerable을 이용한 IEnumerable에 대한 병렬 처리
13406정성태9/4/20233522VS.NET IDE: 186. Visual Studio Community 버전의 라이선스
13405정성태9/3/20233969닷넷: 2138. C# - async 메서드 호출 원칙
13404정성태8/29/20233479오류 유형: 876. Windows - 키보드의 등호(=, Equals sign) 키가 눌리지 않는 경우
1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...