- declarative way of outlining your AWS infrastructure for any resources
Benefits
=> Infrastructure as code
=> Cost Saving: Saving strategy, estimate
=> Productivity: destroy and re-created
Exercise
CloudFormation Code
data:image/s3,"s3://crabby-images/c2bd0/c2bd006a5c98ba23ae6c17645aeefc4c0362bb78" alt=""
Creating
data:image/s3,"s3://crabby-images/ee66b/ee66b87af070c4caa10edfd52fa7ffc5fde7ab1d" alt=""
If you click View in Designer
data:image/s3,"s3://crabby-images/d5a68/d5a68c7c484ad2e67b52c57e97534ae32bdb94f0" alt=""
Specify Stack Name
data:image/s3,"s3://crabby-images/f4c51/f4c51cce7591db1906c7ef17ac123a8fe68e9030" alt=""
Here's the Stack
data:image/s3,"s3://crabby-images/470af/470af61c4d03a6c85adb2afe9fd5b4d34706230a" alt=""
When Creation is Done
data:image/s3,"s3://crabby-images/f0fa8/f0fa8d53c8169d2938c6b865862125f69b9fc14c" alt=""
When press Delete Button its gonna delete all the resources
data:image/s3,"s3://crabby-images/38944/389446772b540d7547e1d2bd9c13e76e67934733" alt=""
CDK(AWS Cloud Development Kit)
- a way for you to define your cloud infrastructureusing a familiar programming language.
- CDK를 사용하면 클라우드 인프라를 JavaScript, TypeScript, Python, Java, .NET과 같은 프로그래밍 언어로 작성할 수 있습니다. 이렇게 작성된 코드는 CDK에 의해 CloudFormation 템플릿으로 컴파일되어 JSON 또는 YAML 형식으로 사용될 수 있습니다. 따라서 인프라와 애플리케이션 런타임 코드를 함께 배포할 수 있으며, 같은 언어를 공유할 수 있습니다.
Elastic Beanstalk
data:image/s3,"s3://crabby-images/03e7c/03e7ce868f98f09443ffe735c6824d31892e14a8" alt=""
=> Manage Infrastructure, Deploy Code, Configure all databaes + load balancers, etc + Scaling Concerns
Elastic Beanstalk is a developer centric view of deploying an application on AWS(in one view)
- Managed Service
- Instance configuration / OS is handled by Beanstalk
- Deployment strategy is configurable but performed by Elastic Beanstalk
=> Just application code is resposibility of develop
Configure Environment
data:image/s3,"s3://crabby-images/51805/5180535543bcec7e60c906e6c3ea4eee5705e3d7" alt=""
data:image/s3,"s3://crabby-images/af242/af2425d6e70153b06185b51a84a6af68a430eed4" alt=""
Platform
data:image/s3,"s3://crabby-images/62852/6285256e331f3a8ab293fc5e741a744e15ad409c" alt=""
Samples
data:image/s3,"s3://crabby-images/6112c/6112c6072db3f57376a13292bc0f7a5f6170d27f" alt=""
Service Access
data:image/s3,"s3://crabby-images/4728e/4728e9f864c3eaf4e1929eff33a7c532438fa606" alt=""
Create New Role with those policies
data:image/s3,"s3://crabby-images/4bc1a/4bc1ad87e423617486e4f78c36d3e1da13b1a0f4" alt=""
data:image/s3,"s3://crabby-images/4cc4c/4cc4c53540365ed3a94dc1e4a3404844adfe4049" alt=""
and Click skip to review
data:image/s3,"s3://crabby-images/45e33/45e332212be3eb9b67e707a27ea30f9dd7a83f15" alt=""
CloudFormation will be created
data:image/s3,"s3://crabby-images/100fb/100fbc6da984b33307fac3d211b5b7448782e686" alt=""
data:image/s3,"s3://crabby-images/1cd72/1cd728f3b59b253f5ef81efdf511d9d5117d9151" alt=""
If you click on Beanstalk Domain Name
data:image/s3,"s3://crabby-images/7f81e/7f81eac1dbf29443b5bacc1692d675a0feddb319" alt=""
CodeDeploy
- allows you to upgrade both your EC2 instances, applications, and your On-Premises Servers applications from version one to version two,
automatically from a single interface.
CodeCommit
- AWS Github
- Source-control service that hosts Git-based repositories
Benefits:
• Fully managed
• Scalable & highly available
• Private, Secured, Integrated with AWS
CodeBuild
- Code building service in the cloud
- Compiles source code, run tests, and produces packages that are ready to be deployed (by CodeDeploy for example)
data:image/s3,"s3://crabby-images/eea1f/eea1f61579ec30f011edad5246e903f567e3e4b8" alt=""
Benefits:
- Fully Managed, serverless
- Continuously scalable & highly available
CodePipeline
- Orchestrate the different steps to have the code automatically pushed to production(CI/CD)
Benefits:
- Fully managed
- Fast delivery & rapid updates
data:image/s3,"s3://crabby-images/6136e/6136ed9d7e072375202fafdb619bc7d34d10647a" alt=""
CodeArtifact
- secure, scalable, and cost-effective artifact management for software development
- Works with common dependency management tools such as Maven, Gradle, npm, yarn, twine, pip, and NuGet
CodeStar
- Unified UI
- “Quick way” to get started to correctly set-up CodeCommit, CodePipeline,CodeBuild, CodeDeploy, Elastic Beanstalk, EC2, etc...
Cloud9
- cloud IDE (Integrated Development Environment) for writing, running and debugging code (IntelliJ, Visual Studio Code)
- Web Browser IDE
=> Real time pair programming
AWS Systems Manager는 AWS의 리소스 및 온프레미스 서버의 자동 및 수동 작업을 관리합니다.
- 온프레미스와 EC2 인스턴스의 패키지 업그레이드
- 설치 소프트웨어 목록 생성
- 새 애플리케이션 설치
- EBS 스냅샷을 이용한 AMI 이미지 생성
- IAM 인스턴스 프로파일 부착
- S3 버킷에 대한 퍼블릭 접근 차단
data:image/s3,"s3://crabby-images/b6bcc/b6bcc327af16ce5709256b0635b641ac92b9a08c" alt=""
=> Allows you to start a secure shell on your EC2 and on-premises servers
Systems Manager의 주요 기능은 다음 두 가지입니다.
- 액션(Actions)
- 인사이트(Insights)
=> 패치 자동화는 여러 서버에 있는 소프트웨어나 시스템을 최신 상태로 유지하기 위해 사용되는 프로세스입니다. 이를 통해 관리자는 일일이 각 서버에 접속하여 패치를 설치하거나 업데이트하는 번거로움을 덜 수 있습니다. 대신, 자동화된 방식으로 패치를 배포하고, 일관된 규정 준수를 달성
출처: https://kimjingo.tistory.com/187 [김징어의 Devlog:티스토리]
System Manager Parameter Store
- Secure Storage for configuration and secrets
- Severless, scalable, durable
data:image/s3,"s3://crabby-images/d878a/d878af53e6200b7107fbf6a0501db200773c5944" alt=""
data:image/s3,"s3://crabby-images/7d3f0/7d3f07fe723eb6c051d57758d4b61d45fea567a3" alt=""
data:image/s3,"s3://crabby-images/b453c/b453c4856e91e39e7c8e6fdd3bd7a8b30e345941" alt=""