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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...
NoWriterDateCnt.TitleFile(s)
11756정성태10/19/201812970오류 유형: 500. Visual Studio Code의 아두이노 프로그램 개발 시 인텔리센스가 안 된다면?
11755정성태10/19/201814634오류 유형: 499. Visual Studio Code extension for Arduino - #include errors detected. [1]
11754정성태10/19/201811476개발 환경 구성: 415. Visual Studio Code를 이용한 아두이노 프로그램 개발 - 새 프로젝트
11753정성태10/19/201818903개발 환경 구성: 414. Visual Studio Code를 이용한 아두이노 프로그램 개발
11752정성태10/18/201811097오류 유형: 498. SQL 서버 - Database source is not a supported version of SQL Server
11751정성태10/18/201811213오류 유형: 497. Visual Studio 실행 시 그래픽이 투명해진다거나, 깨진다면?
11750정성태10/18/201810076오류 유형: 496. 비주얼 스튜디오 - One or more projects in the solution were not loaded correctly.
11749정성태10/18/201811474개발 환경 구성: 413. 비주얼 스튜디오에서 작성한 프로그램을 빌드하는 가장 쉬운 방법
11748정성태10/18/201812391개발 환경 구성: 412. Arduino IDE를 Store App으로 설치한 경우 컴파일만 되고 배포가 안 되는 문제
11747정성태10/17/201812552.NET Framework: 799. C# - DLL에도 EXE처럼 Main 메서드를 넣어 실행할 수 있도록 만드는 방법파일 다운로드1
11746정성태10/15/201811787개발 환경 구성: 411. Bitvise SSH Client의 인증서 모드에서 자동 로그인 방법파일 다운로드1
11745정성태10/15/201810363오류 유형: 495. TFS 파일/폴더 삭제 - The item [...] could not be found in your workspace, or you do not have permission to access it.
11744정성태10/15/201810963개발 환경 구성: 410. msbuild로 .pubxml 설정에 따른 배포 파일을 만드는 방법
11743정성태10/15/201811577웹: 37. Bootstrap의 dl/dt/dd 조합에서 문자열이 잘리지 않도록 CSS 설정
11742정성태10/15/201817207스크립트: 13. 윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법
11741정성태10/15/201811614Phone: 13. Android - LinearLayout 간략 설명
11740정성태10/15/201813859사물인터넷: 51. Synology NAS(DS216+II)를 이용한 원격 컴퓨터의 전원 스위치 제어
11739정성태10/15/201815238Windows: 151. 윈도우 10의 전원 관리가 "균형 조정(Balanced)"으로 바뀌는 문제
11738정성태10/15/201814008오류 유형: 494. docker - 윈도우에서 실행 시 "unknown shorthand flag" 오류 [1]
11737정성태10/13/20189911오류 유형: 493. Azure Kudu - There are ... items in this directory, but maxViewItems is set to 299
11736정성태10/12/201811145오류 유형: 492. Visual Studio 로딩 시 오류 - The 'Scc Display Information' package did not load correctly.
11735정성태10/12/201816857VS.NET IDE: 129. Visual Studio - 특정 문자(열)를 개행 문자로 바꾸는 방법
11734정성태10/10/201811925Linux: 4. Synology NAS(DS216+II)에 FTDI 장치 연결 후 C#(.NET Core)으로 DTR 제어파일 다운로드1
11733정성태10/10/201813778Linux: 3. Synology NAS(DS216+II)에서 FTDI 장치를 C/C++로 제어
11732정성태10/10/201813877디버깅 기술: 119. windbg 분석 사례 - 종료자(Finalizer)에서 예외가 발생한 경우 비정상 종료(Crash) 발생파일 다운로드1
11731정성태10/9/201813104개발 환경 구성: 409. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 웹 앱 확장 처리파일 다운로드1
... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...