SSH를 사용하여 원격 서버에 안전하게 연결하는 것은 시스템 관리 및 자동화의 일반적인 작업입니다. Linux 서버를 다룰 때 보안 강화를 위해 SSH 키 인증이 비밀번호 인증보다 선호되는 경우가 많습니다. 이 문서에서는 Go에서 PEM(Privacy Enhanced Mail) 키를 사용하여 원격 서버에 SSH 연결을 설정하는 방법을 보여줍니다.
Go의 ssh 패키지는 SSH 연결을 지원합니다. PEM 키를 사용하여 연결하려면 먼저 키를 ssh.Signer 객체로 구문 분석해야 합니다. 이 목적으로 ssh.ParsePrivateKey 함수를 사용할 수 있습니다. ssh.Signer가 있으면 ssh.PublicKeys를 사용하여 ssh.AuthMethod 객체를 생성할 수 있습니다. 이 ssh.AuthMethod는 서버 인증에 사용됩니다.
ssh.AuthMethod가 준비되었으면 이제 ssh.ClientConfig 개체를 구성할 수 있습니다. 이 구성에서는 사용자 이름, 인증 방법 및 기타 필수 매개변수를 지정합니다. 구성이 설정되면 ssh.Dial 기능을 사용하여 연결을 설정합니다. 그런 다음 ssh.NewSession을 사용하여 새 세션을 생성하고 원격 서버에서 명령을 실행할 수 있습니다.
다음은 단계를 간략하게 설명하는 예제 코드 조각입니다.
<code class="go">import ( "io" "log" "net" "os" "golang.org/x/crypto/ssh" ) func main() { pemBytes, err := os.ReadFile("my_key.pem") if err != nil { log.Fatal(err) } signer, err := ssh.ParsePrivateKey(pemBytes) if err != nil { log.Fatal(err) } auths := []ssh.AuthMethod{ssh.PublicKeys(signer)} cfg := &ssh.ClientConfig{ User: "my_user", Auth: auths, } conn, err := ssh.Dial("tcp", "remote_host:22", cfg) if err != nil { log.Fatal(err) } defer conn.Close() session, err := conn.NewSession() if err != nil { log.Fatal(err) } defer session.Close() stdout, err := session.StdoutPipe() if err != nil { log.Fatal(err) } if err := session.Run("whoami"); err != nil { log.Fatal(err) } if _, err := io.ReadAll(stdout); err != nil { log.Fatal(err) } }</code>
이 단계를 따르고 다음을 사용하여 제공된 코드 조각을 사용하면 Go 프로그램에서 PEM 키를 사용하여 원격 서버에 대한 보안 SSH 연결을 설정할 수 있습니다.
위 내용은 Go에서 SSH 및 PEM 키를 사용하여 서버에 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!