Java 개발자가 AWS ECS에 Spring Boot API를 배포하는 방법을 물었을 때 저는 이것이 CDKTF(Cloud Development Kit for Terraform) 프로젝트의 최신 업데이트를 살펴볼 수 있는 절호의 기회라고 생각했습니다.
이전 기사에서는 Python과 같은 범용 프로그래밍 언어를 사용하여 IaC(Infrastructure as Code)를 작성할 수 있는 프레임워크인 CDKTF를 소개했습니다. 그 이후로 CDKTF는 첫 번째 GA 릴리스에 도달했으며 지금이 다시 방문하기에 완벽한 시기입니다. 이 기사에서는 CDKTF를 사용하여 AWS ECS에 Spring Boot API를 배포하는 방법을 안내합니다.
내 Github 저장소에서 이 기사의 코드를 찾아보세요.
구현에 대해 자세히 알아보기 전에 배포하려는 아키텍처를 검토해 보겠습니다.
이 다이어그램에서 아키텍처를 3개의 레이어로 나눌 수 있습니다.
우리가 배포 중인 Java API는 GitHub에서 사용할 수 있습니다.
3개의 엔드포인트가 있는 간단한 REST API를 정의합니다.
Dockerfile을 추가해 보겠습니다.
FROM maven:3.9-amazoncorretto-21 AS builder WORKDIR /app COPY pom.xml . COPY src src RUN mvn clean package # amazon java distribution FROM amazoncorretto:21-alpine COPY --from=builder /app/target/*.jar /app/java-api.jar EXPOSE 8080 ENTRYPOINT ["java","-jar","/app/java-api.jar"]
애플리케이션을 배포할 준비가 되었습니다!
AWS CDKTF를 사용하면 Python을 사용하여 AWS 리소스를 정의하고 관리할 수 있습니다.
- [**python (3.13)**](https://www.python.org/) - [**pipenv**](https://pipenv.pypa.io/en/latest/) - [**npm**](https://nodejs.org/en/)
CDKTF 및 해당 종속 항목을 설치하여 필요한 도구가 있는지 확인하세요.
$ npm install -g cdktf-cli@latest
이렇게 하면 다양한 언어에 대한 새 프로젝트를 시작할 수 있는 cdktf CLI가 설치됩니다.
다음을 실행하여 새로운 Python 프로젝트를 스캐폴딩할 수 있습니다.
FROM maven:3.9-amazoncorretto-21 AS builder WORKDIR /app COPY pom.xml . COPY src src RUN mvn clean package # amazon java distribution FROM amazoncorretto:21-alpine COPY --from=builder /app/target/*.jar /app/java-api.jar EXPOSE 8080 ENTRYPOINT ["java","-jar","/app/java-api.jar"]
3 단계 : 건물 층
- [**python (3.13)**](https://www.python.org/) - [**pipenv**](https://pipenv.pypa.io/en/latest/) - [**npm**](https://nodejs.org/en/)는 Terraform (CDKTF)의 CDK가 뚜렷한 TerraForm 구성으로 컴파일되는 인프라 리소스 그룹을 나타냅니다. 스택은 응용 프로그램 내의 다른 환경에 대해 별도의 상태 관리를 가능하게합니다. 계층 간의 리소스를 공유하려면 크로스 스택 참조를 사용합니다.
<_> 프로젝트에 Network_stack.py 파일을 에 추가하십시오
모든 네트워크 리소스를 생성하려면 다음 코드를 추가하십시오.
네트워크 스택을 를 배포하십시오
$ npm install -g cdktf-cli@latest
# init the project using aws provider $ mkdir samples-fargate $ cd samples-fargate && cdktf init --template=python --providers=aws
2.
infra_stack.py 파일을 추가하십시오
#!/usr/bin/env python from constructs import Construct from cdktf import App, TerraformStack class MyStack(TerraformStack): def __init__(self, scope: Construct, id: str): super().__init__(scope, id) # define resources here app = App() MyStack(app, "aws-cdktf-samples-fargate") app.synth()
모든 인프라 리소스를 생성하기 위해 다음 코드를 추가하십시오.
<p>
<br>
파일을 편집하십시오 :
</p>
<pre class="brush:php;toolbar:false">$ mkdir infra
$ cd infra && touch network_stack.py
</pre>
<p>
<inf> 를 배치하십시오
<br>
<n> alb의 DNS 이름에 주목하십시오.
</n></inf></p> <pre class="brush:php;toolbar:false">from constructs import Construct
from cdktf import S3Backend, TerraformStack
from cdktf_cdktf_provider_aws.provider import AwsProvider
from cdktf_cdktf_provider_aws.vpc import Vpc
from cdktf_cdktf_provider_aws.subnet import Subnet
from cdktf_cdktf_provider_aws.eip import Eip
from cdktf_cdktf_provider_aws.nat_gateway import NatGateway
from cdktf_cdktf_provider_aws.route import Route
from cdktf_cdktf_provider_aws.route_table import RouteTable
from cdktf_cdktf_provider_aws.route_table_association import RouteTableAssociation
from cdktf_cdktf_provider_aws.internet_gateway import InternetGateway
class NetworkStack(TerraformStack):
def __init__(self, scope: Construct, ns: str, params: dict):
super().__init__(scope, ns)
self.region = params["region"]
# configure the AWS provider to use the us-east-1 region
AwsProvider(self, "AWS", region=self.region)
# use S3 as backend
S3Backend(
self,
bucket=params["backend_bucket"],
key=params["backend_key_prefix"] + "/network.tfstate",
region=self.region,
)
# create the vpc
vpc_demo = Vpc(self, "vpc-demo", cidr_block="192.168.0.0/16")
# create two public subnets
public_subnet1 = Subnet(
self,
"public-subnet-1",
vpc_id=vpc_demo.id,
availability_zone=f"{self.region}a",
cidr_block="192.168.1.0/24",
)
public_subnet2 = Subnet(
self,
"public-subnet-2",
vpc_id=vpc_demo.id,
availability_zone=f"{self.region}b",
cidr_block="192.168.2.0/24",
)
# create. the internet gateway
igw = InternetGateway(self, "igw", vpc_id=vpc_demo.id)
# create the public route table
public_rt = Route(
self,
"public-rt",
route_table_id=vpc_demo.main_route_table_id,
destination_cidr_block="0.0.0.0/0",
gateway_id=igw.id,
)
# create the private subnets
private_subnet1 = Subnet(
self,
"private-subnet-1",
vpc_id=vpc_demo.id,
availability_zone=f"{self.region}a",
cidr_block="192.168.10.0/24",
)
private_subnet2 = Subnet(
self,
"private-subnet-2",
vpc_id=vpc_demo.id,
availability_zone=f"{self.region}b",
cidr_block="192.168.20.0/24",
)
# create the Elastic IPs
eip1 = Eip(self, "nat-eip-1", depends_on=[igw])
eip2 = Eip(self, "nat-eip-2", depends_on=[igw])
# create the NAT Gateways
private_nat_gw1 = NatGateway(
self,
"private-nat-1",
subnet_id=public_subnet1.id,
allocation_id=eip1.id,
)
private_nat_gw2 = NatGateway(
self,
"private-nat-2",
subnet_id=public_subnet2.id,
allocation_id=eip2.id,
)
# create Route Tables
private_rt1 = RouteTable(self, "private-rt1", vpc_id=vpc_demo.id)
private_rt2 = RouteTable(self, "private-rt2", vpc_id=vpc_demo.id)
# add default routes to tables
Route(
self,
"private-rt1-default-route",
route_table_id=private_rt1.id,
destination_cidr_block="0.0.0.0/0",
nat_gateway_id=private_nat_gw1.id,
)
Route(
self,
"private-rt2-default-route",
route_table_id=private_rt2.id,
destination_cidr_block="0.0.0.0/0",
nat_gateway_id=private_nat_gw2.id,
)
# associate routes with subnets
RouteTableAssociation(
self,
"public-rt-association",
subnet_id=private_subnet2.id,
route_table_id=private_rt2.id,
)
RouteTableAssociation(
self,
"private-rt1-association",
subnet_id=private_subnet1.id,
route_table_id=private_rt1.id,
)
RouteTableAssociation(
self,
"private-rt2-association",
subnet_id=private_subnet2.id,
route_table_id=private_rt2.id,
)
# terraform outputs
self.vpc_id = vpc_demo.id
self.public_subnets = [public_subnet1.id, public_subnet2.id]
self.private_subnets = [private_subnet1.id, private_subnet2.id]
</pre>
<p>
3. <service> 서비스 계층
<img src="https://img.php.cn/upload/article/000/000/000/173768468278252.png" alt="Network Deployment" loading="lazy" style="max-width:90%" style="max-width:90%">
</service></p> 프로젝트 에 service_stack.py <lo> 파일을 추가하십시오
<p>
</p>
<code> 모든 ECS 서비스 리소스를 생성하려면 다음 코드를 추가하십시오.
<p>
<img src="https://img.php.cn/upload/article/000/000/000/173768468369073.png" alt="Network Map" loading="lazy" style="max-width:90%" style="max-width:90%">
<..> main.py를 업데이트하십시오 (마지막으로?) :
</..></p>
<h3>
서비스 스택 를 배포하십시오
</h3>
여기 우리는 간다!
<created> 우리는 AWS ECS Fargate에 새로운 서비스를 배치하기 위해 모든 리소스를 성공적으로 만들었습니다.
<to> 스택 목록을 얻으려면 다음을 실행하십시오.
<p>
<strong>
</strong> <br></p>
<h2>
4단계: Github 작업 워크플로
</h2>
<p>배포를 자동화하기 위해 GitHub Actions 워크플로를 <strong>java-api</strong>에 통합해 보겠습니다. Github Actions를 활성화하고 저장소의 비밀과 변수를 설정한 후 .github/workflows/deploy.yml 파일을 생성하고 아래 콘텐츠를 추가하세요.<br>
</p>
<pre class="brush:php;toolbar:false">FROM maven:3.9-amazoncorretto-21 AS builder
WORKDIR /app
COPY pom.xml .
COPY src src
RUN mvn clean package
# amazon java distribution
FROM amazoncorretto:21-alpine
COPY --from=builder /app/target/*.jar /app/java-api.jar
EXPOSE 8080
ENTRYPOINT ["java","-jar","/app/java-api.jar"]
</pre>
<p>워크플로가 잘 작동하고 있습니다.</p>
<p><img src="https://img.php.cn/upload/article/000/000/000/173768468718392.png" alt="Github Actions" loading="lazy" style="max-width:90%" style="max-width:90%"></p>
<p>아래 이미지와 같이 서비스가 성공적으로 배포되었습니다.</p>
<p><img src="https://img.php.cn/upload/article/000/000/000/173768468825982.png" alt="ECS Service" loading="lazy" style="max-width:90%" style="max-width:90%"></p>
<h2>
5단계: 배포 검증
</h2>
<p>다음 스크립트를 사용하여 배포를 테스트합니다(<em>ALB URL을 사용자 URL로 교체</em>).<br>
</p>
<pre class="brush:php;toolbar:false">- [**python (3.13)**](https://www.python.org/)
- [**pipenv**](https://pipenv.pypa.io/en/latest/)
- [**npm**](https://nodejs.org/en/)
</pre>
<blockquote>
<p>이제 ALB가 트래픽을 처리할 준비가 되었습니다!</p>
</blockquote>
<h2>
<strong>최종 생각</strong>
</h2>
<p>AWS CDKTF를 활용하면 Python을 사용하여 깔끔하고 유지 관리가 가능한 IaC 코드를 작성할 수 있습니다. 이 접근 방식은 AWS ECS Fargate에서 Spring Boot API와 같은 컨테이너화된 애플리케이션 배포를 단순화합니다.</p>
<p>CDKTF의 유연성과 Terraform의 강력한 기능이 결합되어 최신 클라우드 배포를 위한 탁월한 선택이 됩니다.</p>
<p>CDKTF 프로젝트는 인프라 관리를 위한 많은 흥미로운 기능을 제공하지만 때로는 너무 장황하다고 생각될 때도 있다는 점을 인정해야 합니다.</p>
<p>CDKTF에 대한 경험이 있나요? 제작에 사용해 보셨나요?</p>
<p>귀하의 경험을 자유롭게 공유해 주세요.</p>
</to></created>
위 내용은 CDKTF를 사용하여 AWS EC에 SpringBoot API를 배포하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!