4

展開を自動化するためにファブリックを実行しています。痛いほど遅いです。

私のローカル環境:

(somenv)bob@sh ~/code/somenv/somenv/fabfile $  > uname -a
Darwin sh.local 12.4.0 Darwin Kernel Version 12.4.0: Wed May  1 17:57:12 PDT 2013; root:xnu-2050.24.15~1/RELEASE_X86_64 x86_64

私のファブファイル:

#!/usr/bin/env python

import logging
import paramiko as ssh
from fabric.api import env, run

env.hosts = [ 'examplesite']
env.use_ssh_config = True
#env.forward_agent = True
logging.basicConfig(level=logging.INFO)
ssh.util.log_to_file('/tmp/paramiko.log')

def uptime():
  run('uptime')

デバッグ ログの一部を次に示します。

(somenv)bob@sh ~/code/somenv/somenv/fabfile $  > date;fab -f /Users/bob/code/somenv/somenv/fabfile/pefabfile.py uptime
Sun Aug 11 22:25:03 EDT 2013
[examplesite] Executing task 'uptime'
[examplesite] run: uptime
DEB [20130811-22:25:23.610] thr=1   paramiko.transport: starting thread (client mode): 0x13e4650L
INF [20130811-22:25:23.630] thr=1   paramiko.transport: Connected (version 2.0, client OpenSSH_5.9p1)
DEB [20130811-22:25:23.641] thr=1   paramiko.transport: kex algos:['ecdh-sha2-nistp256', 'ecdh-sha2-nistp384', 'ecdh-sha2-nistp521', 'diffie-hellman-grou

paramiko がスレッドを開始するまでに 20 秒かかります。確かに、Executing task 'uptime'それほど時間はかかりません。ssh を介して手動でログインし、稼働時間を入力して、5 ~ 6 秒で終了できます。モードのデバッグ情報を抽出する方法について何か助けていただければ幸いです。ここに記載されている変更を行いましたが、違いはありません。

4

3 に答える 3

8

試す:

env.disable_known_hosts = True

参照: https://github.com/paramiko/paramiko/pull/192 & paramiko による遅い公開鍵認証

于 2013-09-16T13:42:38.000 に答える