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
運用事件簿
Search
cm-komuro
February 11, 2017
Technology
0
2.4k
運用事件簿
合同勉強会 in 福岡で発表したスライドです
cm-komuro
February 11, 2017
Tweet
Share
More Decks by cm-komuro
See All by cm-komuro
How To 脆弱性対応
cmkomuro
0
620
内容は話せないけどGamedayのススメ
cmkomuro
0
460
ゲンバのサービス運用
cmkomuro
2
1.3k
Introduction of Jooby. DevIO2016
cmkomuro
0
1.2k
Other Decks in Technology
See All in Technology
web-application-security
matsuihidetoshi
1
210
[2024/04/23]tbls活用事例 〜 ビューポイントから データベースを整理してみた話 〜
tosite
0
110
チームでロジカルシンキングに改めて向き合っている話 〜学習環境と実践⽅法〜
sansantech
PRO
3
3.3k
家族アルバム みてねにおけるGrafana活用術 / Grafana Meetup Japan Vol.1 LT
isaoshimizu
1
1.1k
Max out Local LLM in Challenging Environments
sashimimochi
2
200
Cracking the KubeCon CfP
inductor
2
270
How to do well in consulting–Balkan Ruby 2024
irinanazarova
0
170
競技としてのKaggle、役に立つKaggle
yu4u
7
2.5k
社内アプリで Cloudflare D1を プロダクト運用してみた体験談(Tokyo)
haochenx
0
130
今年のRubyKaigiはProfiler Year🤘
osyoyu
0
490
自己改善からチームを動かす! 「セルフエンジニアリングマネージャー」のすゝめ
shoota
6
1.1k
LangSmith入門―トレース/評価/プロンプト管理などを担うLLMアプリ開発プラットフォーム
os1ma
5
780
Featured
See All Featured
The Straight Up "How To Draw Better" Workshop
denniskardys
228
130k
GitHub's CSS Performance
jonrohan
1025
450k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
26
2.3k
Into the Great Unknown - MozCon
thekraken
15
1k
Side Projects
sachag
451
41k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
188
16k
Designing for Performance
lara
601
67k
WebSockets: Embracing the real-time Web
robhawkes
59
7k
Ruby is Unlike a Banana
tanoku
96
10k
Designing for humans not robots
tammielis
247
25k
Gamification - CAS2011
davidbonilla
77
4.6k
A better future with KSS
kneath
231
16k
Transcript
ӡ༻ࣄ݅ ߹ಉษڧձ IN Ԭ KOMURO, Hiraku @com4dc
ࣗݾհ SELF INTRODUCTION ▸ খࣨ ܒ ▸ ϞόΠϧόοΫΤϯυΤϯδχΞʢJava, AWS, ͪΐͬͱऄʣ
▸ ࡛ۄݝग़࡛ۄҭͪɺݱࡏւಓࡳຈࡏॅ ▸ ΫϥεϝιουגࣜձࣾϞόΠϧΞϓϦαʔϏε෦ ▸ ʢࣗশʣํ։ຽ ▸ ΫϥεϝιουSteam෦෦һʢFPSɺTPSʣ
ւಓհ ւಓ͔Βདྷ·ͨ͠ ▸ Ҡಈڑʹͯ͠2000km ▸ ݱࡏւಓʮݫౙظʯݱࡏɺઇ·ͭΓਅͬ࠷த ࣗͷ ຊؾݐ
None
None
None
͜Ε͕(ࠓͷ)ւಓͩʂ
ؓٳ
ӡ༻ͯ͠ΔϓϩδΣ Ϋτʹ͍ͭͯ
ϓϩδΣΫτʹ͍ͭͯ ϓϩδΣΫτ֓ཁ ▸ ઃܭɺ։ൃ͔ΒΠϯϑϥඋɺӡ༻αϙʔτ·ͰΛ୲ ▸ σʔλҠߦର͕300ສϢʔβʔ΄Ͳ ▸ ϐʔΫ࣌ͷΞΫηεೝূαʔόʔʹ͓͍ͯؒ5ɺ6ສΞΫ ηε ▸
ϞόΠϧΞϓϦͷDL100ສఔ ▸ ࣗͷ୲Oauthೝূج൫ͷΧελϜΫϥΠΞϯταʔόʔ
ϓϩδΣΫτʹ͍ͭͯ ϓϩδΣΫτମ੍ ▸ ։ൃϓϩδΣΫτ͕ಉ࣌ฒߦͰ3ͭ ▸ ͦΕͧΕ։ൃ։࢝ظ͕ؒҟͳΔ ▸ ϓϩύʔͱύʔτφʔ͕ʑ͘Β͍ͷׂ߹
։ൃ࣌ͷମ੍
ϓϩδΣΫτʹ͍ͭͯ MICRO SERVICE܈Ͱߏ ϞόΠϧAPI ΧελϜೝূAPI OAUTH2 ೝূج൫ ϞόΠϧ
ϓϩδΣΫτʹ͍ͭͯ ϓϩδΣΫτͷ͓Αͦͷ࣌ؒ࣠ ϞόΠϧAPI։ൃ ೝূAPI։ൃ ཧCMS։ൃ 20161݄͘Β͍ 20168݄͘Β͍ ϞόΠϧAPIӡ༻
։ൃޙͷӡ༻ϑΣʔζ
ϓϩδΣΫτʹ͍ͭͯ ΄ͱΜͲશ͕ͯҟͳΔϓϩδΣΫτ܈ ϞόΠϧ ೝূ CMS AWS։ൃ༻ ൿີ伴 伴1 伴2 伴2
ϑϨʔϜ ϫʔΫ Play for Scala SpringBoot Ruby on Rails σϓϩΠํ๏ Golden AMI CodeDeploy CodeDeploy ݴޠ Scala Java8 Ruby
ϓϩδΣΫτʹ͍ͭͯ ϓϩδΣΫτΛߏ͢ΔେྔͷαʔϏε
ଟ͗͢ͳ͍ɾɾɾʁ
ϓϩδΣΫτʹ͍ͭͯ ։ൃ͔࣌Βͷେ෯ͳମ੍มߋ ▸ ScalaϓϩάϥϚʔ͕3໊ˠ0໊ ▸ JavaͱRubyΤϯδχΞ͕ࣣసീ͠ͳ͕ΒɺPlay ScalaΛอक ▸ AWSαʔϏεͷো͋ΔͨΊɺJavaɺRubyΤϯδχΞ͕͜ ΕΒͷରԠ݉
▸ ݁Ռ ▸ AWSɺJavaɺScalaɺʢPythonʣͱ͍͏εΩϧηοτ͕ര
None
ϓϩδΣΫτʹ͍ͭͯ ӡ༻ॳظͷঢ়گ ▸ ιʔείʔυBacklogͷWikiΛαϧϕʔδͯ͠෦ߏΛ ཧղ͢Δʑʢ͢Ͱʹ։ൃϝϯόʔ͕͍ͳ͍ͨΊʣ ▸ ҟͳΔDeployπʔϧڥΛɺͲͷΑ͏ʹΓସ͑Δ͔Λ ࡧʢखॱ͕େ෯ʹҟͳΔͨΊɺΦϖϨʔγϣϯϛε͕ൃੜ ͦ͠͏ʣ ▸
ো࣌ͷϩάௐࠪͷखॱΛൿͷखॱΛେࢸٸ໌จԽ͢Δ ʢ͜͜Ͱϩάͷൃ֮͢Δɻ͜Ε·ͨผͷʣ
ࣄ݅
ࣄ݅ ͦͦ͜͜ͷࣄ݅Ұཡ ▸ CASE1. ϞόΠϧΞϓϦϦϦʔεϛεʹΑΔεςʔδϯάڥࢮࣄނ ▸ CASE2. DynamoDB StreamsࢮʹΑΓDBಉظࣦഊࣄ݅ ▸
ʢ୭ؾ͔ͮͳ͔ͬͨͷͰ΄ͱΜͲີࣨࡴਓঢ়ଶɻূڌͳ͠ʣ ▸ CASE3. fluentd ͷϓϥάΠϯʹΑΔϩάফࣦࣄ݅ɻࠈͷαϧ ϕʔδ࡞ۀʢ·ͩͪΐͬͱ͚ͩଓ͍ͯΔΜ͡ΌΑʣ ▸ CASE4. EC2ΨνϟʹΑΔύϑΥʔϚϯεԼࣄނ ▸ ʢ௨ৗͷ1/10ҎԼɻ͞ΕͲϔϧενΣοΫมԽͳ͠ʣ
ࣄ݅ ࣄ݅ൈਮ ▸ CASE1. ϞόΠϧΞϓϦϦϦʔεϛεʹΑΔεςʔδϯάڥࢮࣄނ ▸ CASE2. DynamoDB StreamsࢮʹΑΓDBಉظࣦഊࣄ݅ ▸
ʢ୭ؾ͔ͮͳ͔ͬͨͷͰີࣨࡴਓʣ ▸ CASE3. fluentd ͷϓϥάΠϯʹΑΔϩάফࣦࣄ݅ɻࠈͷαϧ ϕʔδ࡞ۀʢ·ͩͪΐͬͱ͚ͩଓ͍ͯΔΜ͡ΌΑʣ ▸ CASE4. EC2ΨνϟʹΑΔύϑΥʔϚϯεԼࣄނ ▸ ʢ௨ৗͷ1/10ҎԼɻ͞ΕͲϔϧενΣοΫϔϧγʔʣ ॾࣄʹΑΓࠓճ͜ΕҰ
CASE.1
εςʔδϯάڥ͚ͨϞόΠ ϧΞϓϦΛετΞʹϦϦʔεͪ͠Ό ͍·ͨ͠
None
ࣄ݅̍ ঢ়گΛཧ ▸ ετΞਃΛ͔͚ͯެ։ͨ͠ΞϓϦέʔγϣϯͷAPIଓઌ ͕ɺεςʔδϯάڥΛ͍͍ͯͨͱ͍͏ใࠂ ▸ ͢ͰʹඦϢʔβʔ͕DLࡁΈ ▸ AndroidΞϓϦͷΈ ▸
͜ΕʹΑΓ։ൃεςʔδϯάαʔόʔ͕࣮࣭ࢮʢຊ൪ͷΞ ϓϦ͕ࢀর͍ͯ͠ΔՄೳੑ͕͋ΔͨΊʣ
None
ͭ·Γ
ຊདྷ͜͏͋Δ͖ڥ͕
͜͏ͳͬͨ
None
ࣄ݅̍ ଈ࣌ۓٸରԠ ▸ ޡͬͨΞϓϦέʔγϣϯ͔ΒͷΞΫ ηεΛःஅ ▸ ڧ੍ΞοϓσʔτઃఆΛಋೖ ʢ403ΤϥʔͰฦ٫ʣ ▸ Ϧιʔεʹؔͯ͠શͯຊ൪ڥͱ
ಉͷͷ͔ۭσʔλʹͯ͠ɺΤο δαʔόʔͷΩϟογϡΛશͯΫϦ Ξ
ࣄ݅̍ ۓٸରԠͷՌ ▸ ޡͬͨΞϓϦέʔγϣϯ͔ΒͷΞΫηεΛःஅ ▸ ݁Ռతʹ͜ͷରԠෆཁɻΞϓϦͰอ͍࣋ͯ͠ΔΞΫηετʔΫϯ IDɺϓϩμΫγϣϯڥ͚Ͱ͋Γɺεςʔδϯάڥͱಥ͖߹Θ ͤΔͱવଘࡏ͠ͳ͍ͨΊɺແޮͳΞΫηετʔΫϯͱͯ͠ॲཧ͞Ε Δ ▸
Ϧιʔεʹؔͯ͠શͯຊ൪ڥͱಉͷͷ͔ۭσʔλʹ ▸ ޡͬͨΞϓϦ͔Βݟͯ৽ใͳͲ։ൃใ͕ग़͍ͯͳ͍͜ͱ͕ ֬ೝͰ͖ͨɻ͜͜ͷϦιʔεϩάΠϯ͍ͯ͠ͳͯ͘ݟΕΔใͰ ͋ΔͨΊɺ͜ͷରԠඞਢͩͬͨ
ରԠࡦ1 εςʔδϯάαʔόʔ࠶ߏங
ରԠࡦ1 ڥͷશͯΛෳ͢Δ
શͯͷڥΛෳ͢Δ ϝϦοτ ▸ طଘͷεςʔδϯάڥΛอશͰ͖Δ ▸ Πϯϑϥڥ΄ͱΜͲCloudFormationͷςϯϓϨʔτͰ ߏங͞Ε͍ͯΔͨΊɺ৽ͨͳڥߏஙଈ࠲ʹՄೳ
શͯͷڥΛෳ͢Δ σϝϦοτ ▸ ڥͷશͯΛෳ͢ΔͨΊAWSͷར༻අ͕୯७ʹ2ഒͱͳΔ ▸ DeployεΫϦϓτπʔϧͳͲमਖ਼ͷӨڹ͕ग़ͯ͠·͏
ରԠࡦ2 εςʔδϯάαʔόʔ࠶ߏங
ରԠࡦ2 ୀආαʔόʔΛߏங͢Δ
ୀආαʔόʔΛߏங ϝϦοτ ▸ શͯͷϦιʔεΛෳ͢Δͷʹରͯ͠ѹతʹඅ༻ΛѹॖͰ ͖Δ ▸ DeployπʔϧͳͲͷӨڹ͕࠷খݶͱͳΓɺӨڹൣғΛۃ ΊͯݶఆͰ͖Δ
ୀආαʔόʔΛߏங σϝϦοτ ▸ ୀආαʔόʔͷߏங͕ൃੜ͢Δ ▸ Route53ͷมߋͳͲൺֱతखॱ͕ෳࡶʹͳΔ ▸ CloudFrontͷมߋͱ৽ن࡞͕ೖΔͨΊ͕͔͔࣌ؒΔ ʢฒྻԽͰ͖ͳ͍ʣ ▸
nginxͷConfigurationΛAnsibleͰߏ͢ΔͨΊͷௐ͕ࠪඞ ཁʹͳΔ
ରԠࡦ3 εςʔδϯάαʔόʔ࠶ߏங
ରԠࡦ3 ୀආαʔόʔΛߏங͢Δʢվળʣ
ୀආαʔόʔΛߏஙʢMODIFIEDʣ ϝϦοτ ▸ શͯͷϦιʔεΛෳ͢Δͷʹରͯ͠ѹతʹඅ༻ΛѹॖͰ ͖Δ ▸ DeployπʔϧͳͲͷӨڹ͕࠷খݶͱͳΓɺӨڹൣғΛۃ ΊͯݶఆͰ͖Δ ▸ ʢNewʂʣCloudFrontͷઃఆมߋͷӨڹ͕ޡͬͯϦϦʔε
͞ΕͨΞϓϦͷϢʔβʔٴ͠ͳ͍ʂ
ୀආαʔόʔΛߏஙʢMODIFIEDʣ σϝϦοτ ▸ ୀආαʔόʔͷߏங͕ൃੜ͢Δ ▸ Route53ͷมߋͳͲൺֱతखॱ͕ෳࡶʹͳΔ ▸ ʢDeletedʂʣCloudFrontͷ৽ن࡞͞ΕΔͨΊɺ͕͔࣌ؒ ͔ͬͯ͠·͏ ▸
nginxͷConfigurationΛAnsibleͰߏ͢ΔͨΊͷௐ͕ࠪඞ ཁʹͳΔ
࠷ऴతͳखॱ εςʔδϯάαʔόʔ࠶ߏங
࠷ऴతͳ࠶ߏஙखॱ ରԠࡦ3Λ࠾༻ ▸ ੩తϨεϙϯεΛฦ٫͢ΔnginxΛखಈͰߏஙʢEC2x2ʣ ▸ ୀආ༻ͷ੩తϦιʔεΛஔ͢ΔS3όέοτΛ CloudFormationͰ෦ߏங ▸ طଘͷCloudFrontͷCNAMEsʹ৽͍͠εςʔδϯάڥͷ υϝΠϯʢstg2.hogeʣΛઃఆ
▸ Route53ͷ໊લղܾͷઃఆΛมߋ
࠷ऴతͳ࠶ߏஙखॱ ࠷ऴҊ
·ͱΊ
·ͱΊ ࣄ݅ࢥ͍ΑΒͳ͍ͱ͜Ζ͔Β༙͍ͯ͘Δ ▸ ΞϓϦέʔγϣϯΤϯδχΞͱݴ͑ɺߏΛཧղ͍ͯ͠ͳ ͍ͱӨڹൣғΛίϯτϩʔϧ͢ΔରԠ͕Ͱ͖ͳ͍ ▸ ӡ༻ʹܞΘͬͨ࣌Ͱɺࣗͷൣғ֎ͷΦʔόʔϥο ϓͯ͠αϙʔτɾֶश͍͕ͯ࢟͘͠ඞཁ ▸ ͨͩɺτϥϒϧ͕ى͖ΔͱΈ͕ͦϑϧճసͯͪ͠ΐͬͱς
ϯγϣϯ্͕͕Δͷࣄ࣮Ͱ͋ΔΘ͚Ͱʢ͋·Γྑ͘ͳ͍ ▸ ӡ༻৻ॏʹʂ࣌ʹେʹʂ
FIN. ଞͷࣄ݅ͷ ৄࡉ࠙ձͰ