다음의 구조도에는 모델 빌딩 및 모델 배포 코드의 CodeCommit 저장소가 포함되어 있지 않습니다.
새로운 MLOps 프로젝트 템플릿을 사용하여 이미지 빌딩 CI/CD를 위해 다음과 같은 리소스를 프로비저닝하고 구성합니다. 이에 대해서는 이 포스트의 나중에 더 자세히 설명하겠습니다:
- SageMaker code repositories - 프로젝트 템플릿에 의해 다섯 개의 CodeCommit 저장소가 생성됩니다. 그 중 세 개의 저장소에는 처리, 교육 및 추론에 사용되는 이미지를 빌드하는 데 필요한 코드가 포함되어 있습니다. 이 코드는 원하는 대로 수정하여 이미지를 사용자 정의할 수 있습니다. SageMaker 파이프라인을 사용하여 모델 교육 코드에 대한 저장소와 AWS CloudFormation 및 CodePipeline을 사용하여 모델 배포 코드에 대한 저장소가 포함되어 있습니다. UI를 통해 CI/CD 파이프라인의 일부로 빌드하려는 이미지를 선택할 수 있으며, 선택한 저장소만이 생성됩니다.
- Amazon ECR repositories - 교육, 처리 및 추론 이미지를 위한 Amazon ECR 저장소가 생성됩니다.
- Model build and deploy triggers - Amazon EventBridge 규칙이 생성되어 Amazon ECR 상태 변경 시 모델 빌드 CodePipeline 파이프라인을 트리거합니다. 이로써 Amazon ECR에 새로운 컨테이너 버전이 빌드되고 푸시될 때 자동으로 SageMaker 파이프라인을 트리거하는 프로세스가 자동화됩니다. 또한 모델 배포 CodePipeline 파이프라인은 이벤트브릿지를 통해 모델 레지스트리 내의 모델 상태가 '승인'으로 변경될 때 트리거되도록 구성됩니다.
- MLOps S3 bucket - MLOps 파이프라인을 위한 Amazon Simple Storage Service(Amazon S3) 버킷이 프로젝트와 파이프라인의 입력 및 아티팩트에 사용됩니다.
이러한 리소스를 사용하여 end-to-end CI/CD 파이프라인을 설정하기 위해 필요한 모든 프로비저닝 및 구성 작업은 SageMaker 프로젝트에 의해 자동으로 수행됩니다.
git clone https://github.com/jeonilshin/amazon-sagemaker-cicd-pipeline.git
mv amazon-sagemaker-cicd-pipeline/src/* ./
aws cloudformation create-stack --stack-name skills-infra --template-body file://aws.yml
약 10분에서 15분뒤
도메인에서 Launch
를 선택해서 Studio
를 선택하세요
Studio에 왼쪽에 드롭메뉴가 볼수 있습니다. 드롭메뉴 Deployments를 선택해서 Projects를 선택하고 + Create Project
를 누르세요
Image building, model building, and model deployment
선택하세요
다음과 같이 작성하고, Create Project
를 누르세요
Project가 생성 되면 밑 사진과 같이 Successfully created MyProject project.
가 뜨고, Project의 Repository도 생깁니다. clone repo...
를 누르세요
리포지토리를 clone후 codebuild-buildspec.yml
파일과 Dockerfile
파일이 왼쪽에 나타납니다.
buildspec 파일이 있다면 CodeBuild과 ECR도 정상 적으로 생성됬다는 의미입니다. 그래도, 정상 적으로 생성되는지 확인합니다.
새 코드가 이미지 빌딩 저장소 중 하나에 푸시되면 CodeBuild 프로젝트가 시작되고 새 이미지 버전이 빌드되어 Amazon ECR에 푸시됩니다. ML 워크플로우의 각 단계를 자동화하기 위해 EventBridge 규칙 세트가 생성됩니다. 이 새로운 템플릿에서는 EventBridge에서 규칙이 생성되어 새 컨테이너 버전이 Amazon ECR에 푸시될 때 모델 빌드 파이프라인을 트리거하도록 설정됩니다.
Dockerfile를 수정 하면 자동으로 CICD 파이프라인이 작동 하고 있는지 확인 할 수 있습니다.
- Dockerfile 수정.
- CodeCommit으로 Push 합니다.
- CodeBuild에 Build하고 있는지 확인 합니다.
우리가 수정했던 Dockerfile에 ECHO 명령어를 볼 수 있고
이미지 빌딩 CI/CD를 위한 새로운 SageMaker MLOps 프로젝트 템플릿을 안내했습니다. 이 템플릿에서 제공하는 구조를 활용하여 Docker 파일을 수정하여 사용 사례에 맞게 맞출 수 있으며, 더 많은 이미지 빌딩 저장소를 포함하는 사용자 정의 템플릿을 생성하거나 자동 파이프라인 트리거를 위한 사용자 정의 규칙을 생성할 수 있습니다. 이를 실제로 시도해보시고 궁금한 점이 있으면 댓글 섹션에서 질문해주시기 바랍니다!