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
なにか提案を?