AWS EC2 인스턴스 메타데이터
# IMDSv1
curl http://169.254.169.254/latest/dynamic/instance-identity/document
# IMDSv2
TOKEN=`curl -H "X-aws-ec2-metadata-token-ttl-seconds: 21600"` -X PUT "http://169.254.169.254/latest/api/token"
curl -H "X-aws-ec2-metadata-token: $TOKEN" http://169.254.169.254/latest/dynamic/instance-identity/document
{
"accountId": "",
"architecture": "arm64",
"availabilityZone": "ap-northeast-2c",
"billingProducts": null,
"devpayProductCodes": null,
"marketplaceProductCodes": null,
"imageId": "ami-0331a5c9d849893dc",
"instanceId": "",
"instanceType": "c6g.xlarge",
"kernelId": null,
"pendingTime": "2024-06-23T01:01:23Z",
"privateIp": "192.169.44.196",
"ramdiskId": null,
"region": "ap-northeast-2",
"version": "2017-09-30"
}
인스턴스 메타데이터 검색을 활용해서 동적 데이터의 인스턴스 자격 증명 문서(instance-identity/document)를 가져오는 예시이다. 이번 글에서는 AWS SDK for Java
라이브러리에서 제공하는 EC2 메타데이터 유틸리티
를 통해 AWS EC2 인스턴스에서 실행중인 애플리케이션 서버에서 EC2 인스턴스 정보를 조회할 수 있도록 작성해보려고 한다. 스프링 부트 기반의 애플리케이션이라면 스프링 부트 액추에이터의 InfoContributor 인터페이스를 구현한 EC2MetadataInfoContributor
를 만들어보자.
EC2MetadataInfoContributor with SDK for Java 1.x
dependencies {
// the AWS SDK for Java v1.x will enter maintenance mode on July 31, 2024, and reach end-of-support on December 31, 2025.
implementation platform('com.amazonaws:aws-java-sdk-bom:1.12.748')
implementation 'com.amazonaws:aws-java-sdk-ec2'
}
import com.amazonaws.util.EC2MetadataUtils;
import org.springframework.boot.actuate.info.Info;
import org.springframework.boot.actuate.info.InfoContributor;
import org.springframework.stereotype.Component;
@Component
public class EC2MetadataInfoContributor implements InfoContributor {
private final boolean isRunningAwsEC2;
public EC2MetadataInfoContributor() {
isRunningAwsEC2 = EC2MetadataUtils.getInstanceId() != null;
}
@Override
public void contribute(Info.Builder builder) {
if (isRunningAwsEC2) {
EC2MetadataUtils.InstanceInfo instanceInfo = EC2MetadataUtils.getInstanceInfo();
builder.withDetail("ec2", instanceInfo);
}
}
}
EC2MetadataInfoContributor with SDK for Java 2.x
dependencies {
implementation platform('software.amazon.awssdk:bom:2.21.4')
implementation 'software.amazon.awssdk:imds'
implementation 'software.amazon.awssdk:url-connection-client'
}
mport org.springframework.boot.actuate.info.Info;
import org.springframework.boot.actuate.info.InfoContributor;
import org.springframework.stereotype.Component;
import software.amazon.awssdk.core.document.Document;
import software.amazon.awssdk.imds.Ec2MetadataClient;
import software.amazon.awssdk.imds.Ec2MetadataResponse;
@Component
public class EC2MetadataInfoContributorV2 implements InfoContributor {
private boolean isRunningAwsEC2;
public EC2MetadataInfoContributorV2() {
try (Ec2MetadataClient client = Ec2MetadataClient.create()) {
isRunningAwsEC2 = client.get("/latest/meta-data/instance-id").asString() != null;
} catch (Exception ignored) {
// ignored
}
}
@Override
public void contribute(Info.Builder builder) {
if (isRunningAwsEC2) {
try (Ec2MetadataClient client = Ec2MetadataClient.create()) {
Ec2MetadataResponse metadataResponse = client.get("/latest/dynamic/instance-identity/document");
Document document = metadataResponse.asDocument();
builder.withDetail("ec2", document.asMap());
} catch (Exception ignored) {
// ignored
}
}
}
}
인스턴스 메타데이터 검색
- SDK 버전에 따라 SDK가 엔드포인트를 IMDS로 확인하기 위해 확인하는 위치가 다르다.
- Java 2.x는 IMDSv2만 지원하지만 Java 1.x는 IMDSv2 를 사용할 수 없을때 IMDSv1 으로도 조회한다.
- Java 2.x는 인스턴스 메타데이터 카테고리를 직접 명시해야한다.
- Java 1.x는 2025년 12월 31일 지원 종료(End of support)된다.