Go의 x/crypto/ssh를 사용하여 Bastion Node를 통해 개인 인스턴스에 SSH 연결 설정
시나리오 개요
퍼블릭 및 프라이빗 서브넷이 있는 VPC에서 "bastion" 인스턴스 퍼블릭 서브넷에 상주하며 프라이빗 서브넷의 프라이빗 "서비스 인스턴스"에 대한 액세스를 제공합니다.
Go의 x/crypto/ssh를 통해 연결
Go의 x/crypto/ssh를 통해 서비스 인스턴스를 생성하려면 다음을 따르세요. 단계:
배스천 연결 설정:
bClient, err := ssh.Dial("tcp", bastionAddr, config) if err != nil { log.Fatal(err) }
서비스에 다이얼 연결 인스턴스:
conn, err := bClient.Dial("tcp", serviceAddr) if err != nil { log.Fatal(err) }
가상 SSH 연결 생성:
ncc, chans, reqs, err := ssh.NewClientConn(conn, serviceAddr, config) if err != nil { log.Fatal(err) }
인스턴스화 서비스용 SSH 클라이언트 호스트:
sClient := ssh.NewClient(ncc, chans, reqs)
nc의 대안 명령
x/crypto/ssh 라이브러리는 nc 명령을 사용하지 않고도 배스천 호스트에서 서비스 호스트에 연결을 설정할 수 있는 Dial 메서드를 제공합니다.
위 내용은 Go의 x/crypto/ssh를 사용하여 Bastion 호스트를 통해 개인 인스턴스에 대한 SSH 연결을 설정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!