面料需要很长时间用ssh

时间:2013-08-12 02:35:00

标签: deployment ssh fabric paramiko

我正在运行fabric来自动部署。这很痛苦。

我的当地环境:

(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

我的fab文件:

#!/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秒内退出。我很感激有关如何提取模式调试信息的任何帮助。我做了changes mentioned here,但没有区别。

3 个答案:

答案 0 :(得分:8)

尝试:

env.disable_known_hosts = True

请参阅: https://github.com/paramiko/paramiko/pull/192 &安培; Slow public key authentication with paramiko

答案 1 :(得分:0)

可能是DNS解析和/或IPv6的问题。

您可以尝试一些事项:

  • 使用env.hosts
  • 中的IP地址替换服务器名称
  • 禁用IPv6
  • 使用其他DNS服务器(例如OpenDNS)

答案 2 :(得分:0)

对于正在查看2014年后的任何人paramiko,这是检查已知主机时的慢速组件,于2014年3月(v1.13)引入了一个修复程序,{{1}在v1.9.0中,并向后移植到v1.8.4和v1.7.4。

所以,升级!