1

Google Compute Engine でインスタンスを作成しました。SSHJ を使用して接続する必要がありますが、取得できません。AWS を使用して正常に接続できます。

public String exec(String host, String keyPair, String script) throws IOException{
    File keyPairFile = new File(keyPair);
    SSHClient ssh = new SSHClient();
    ssh.addHostKeyVerifier(new PromiscuousVerifier());
    ssh.connect(host);

    PKCS8KeyFile keyFile = new PKCS8KeyFile();
    keyFile.init(keyPairFile);
    ssh.auth(USER_DEFAULT, new AuthPublickey(keyFile));

    Session session = null;
    try {
        logger.info("Conectando via ssh " + host + "...");
        session = ssh.startSession();
        final Command command = session.exec(script);
        String response = IOUtils.readFully(command.getInputStream()).toString();
        command.join(10, TimeUnit.SECONDS);
        return response;
    } finally {
        session.close();
        ssh.disconnect();
        ssh.close();
    }
}

Google Compute Engine は何をしますか?

puttygen を使用して公開鍵と秘密鍵を作成しました。次に、Google Compute Engine のコンソールにアクセスし、公開鍵をインポートしました。そうすれば、秘密鍵を使用してパテでアクセスできました。

上記で定義した exec メソッドを使用して SSHJ でアクセスしようとすると、次のエラーが発生します。

Exception in thread "main" net.schmizz.sshj.userauth.UserAuthException: Exhausted available authentication methods
    at net.schmizz.sshj.userauth.UserAuthImpl.authenticate(UserAuthImpl.java:114)
    at net.schmizz.sshj.SSHClient.auth(SSHClient.java:205)
    at net.schmizz.sshj.SSHClient.auth(SSHClient.java:190)
    at br.com.clouddeploy.service.SSHConnect.exec(SSHConnect.java:31)
    at br.com.clouddeploy.main.TestConecte.main(TestConecte.java:17)
Caused by: net.schmizz.sshj.userauth.UserAuthException: Problem getting public key from PKCS8KeyFile{resource=[PrivateKeyFileResource] E:\Essencial\SkyDrive\MESTRADO\Disciplinas\2014 e 2015\EDD\Pesquisa\google-teste.ppk}
    at net.schmizz.sshj.userauth.method.KeyedAuthMethod.putPubKey(KeyedAuthMethod.java:46)
    at net.schmizz.sshj.userauth.method.AuthPublickey.buildReq(AuthPublickey.java:62)
    at net.schmizz.sshj.userauth.method.AuthPublickey.buildReq(AuthPublickey.java:81)
    at net.schmizz.sshj.userauth.method.AbstractAuthMethod.request(AbstractAuthMethod.java:63)
    at net.schmizz.sshj.userauth.UserAuthImpl.authenticate(UserAuthImpl.java:92)
    ... 4 more
Caused by: java.io.IOException: Could not read key pair from: [PrivateKeyFileResource] E:\Essencial\SkyDrive\MESTRADO\Disciplinas\2014 e 2015\EDD\Pesquisa\google-teste.ppk
    at net.schmizz.sshj.userauth.keyprovider.PKCS8KeyFile.readKeyPair(PKCS8KeyFile.java:145)
    at net.schmizz.sshj.userauth.keyprovider.PKCS8KeyFile.getPublic(PKCS8KeyFile.java:72)
    at net.schmizz.sshj.userauth.method.KeyedAuthMethod.putPubKey(KeyedAuthMethod.java:44)
    ... 8 more

なにか提案を?

4

1 に答える 1