有没有一种简单的方法可以使用其Name标签连接到EC2实例?

时间:2014-01-29 07:37:00

标签: ssh amazon-ec2

我们的团队正在开发AWS,我们有很多实例,我们不断添加和删除。每个实例都有一个逻辑名称,这有助于我们了解它的作用以及查找它。 但是,当我们想连接到一个时,我们需要一直更新~/.ssh/config文件,或者转到Web控制台,按名称查找实例,复制其IP,然后才能运行它使用:

ssh -i ~/.aws/my-pem-file.pem ubuntu@ec2-111-111-111-111.compute-1.amazonaws.com

我在徘徊是否有一种更简单的方法,你可以指定机器名称,EC2会做其余的吗?

这样的东西
ssh-aws my-machine-name

3 个答案:

答案 0 :(得分:7)

如果使用弹性IP(未更改)配置实例/负载均衡器,则始终可以使用SSH配置文件。

其次,如果您配置了Unified AWS CLI Tools,则可以将这些功能添加到Bash配置文件中。假设您拥有的每个实例都有一个唯一的“Name”标记,这将返回该SSH实例请求的IP地址。 (否则,它只会使用第一个“名称”匹配。)

function hostname_from_instance() {
    echo $(aws ec2 describe-instances --filters "{\"Name\":\"tag:Name\", \"Values\":[\"$1\"]}" --query='Reservations[0].Instances[0].PublicDnsName' | tr -d '"')
}

function ip_from_instance() {
    echo $(aws ec2 describe-instances --filters "{\"Name\":\"tag:Name\", \"Values\":[\"$1\"]}" --query='Reservations[0].Instances[0].PublicIpAddress' | tr -d '"')
}

function ssh-aws() {
    ssh -i ~/.ssh/your-keypair.pem ec2-user@$(ip_from_instance "$1")
}

根据您是否在VPC内部运行实例,有时您会收到其中一个。全公共(经典)EC2应该总是取回主机名,有时候是公共IP。

根据需要随意调整/调整。

答案 1 :(得分:3)

我写了一个小bash脚本,使用aws-cli(感谢@Ryan Parman)从机器名称中找到正确的机器IP和PEM:

http://sash.agassi.co.il/

要使用它,只需致电

sash <machine-name>

我还添加了更多功能,例如uploaddownload和多重连接......

答案 2 :(得分:0)

简单的方法是将此ssh -i ~/.aws/my-pem-file.pem ubuntu@ec2-111-111-111-111.compute-1.amazonaws.com输入到.sh文件中,其中包含您指定的逻辑名称。现在,当您运行$ logical-name.sh时,您将登录到该实例。如果实例地址已更改,则需要更新该文件。要克服的一个选择是为每个实例分配ip,但我不确定这是否可行。