Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
AWS ECS の説明 /aws-ecs-introduction
Search
yutachaos
October 01, 2018
Technology
120
0
Share
AWS ECS の説明 /aws-ecs-introduction
サポーターズ下記勉強会用資料
https://supporterzcolab.com/event/522/
yutachaos
October 01, 2018
More Decks by yutachaos
See All by yutachaos
JenkinsのJobを CronJobに移した話 /The story of moving Jenkins Job to CronJob
yutachaos
0
250
History of Infrastructure as a Code testing
yutachaos
2
5.5k
AWS CodePipeline 初めて触って少しハマった話 / A story that challenged AWS CodePipeline for the first time
yutachaos
0
120
gRPC in スタディサプリENGLISH / gRPC in StudySapuri ENGLISH
yutachaos
0
3k
AKS,EKS,GKEコマンド比較してみた /compared AKS, EKS, GKE command
yutachaos
2
2.5k
Docker + Jenkinsでバッチ実行 / Using Docker and Jenkins execution batch
yutachaos
0
280
Spring Batchの紹介
yutachaos
0
300
非エンジニア向けMarkdown 勉強会
yutachaos
1
450
Circle CI 入門
yutachaos
0
760
Other Decks in Technology
See All in Technology
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
5
1.3k
The essence of decision-making lies in primary data
kaminashi
0
230
Embeddings : Symfony AI en pratique
lyrixx
0
450
【AWS】CloudTrail LakeとCloudWatch Logs Insightsの使い分け方針
tsurunosd
0
130
自分をひらくと次のチャレンジの敷居が下がる
sudoakiy
5
1.7k
ブラックボックス化したMLシステムのVertex AI移行 / mlops_community_62
visional_engineering_and_design
1
260
Goビルドを理解し、 CI/CDの高速化に挑む
satoshin
0
100
OpenClaw初心者向けセミナー / OpenClaw Beginner Seminar
cmhiranofumio
0
240
Physical AI on AWS リファレンスアーキテクチャ / Physical AI on AWS Reference Architecture
aws_shota
1
310
VSCode中心だった自分がターミナル沼に入門した話
sanogemaru
0
900
「活動」は激変する。「ベース」は変わらない ~ 4つの軸で捉える_AI時代ソフトウェア開発マネジメント
sentokun
0
140
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
5
1.3k
Featured
See All Featured
Principles of Awesome APIs and How to Build Them.
keavy
128
17k
Are puppies a ranking factor?
jonoalderson
1
3.2k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
3.8k
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
440
A Modern Web Designer's Workflow
chriscoyier
698
190k
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
780
XXLCSS - How to scale CSS and keep your sanity
sugarenia
249
1.3M
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.5k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.7k
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
210
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Transcript
AWS ECS
ࣗݾհ • ଜ༐ଠ • SREΤϯδχΞ • ϓϩάϥϛϯάݴޠ • Java, node,
PHP, Ruby, Go • ීஈAWSΛར༻ͨ͠γεςϜͷӡ༻ɺӡ༻վળͱ͔ͬͯ·͢ɻ • ࠷ۙEnvoyΛ͍ͬͯ͡·ͨ͠ɻ • AWS Certificated Solutions Architect • AWS Certificated DepOps Engineer
Agenda • Containerٕज़ʹ͍ͭͯͷ͓͞Β͍ • ECSʹ͍ͭͯ • ECSͷ֓೦ʹ͍ͭͯ
ContainerͬͯԿʁ
• ߓʹ͋ΔΞϨ • Container ʹ DockerͰͳ͍ɻ • DockerίϯςφܕԾԽͷ࣮ͷҰͭ • DockerΧʔωϧͱcgroupsͳͲͷٕज़Λ
Έ߹ΘͤͯɺΞϓϦέʔγϣϯͱϥϯλΠϜ ࣮ߦڥΛ·ͱΊͯ͢Δٕज़ • ίϯςφϓϩηε ͬ͘͟Γͱͨ͠ղઆ
• ΞϓϦέʔγϣϯͱ࣮ߦڥΛҰͭʹ·ͱΊ Δ͜ͱͰ։ൃͱӡ༻νʔϜ͕εϜʔζʹӡ༻ ग़དྷΔ • e.g. ϩʔΧϧͱຊ൪Ͱಉ͡Dockerfile͑ Δ!ɺΠϯϑϥνʔϜ͕Dockerfile࡞ͬͯɺ ։ൃνʔϜʹͤΔʂٯ·ͨવΓ Կ͕ྑ͍ͷʁ
• Elastic Container Serviceͷུ • AWS͕ఏڙ͢ΔίϯςφΦʔέετϨʔ γϣϯπʔϧ • e.g. kubernates,
docker swarmͱ͔ • Docker͚ͩͰग़དྷͳ͍ίϯςφͷ Scaling, ஔ, ཧΛߦ͏αʔϏε ECSʹ͍ͭͯ
ECS overview EC2 Launch type
• ECR • Elastic Container RegistryͷུɺAWS্ͰϚωʔδυʹ ӡ༻͞ΕΔɺDocker imageΛอଘ͢ΔRegistry • Cluster
• Container͕࣮ࡍʹ࣮ߦ͞ΕΔEC2Πϯελϯεͷू߹ ମ • Service • Task definitionΛͱʹͯ͠࡞͞ΕͨTaskΛ͍ͭ͘ى ಈ͢Δ͔ɺͲͷΑ͏ʹஔ͢Δͷ͔ɺͲͷϩʔυόϥϯ αʔܦ༝Ͱ௨৴͢Δ͔ͷઃఆɻTask definitionͱ1:1Ͱ ઃఆ͢Δ ༻ޠ1
• Task definition • Containerͷ࣮ߦ͢Δܗ • Task • Task definitionΛͱʹͯ͠࡞͞Εͨ
Containerͷ࣮ଶ ༻ޠ2
Task Definitionʹ͍ͭͯ • ECS্Ͱ࣮ߦ͢ΔContainerͷઃఆ • EC2ͱFargateλΠϓ͕͋Δ • ࣮ߦͤ͞Δcontainerͷimage,ར༻͢Δ ڥมɺportͷઃఆͳͲΛߦ͏
Serviceʹ͍ͭͯ • ECS্Ͱ࣮ߦ͢ΔTaskʹ͍ͭͯͷ·ͱΊΔઃఆ • Containerͷಈ͔͢ɺInstanceͷTaskஔ ઓུ • Load balancerͷport mappingͳͲΛ୲͏ɻ
ECS agent • EC2্Ͱಈ͘ɺECSͷcontainerͷঢ়ଶΛѲ͢Δ agent • ͜ͷagentࣗମdockerͰEC2ͷதͰಈ͍͍ͯΔ • EC2 typeͷ߹ɺ͜ͷECS
agentΛEC2ىಈ࣌ʹಈ͘ Α͏ʹͯ͠Clusterʹొ͢Δ
Ϣʔεέʔε Rails appΛECSͰಈ͔͢߹ • Rails appͷimageΛઃఆͨ͠Task definitionΛ࡞ • Load balancerΛ͚ͭͨServiceΛ࡞͢Δ
Sample
ղઆ • Route53Λར༻ͯ͠domainΛઃఆ • ௨৴ALBܦ༝ͰContainerʹૹΔ • ApplicationContainerͰ࡞ɺECSͰε έʔϦϯάͷཧ
Fargate launch typeʹ͍ͭͯ • ECSʹ̎ͭͷlaunch type EC2 launch typeͱ Fargate
launch type͕͋Δɻ • EC2 launch typeContainerΛಈ͔ͨ͢ΊͷEC2Λ ཧ͢Δඞཁ͕͋Δ͕ɺFargate launch typeಈ͔ͨ͢ ΊͷEC2ͷresourceΛAWSଆͰཧͯ͘͠ΕΔɻ • ཧίετ͕ݮΔ • ݸਓతʹ·ͩಋೖͨ͜͠ͱͳ͍ɻ
ECS overview Fargate Launch type
͓ΘΓʹ • ECScluster্ͰserviceͰཧ͞Εͨ container͔ΒΔtaskΛtask definitionΛͱ ʹ࡞͠ɺӡ༻͢Δػೳ • ContainerΛຊ൪ӡ༻͢Δ͜ͱ։ൃɺӡ༻త ͳϦϨʔγϣϯʹʹཱͭ
༨ஊ
Modern Web appΛߟ͑Δͱ ͖ʹศརͳϖʔδ
Twelve-factor-app • https://12factor.net/ • ݩherokuͷ Adam Wiggins͕2011ʹॻ͍ ͨmodernͳSaaSΛ࡞ΔͨΊͷํ๏ • ࣮࣭ContainerΛར༻͢ΔappΛ࡞͢Δͱ
͖ͷํ๏ͷstandardͷҰͭ
Cloud Native landscape • https://landscape.cncf.io/ • CNCF(Cloud Native Computing Foundation)
͕ఏ͍ࣔͯ͠ΔɺCloud NativeͳΞϓϦέʔ γϣϯΛનΊ্͍ͯ͘ͰͷϩʔυϚοϓ
AWS ެࣜͷࢿྉ • ެࣜͷdoc • re:InventAWS Summit, Black beltͷεϥΠ υslideshareɺಈըyoutubeʹଟ্͘
͕͍ͬͯ·͢ɻ • ࠔͬͨΒެ͕ࣜҰ൪!
ྑ͍ Container lifeΛ!