> 백엔드 개발 > Golang > x/crypto/ssh를 사용하여 Go에서 Bastion 호스트를 통해 개인 인스턴스에 SSH로 연결하는 방법은 무엇입니까?

x/crypto/ssh를 사용하여 Go에서 Bastion 호스트를 통해 개인 인스턴스에 SSH로 연결하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-06 16:42:22
원래의
352명이 탐색했습니다.

How to SSH into a Private Instance via a Bastion Host in Go using x/crypto/ssh?

x/crypto/ssh를 사용하여 Go에서 Bastion 노드를 통해 프라이빗 인스턴스에 SSH 연결 설정

이 시나리오에서는 연결을 목표로 합니다. 퍼블릭 및 프라이빗 서브넷이 포함된 AWS VPC 내에 배포된 배스천 노드를 통해 로컬 노트북에서 프라이빗 인스턴스("서비스 인스턴스"라고 함)로 연결됩니다. 서비스 인스턴스에서 명령을 실행하고 로컬 노트북에서 파일을 전송하려고 합니다.

Go의 "x/crypto/ssh" 라이브러리를 사용하여 이를 달성하려면:

  1. 배스천 호스트에 대한 연결 설정:

    • 다음을 나타내는 ssh.Client를 생성합니다. Bastion 호스트에 연결합니다.
  2. Bastion에서 서비스 인스턴스에 대한 연결 설정:

    • 귀하와 서비스 사이에 가상 net.Conn을 설정하는 요새 클라이언트 인스턴스.
  3. 서비스 인스턴스용 새 SSH 클라이언트 생성:

    • net.Conn을 ssh.Conn으로 변환 ssh.NewClientConn을 사용합니다.
    • 새 ssh.Client를 생성합니다. (sClient)를 사용하여 서비스 인스턴스와 통신합니다.
  4. 명령 실행 및 파일 전송:

    • sClient를 활용하여 서비스 인스턴스에서 명령을 실행합니다.
    • 파일 전송 메커니즘을 구현합니다. (예: SFTP)을 사용하여 로컬 노트북에서 서비스 인스턴스로 파일을 업로드합니다.

다음은 이러한 단계를 보여주는 코드 조각입니다.

// connect to the bastion host
bClient, err := ssh.Dial("tcp", bastionAddr, config)
if err != nil {
    log.Fatal(err)
}

// Dial a connection to the service host, from the bastion
conn, err := bClient.Dial("tcp", serviceAddr)
if err != nil {
    log.Fatal(err)
}

ncc, chans, reqs, err := ssh.NewClientConn(conn, serviceAddr, config)
if err != nil {
    log.Fatal(err)
}

sClient := ssh.NewClient(ncc, chans, reqs)
로그인 후 복사

sClient를 사용하면 명령을 실행하고 서비스 인스턴스와 파일을 전송할 수 있습니다.

위 내용은 x/crypto/ssh를 사용하여 Go에서 Bastion 호스트를 통해 개인 인스턴스에 SSH로 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿