8

私はこれを機能させようとしていますが、同じエラーが発生し続けます。ホストのfqdnとipを試しました。クレデンシャルを使用して、または使用せずにパスしようとしました。エラーメッセージに示されている行を確認しました。グーグルを検索しましたが、これが機能しない理由を理解できません:

import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('host', username='loginname')
stdin, stdout, stderr = ssh.exec_command("pwd")
stdout.readlines()

エラー:

Traceback (most recent call last):
  File "audit.py", line 7, in <module>
    ssh.connect('host', username='loginname')
  File "/usr/lib/python2.6/site-packages/paramiko/client.py", line 338, in connect
    self._auth(username, password, pkey, key_filenames, allow_agent, look_for_keys)
  File "/usr/lib/python2.6/site-packages/paramiko/client.py", line 520, in _auth
    raise SSHException('No authentication methods available')
  • ssh経由で問題なくホストに接続できます。
  • sshバージョン:OpenSSH_5.3p1、OpenSSL1.0.0-fips2010年3月29日
  • 注:私は、いくつかのリモートサーバーで一連のコマンドを実行する方法を作成しようとしています。を使用sys import argvしてなどpython audit.py host1 host2 host3のスクリプトを実行すると、スクリプトはそれらの特定のホストの監査を実行します。これを実現するbashスクリプトをすでに作成しましたが、Pythonを介してそれを行うためのより良い方法が必要でした。
4

2 に答える 2

15

パスワードまたは秘密鍵(あるいはその両方)のいずれかを提供する必要があります。そうしないと、SSHクライアントはログインデータで認証する方法を認識しません。

これが参考のための私のコード例です。

#!/usr/bin/python

from StringIO import StringIO
import paramiko 

class SshClient:
    "A wrapper of paramiko.SSHClient"
    TIMEOUT = 4

    def __init__(self, host, port, username, password, key=None, passphrase=None):
        self.username = username
        self.password = password
        self.client = paramiko.SSHClient()
        self.client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
        if key is not None:
            key = paramiko.RSAKey.from_private_key(StringIO(key), password=passphrase)
        self.client.connect(host, port, username=username, password=password, pkey=key, timeout=self.TIMEOUT)

    def close(self):
        if self.client is not None:
            self.client.close()
            self.client = None

    def execute(self, command, sudo=False):
        feed_password = False
        if sudo and self.username != "root":
            command = "sudo -S -p '' %s" % command
            feed_password = self.password is not None and len(self.password) > 0
        stdin, stdout, stderr = self.client.exec_command(command)
        if feed_password:
            stdin.write(self.password + "\n")
            stdin.flush()
        return {'out': stdout.readlines(), 
                'err': stderr.readlines(),
                'retval': stdout.channel.recv_exit_status()}

if __name__ == "__main__":
    client = SshClient(host='host', port=22, username='username', password='password') 
    try:
       ret = client.execute('dmesg', sudo=True)
       print "  ".join(ret["out"]), "  E ".join(ret["err"]), ret["retval"]
    finally:
      client.close() 
于 2014-03-23T16:57:20.330 に答える
-3

ssh.connectの前に必要なもの:
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

次に、stdout.read()を使用して次のようなことを行う必要があります。

print stdout.read()
于 2013-01-14T21:11:48.467 に答える