【发布时间】:2019-08-29 23:11:21
【问题描述】:
我有一个动态 IP 上的 EC2 实例,它没有执行任何类型的 DDNS 来保持指向它的公共主机名。我想在我的ssh_config 中为服务器设置一个快捷方式,并让aws CLI 告诉我IP 或主机名是什么。
$ aws ec2 describe-instances \
--filters Name=key-name,Values=FOO \
--query 'Reservations[*].Instances[*].PublicDnsName' \
--output 'text'
ec2-XXX-XXX-XXX-XXX.compute-X.amazonaws.com
但我不知道如何将公共 IP 或主机名解析委派给 aws。
我看到很多人都有scripts for generating an ssh_config from aws,但是如果脚本要修改文件,我不想丢失其他东西。其他一些人有shell aliases to use instead of ssh,但这会使其他专门依赖 SSH 的服务变得复杂。
如果可能,我也宁愿不要使用外部脚本。
Host FOO ec2-FOO
User ec2-user
IdentityFile ~/.ssh/creds/some.pem
# Irrelevant?
Hostname example.com
# Neither alternative below works (assume full `aws` command)
ProxyCommand bash -c 'ssh -i %i %u@$(aws ec2 describe-instances …)'
ProxyCommand nc $(aws ec2 describe-instances …) %p
注意%i(上面用于指定IdentityFile)是not a valid token for ProxyCommand。
相关问题
【问题讨论】:
标签: amazon-ec2 openssh ssh-config