在Fabric中使用SSH密钥文件


100

如何配置结构以使用SSH密钥文件连接到远程主机(例如,Amazon EC2实例)?

Answers:


69

在这里还值得一提的是,您可以为此使用命令行参数:

fab command -i /path/to/key.pem [-H [user@]host[:port]]

150

由于某种原因,要找到一个简单的fabfile以及一个使用SSH密钥文件的有效示例并不容易。我写了一篇有关它的博客文章带有匹配的要点)。

基本上,用法是这样的:

from fabric.api import *

env.hosts = ['host.name.com']
env.user = 'user'
env.key_filename = '/path/to/keyfile.pem'

def local_uname():
    local('uname -a')

def remote_uname():
    run('uname -a')

重要的是设置env.key_filename环境变量,以便Paramiko配置在连接时可以查找它。


4
在实践中,这是更好的答案。
panchicore 2012年

3
env.key_filename 可以包含一个字符串列表,以尝试连接的多个密钥文件。
卡尔·G

我在使用settings上下文管理器的一项任务中以编程方式设置了密钥,直到我更改key_filename='/path/to/key'为,否则无法识别key_filename=['/path/to/key']密钥文件名,因此,如果其他任何人遇到麻烦,请将密钥文件名列为密钥列表可能会解决该问题。这是fab 1.10.1和
Paramiko

2
@AseemHegshetye,它在最新的辗转面料2.这个答案是织物1
尤利安Onofrei

1
我希望使用显式导入而不是导入*
MIT

64

从Fabric 1.4开始提供的另一个很酷的功能-Fabric现在支持SSH配置

如果您的文件中已经包含所有SSH连接参数~/.ssh/config,Fabric将本地支持它,您只需添加:

env.use_ssh_config = True

在fabfile的开头。


2
很有用!如果您遇到类似之类的错误,IOError: [Errno 2] No such file or directory: ' /path/to/.ssh/key'或者Login password for ' root':只是确保您的中没有空格.ssh/config。例如,User=root而不是User = root...
dennis 2013年

@dennis这似乎在2016年仍然是一个问题。谢谢!
gabn88 '16

17

对于fabfile中的fabric2,请使用以下命令:

from fabric import task, Connection

@task
def staging(ctx):
    ctx.name = 'staging'
    ctx.user = 'ubuntu'
    ctx.host = '192.1.1.1'
    ctx.connect_kwargs.key_filename = os.environ['ENV_VAR_POINTS_TO_PRIVATE_KEY_PATH']

@task
def do_something_remote(ctx):
    with Connection(ctx.host, ctx.user, connect_kwargs=ctx.connect_kwargs) as conn:
        conn.sudo('supervisorctl status')

并运行:

fab staging do_something_remote

更新:
对于多个主机(一个主机也可以),您可以使用以下命令:

from fabric2 import task, SerialGroup

@task
def staging(ctx):
    conns = SerialGroup(
        'user@10.0.0.1',
        'user@10.0.0.2',
        connect_kwargs=
        {
            'key_filename': os.environ['PRIVATE_KEY_TO_HOST']
        })
    ctx.CONNS = conns
    ctx.APP_SERVICE_NAME = 'google'

@task
def stop(ctx):
    for conn in ctx.CONNS:
        conn.sudo('supervisorctl stop ' + ctx.APP_SERVICE_NAME)

并使用fab或fab2运行它:

fab staging stop

1
这是在fabric 2.x中进行处理的正确方法,因为所有其他答案均无效。
Vivek Aditya

如何在此staging任务中支持多个主机?
Black_Rider

1
@Black_Rider,将它添加到我的答案中
-MikeL

15

对我来说,以下方法无效:

env.user=["ubuntu"]
env.key_filename=['keyfile.pem']
env.hosts=["xxx-xx-xxx-xxx.ap-southeast-1.compute.amazonaws.com"]

要么

fab command -i /path/to/key.pem [-H [user@]host[:port]]

但是,执行以下操作:

env.key_filename=['keyfile.pem']
env.hosts=["ubuntu@xxx-xx-xxx-xxx-southeast-1.compute.amazonaws.com"]

要么

env.key_filename=['keyfileq.pem']
env.host_string="ubuntu@xxx-xx-xxx-xxx.ap-southeast-1.compute.amazonaws.com"

3
如果您使用env.user="ubuntu"代替,则第一个示例对我有用env.user=["ubuntu"]
泰勒·埃德米斯顿,

7

我今天必须这样做,我的.py文件尽可能简单,就像在@YuvalAdam答案中发布的文件一样,但仍然不断提示输入密码...

查看paramiko(fabric用于ssh的库)日志,发现以下行:

不兼容的SSH节点(没有可接受的KEX算法)

我更新paramiko了:

sudo pip install paramiko --upgrade

现在它正在工作。


1

如上所述,Fabric将在某种形式之后支持.ssh / config文件设置,但是将pem文件用于ec2似乎是有问题的。IOW一个正确设置的.ssh / config文件将通过“ ssh服务器名”从命令行运行,并且当env.host = ['服务器名']时无法与“ fab sometask”一起工作。

通过在我的fabfile.py中指定env.key_filename ='keyfile'并复制我的.ssh / config中已经存在的IdentityFile条目,可以解决此问题。

这可以是Fabric或paramiko,在我的情况下是Fabric 1.5.3和Paramiko 1.9.0。


1

这些答案对py3.7,fabric2.5.0和paramiko 2.7.1都不起作用。

但是,使用文档中的PKey属性确实可以:http ://docs.fabfile.org/en/2.5/concepts/authentication.html#private-key-objects

from paramiko import RSAKey
ctx.connect_kwargs.pkey = RSAKey.from_private_key_file('path_to_your_aws_key')
with Connection(ctx.host, user, connect_kwargs=ctx.connect_kwargs) as conn:
    //etc.... 
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.