Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)
(시리즈 글이 3개 있습니다.)
개발 환경 구성: 443. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구
; https://www.sysnet.pe.kr/2/0/11940

개발 환경 구성: 638. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/12969

VS.NET IDE: 194. Visual Studio - Cross Platform / "Authentication Type: Private Key"로 접속하는 방법
; https://www.sysnet.pe.kr/2/0/13733




Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구 - 두 번째 이야기

예전에 아래와 같은 명령 도구를 사용했었는데,

Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구
; https://www.sysnet.pe.kr/2/0/11940

빌드 도구 업데이트 이후,

msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for '...'.
; https://www.sysnet.pe.kr/2/0/12968

이전에는 성공하던 빌드가 이제는 다음과 같은 오류를 냅니다.

C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Microsoft\VC\v160\Application Type\Linux\1.0\Linux.targets(185,5): error : Could not connect to the remote system. Please verify your connection settings, and that your machine is on the network and reachable. [D:\TestPrj\TestPrj.vcxproj]


도대체 뭐가 잘못된 걸까요? ^^;




정상적으로 빌드가 되는, 비주얼 스튜디오가 설치된 곳의 store.xml과 비교했더니, xml에 필드 하나가 더 추가되었습니다.

<?xml version="1.0" encoding="utf-8"?>
<store hash="51970831b3fef09afccf5...[생략]...927cf8848375f08fb7f27620e">
  <entries>
    <entry id="409410665">
      <hostname>192.168.100.50</hostname>
      <port>22</port>
      <dateAdded>목-13-6 2019 10:50:22</dateAdded>
      <fingerprint />
      <credentials>
        <lastsuccessful>월-1-1 0001 00:00:00</lastsuccessful>
        <lastfailed>월-1-1 0001 00:00:00</lastfailed>
        <lastupdated>월-1-1 0001 00:00:00</lastupdated>
        <username>testusr</username>
        <authenticationMethod>Password</authenticationMethod>
        <password>AQAAANCMn...[생략]...xWSNYXloQqXTA==</password>
      </credentials>
      <properties />
    </entry>
  </entries>
</store>

왠지 저것이 원인인 것 같습니다. 그래서 최신 버전의 liblinux를 참조했더니, FingerPrint 속성 관련해서 업데이트하는 비동기 메서드(UpdateFingerprintAsync)도 추가되었습니다. 그래서, 위와 같은 상황에서 다음과 같이 fingerprint를 업데이트하는 코드를 수행하면,

int storeId = 409410665;
string fingerprint = "SHA256:5HAse+O8MTh4npfJmsUPnDxv1pCI1XEjqOVOFmGk+iI";

store.UpdateFingerprintAsync(storeId, fingerprint, System.Threading.CancellationToken.None);

정상적으로 다시 msbuild가 동작했습니다.




참고로,fingerprint 값은 SSH 연결에서 구하는 값이 그대로 사용됩니다. 따라서 다음과 같이 구할 수 있고,

C:\temp> ssh -o FingerprintHash=sha256 192.168.100.50
The authenticity of host '192.168.100.50 (192.168.100.50)' can't be established.
ECDSA key fingerprint is SHA256:5HAse+O8MTh4npfJmsUPnDxv1pCI1XEjqOVOFmGk+iI.
Are you sure you want to continue connecting (yes/no/[fingerprint])?

저 값을 그대로 UpdateFingerprintAsync 메서드에 전달하면 됩니다.




첨부한 도구는 그래서 다음과 같은 순서로 사용할 수 있습니다.

우선, 비밀번호를 암호화하고,

C:\temp> RemoteSshTool.exe encrypt your_password
AQAAANCMnd8BFdERjH...[생략]...+agXZgnpOhRA==

암호화된 문자열은 적절하게 보관을 하시고, 다음과 같은 명령어를 수행하면 store.xml에 연결 설정이 추가됩니다.

C:\temp> RemoteSshTool.exe add 192.168.100.50 your_user_id AQAAANCMnd8BFdERjHoAwE/Cl+sBAAAA//boMAK0a0mC+ddUSdQEWQAA....[생략]...pOhRA==

이 상태에서는 store.xml에 fingerprint 값이 없는데, 이것을 다시 한번 다음의 명령어로 마무리를 합니다.

c:\temp> RemoteSshTool.exe update-fingerprint -1204116193 SHA256:5HAse+O8MTh4npfJmsUPnDxv1pCI1XEjqOVOFmGk+iI

(첨부 파일은 지난 글에 포함한 RemoteSshTool의 개선된 버전입니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/14/2022]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  [156]  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1151정성태10/18/201122677Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까?
1150정성태10/18/201129865.NET Framework: 250. WPF - ComboBox의 SelectionChagned 이벤트파일 다운로드1
1149정성태10/16/201125566.NET Framework: 249. WPF - d:DesignHeight 값을 구할 수 있을까?
1148정성태10/14/201131563Java: 12. 자바에서 LINQ 사용? [7]
1147정성태10/13/201127474.NET Framework: 248. 닷넷에서 지원되는 문자열 인코딩 이름 목록
1146정성태10/12/201133218.NET Framework: 247. LINQ에서의 Max 기능 구현 [10]파일 다운로드1
1144정성태10/10/201128906.NET Framework: 246. WCF - 서버 측에서의 유효한 Timeout 설정파일 다운로드1
1143정성태10/9/201134475.NET Framework: 245. ASP.NET 서버 측 코드에서 페이스북 계정 연동하는 방법
1142정성태10/8/201134975.NET Framework: 244. 윈도우 폼을 열고 닫는 것만으로 메모리 leak이 발생할까? [2]파일 다운로드1
1141정성태10/7/201133603.NET Framework: 243. DataTable에 대해서 Dispose 메서드를 호출할 필요가 있을까? [4]파일 다운로드1
1140정성태10/6/201126768.NET Framework: 242. 닷넷 개발자 입장에서 이해해 보는 자바의 서블릿, JSP
1138정성태10/1/201144428Java: 11. 웹 로직에서 MS-SQL 서버 연결 [2]
1137정성태9/30/201129970Java: 10. 닷넷 개발자가 설치해 본 Oracle WebLogic Server - 설치 및 기본 도메인 구성
1136정성태9/29/201125357개발 환경 구성: 131. Visual Studio - ASP.NET의 Code-behind처럼 cs 파일을 그룹핑하는 매크로 함수 [2]파일 다운로드1
1135정성태9/29/201122830오류 유형: 138. TF10216: Team Foundation services are currently unavailable
1134정성태9/27/201130287.NET Framework: 241. C# 5.0에 새로 추가된 Caller Info 특성 [5]
1133정성태9/25/201133577VC++: 54. C++로 만든 WinRT 프로그램 [2]
1132정성태9/24/201173048Java: 9. 자바의 keytool.exe 사용법과 Tomcat의 SSL 통신 설정
1131정성태9/23/201129252Java: 8. 닷넷 개발자가 구현해 본 자바 웹 서비스 (2)
1130정성태9/23/201137247Java: 7. 닷넷 개발자가 구현해 본 자바 웹 서비스 (1)파일 다운로드2
1129정성태9/22/201128878개발 환경 구성: 130. Hyper-V에 MS-DOS VM 만드는 방법 - MSDN 구독자 대상 [3]
1128정성태9/20/201129018오류 유형: 137. KB2449742 보안 업데이트로 인한 충돌 문제 해결 - 두 번째 이야기
1127정성태9/19/201133105Java: 6. Java에서 MySQL 사용 [2]
1126정성태9/18/201128263Math: 3. "유클리드 호제법"과 "Bezout's identity" 구현 코드(C#)파일 다운로드1
1125정성태9/17/201126139Windows: 54. Windows 8 개발자 Preview를 사용해 보고... [2]
1124정성태9/17/201126416.NET Framework: 240. System.Collections.ArrayList가 .NET 4.5에서 지원이 안된다??? [2]
... 151  152  153  154  155  [156]  157  158  159  160  161  162  163  164  165  ...