Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)
(시리즈 글이 2개 있습니다.)
개발 환경 구성: 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




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

비밀번호

댓글 작성자
 




... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13139정성태10/9/20226118.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/20227424.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/20225767.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/20226343.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/20226618.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기
13134정성태10/4/20225342오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
13133정성태10/4/20225672Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]
13132정성태10/3/20225568스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현
13131정성태10/3/20228326.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/20225285.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/20225602.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
13128정성태9/23/20228240C/C++: 158. Visual C++ - IDL 구문 중 "unsigned long"을 인식하지 못하는 #import파일 다운로드1
13127정성태9/22/20226717Windows: 210. WSL에 systemd 도입
13126정성태9/15/20227351.NET Framework: 2049. C# 11 - 정적 메서드에 대한 delegate 처리 시 cache 적용
13125정성태9/14/20227557.NET Framework: 2048. C# 11 - 구조체 필드의 자동 초기화(auto-default structs)
13124정성태9/13/20227312.NET Framework: 2047. Golang, Python, C#에서의 CRC32 사용
13123정성태9/8/20227736.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가
13122정성태8/26/20227644.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원
13121정성태8/23/20225558C/C++: 157. Golang - 구조체의 slice 필드를 Reflection을 이용해 변경하는 방법
13120정성태8/19/20227117Windows: 209. Windows NT Service에서 UI를 다루는 방법 [3]
13119정성태8/18/20226669.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법
13118정성태8/18/20225504.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]
13117정성태8/17/20227717.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)파일 다운로드1
13116정성태8/4/20228166.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/20228516.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
13114정성태8/2/20228706.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...