我们的团队正在开发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
答案 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:
要使用它,只需致电
sash <machine-name>
我还添加了更多功能,例如upload
,download
和多重连接......
答案 2 :(得分:0)
简单的方法是将此ssh -i ~/.aws/my-pem-file.pem ubuntu@ec2-111-111-111-111.compute-1.amazonaws.com
输入到.sh文件中,其中包含您指定的逻辑名称。现在,当您运行$ logical-name.sh时,您将登录到该实例。如果实例地址已更改,则需要更新该文件。要克服的一个选择是为每个实例分配ip,但我不确定这是否可行。