我正在运行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,但没有区别。
答案 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
答案 2 :(得分:0)
对于正在查看2014年后的任何人paramiko
,这是检查已知主机时的慢速组件,于2014年3月(v1.13)引入了一个修复程序,{{1}在v1.9.0中,并向后移植到v1.8.4和v1.7.4。
所以,升级!