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

Uri*_*ssi 3 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
Run Code Online (Sandbox Code Playgroud)

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

就像是

ssh-aws my-machine-name
Run Code Online (Sandbox Code Playgroud)

Rya*_*man 7

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

其次,如果您配置了Unified AWS CLI工具,则可以将这些功能添加到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")
}
Run Code Online (Sandbox Code Playgroud)

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

您可以根据需要随意调整/调整.


Uri*_*ssi 3

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

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

要使用它,只需调用

sash <machine-name>
Run Code Online (Sandbox Code Playgroud)

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