小智 6
让我总结一下我在这里发现的内容
curl http://169.254.169.254/latest/meta-data/401 - Unauthorized,则它使用 IMDSv2 或非 IMDSv2。TOKEN=curl -X PUT "<http://169.254.169.254/latest/api/token"> -H "X-aws-ec2-metadata-token-ttl-seconds: 21600" && curl -H "X-aws-ec2-metadata-token: $TOKEN" -v http://169.254.169.254/latest/meta-data/如果您想更改此配置,请按照此操作。
如果您想从 EC2 实例中确定它,您可以尝试向http://169.254.169.254/发送请求并查看状态代码是什么。
例如,此实例启用了 IMDSv2,并且不接受没有令牌的请求:
$ curl -w "%{http_code}\n" http://169.254.169.254/
401
Run Code Online (Sandbox Code Playgroud)
在401个状态码是指未经授权。
如果您拥有有权描述 EC2 实例的 AWS 访问密钥,那么您可以运行以下命令:
$ aws ec2 describe-instances --region us-west-2 --instance-id i-0123456789abcdef --query Reservations[0].Instances[0].MetadataOptions
{
"State": "applied",
"HttpTokens": "optional",
"HttpPutResponseHopLimit": 1,
"HttpEndpoint": "enabled"
}
Run Code Online (Sandbox Code Playgroud)
此服务器不需要 IMDSv2 ( HttpTokensis optional)。
要启用 IMDSv2,您可以运行aws ec2 modify-instance-metadata-options.
| 归档时间: |
|
| 查看次数: |
1621 次 |
| 最近记录: |