我在使用Fabric部署Django站点时遇到了一个奇怪的问题。我已经配置了两台服务器来使用密钥文件进行登录。我可以在没有密码的情况下SSH到两者。我可以正确地运行fab,
$ fab live pull
[mysite.com] Executing task 'pull'
[mysite.com] run: test -d proj
[mysite.com] run: test -d proj/.git
[mysite.com] run: git pull origin master
...
而另一台服务器要求输入密码:
$ fab staging pull
[dev.mysite.com] Executing task 'pull'
[dev.mysite.com] run: test -d proj
[dev.mysite.com] Login password:
fabfile非常明确地设置
def staging():
env.hosts = ['dev.mysite.com']
env.user = 'bamboo'
env.key_filename = '~/.ssh/id_dsa_bamboo'
并直接从命令行运行ssh工作
$ ssh [email protected] -i ~/.ssh/id_dsa_bamboo
Last login: Wed Apr 11 06:24:28 2012 from xxx.xxx.xx.xx
[bamboo@dev ~]$
我也尝试设置env.use_ssh_config = True
并运行~/.ssh/config
设置为
Host dev.mysite.com
User bamboo
IdentityFile ~/.ssh/id_dsa_bamboo
ForwardAgent yes
什么想法可能会发生什么?谢谢您的帮助。
你可以加:
ssh.util.log_to_file("paramiko.log", 10)
在导入之后,在fabfile的顶部,以获取有关授权过程的更多详细信息。
对我来说,我不得不重置SSH代理身份:
ssh-add -D
然后添加我的密钥:
ssh-add -K keyname
小心,这将删除SSH代理的所有身份。
我不得不更新结构(可能在osx更新后):
sudo pip install --upgrade fabric