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 中国語 Web サイトの他の関連記事を参照してください。