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
DevOps導入指南 ~基本編~
Search
Recruit Technologies
August 21, 2020
Technology
5
42k
DevOps導入指南 ~基本編~
2020年度リクルート新人ブートキャンプ エンジニアコースの講義資料です
Recruit Technologies
August 21, 2020
Tweet
Share
More Decks by Recruit Technologies
See All by Recruit Technologies
障害はチャンスだ! 障害を前向きに捉える
rtechkouhou
1
640
Flutter移行の苦労と、乗り越えた先に得られたもの
rtechkouhou
3
11k
ここ数年間のタウンワークiOSアプリのエンジニアのチャレンジ
rtechkouhou
1
1.5k
大規模環境をAWS Transit Gatewayで設計/移行する前に考える3つのポイントと移行への挑戦
rtechkouhou
1
1.9k
【61期 新人BootCamp】TOC入門
rtechkouhou
3
41k
【RTC新人研修 】 TPS
rtechkouhou
1
41k
Android Boot Camp 2020
rtechkouhou
0
41k
HTML/CSS
rtechkouhou
10
50k
TypeScript Bootcamp 2020
rtechkouhou
9
45k
Other Decks in Technology
See All in Technology
マルチプロダクトな開発組織で 「開発生産性」に向き合うために試みたこと / Improving Multi-Product Dev Productivity
sugamasao
1
300
IBC 2024 動画技術関連レポート / IBC 2024 Report
cyberagentdevelopers
PRO
0
110
EventHub Startup CTO of the year 2024 ピッチ資料
eventhub
0
110
Lambda10周年!Lambdaは何をもたらしたか
smt7174
2
110
rootlessコンテナのすゝめ - 研究室サーバーでもできる安全なコンテナ管理
kitsuya0828
3
380
複雑なState管理からの脱却
sansantech
PRO
1
140
【令和最新版】AWS Direct Connectと愉快なGWたちのおさらい
minorun365
PRO
5
750
Oracle Cloud Infrastructureデータベース・クラウド:各バージョンのサポート期間
oracle4engineer
PRO
28
12k
TypeScriptの次なる大進化なるか!? 条件型を返り値とする関数の型推論
uhyo
2
1.6k
スクラムチームを立ち上げる〜チーム開発で得られたもの・得られなかったもの〜
ohnoeight
2
350
Terraform Stacks入門 #HashiTalks
msato
0
350
Why App Signing Matters for Your Android Apps - Android Bangkok Conference 2024
akexorcist
0
130
Featured
See All Featured
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
47
2.1k
Happy Clients
brianwarren
98
6.7k
The Cult of Friendly URLs
andyhume
78
6k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
665
120k
Facilitating Awesome Meetings
lara
50
6.1k
Large-scale JavaScript Application Architecture
addyosmani
510
110k
Optimising Largest Contentful Paint
csswizardry
33
2.9k
The Invisible Side of Design
smashingmag
298
50k
Writing Fast Ruby
sferik
627
61k
Building Your Own Lightsaber
phodgson
103
6.1k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
48k
What's new in Ruby 2.0
geeforr
343
31k
Transcript
© 2020, Recruit Technologies Co., Ltd. All rights reserved. ΫϥυΞʔΩςΫτ(
౻ݪ ྋഅ %FW0QTಋೖࢦೆ ʙجຊฤʙ ൛
ߨࢣհ ౻ݪ ྋഅ גࣜձࣾϦΫϧʔτ ŲƅƁŦƄŞŪ౷ׅຊ෦ŲƅƁŦƄŞŪ։ൃ౷ׅࣨ ŚƃŢƄŬŗžƃŞƄࣨŲƅƁŦƄŞũŎűƄũŎŚƃŢƄŬŗžƃŞƄ෦ ŞŽřŪƄŗŖŝũŞŪŞƄſŖŲƅ ܦྺ ʙ Ϣʔβܥ4JFSʹͯ3%
ʙ ϦΫϧʔτςΫϊϩδʔζʹೖࣾ ओͳ׆ಈ ࣾ֎ؚΉ • ίϯςφɾύϒϦοΫΫϥυܥςΫϊϩδʔͷࣄۀண • ίϛϡχςΟɾΧϯϑΝϨϯεӡӦ 3BODIFS+1ίΞϝϯόʔɾ$MPVE/BUJWF%BZT5PLZPηογϣϯεϐʔΧʔ ӡӦελοϑ • ॻ੶ࣥචɾ࿈ࡌɾొஃͳͲ • 3BODIFSʹΑΔ,VCFSOFUFT׆༻શΨΠυ ΠϯϓϨε • !*5ઌߦࣄྫʹֶͿ,VCFSOFUFTاۀ׆༻ͷݱ࣮ɾίϯςφϕʔεͷ$*$%ຊ൪ࣄྫେղ • 5IJOL*5 ϚϧνΫϥυ࣌ͷ࠷ڧίϯϏ 3BODIFSʹΑΔ,VCFSOFUFT׆༻ΨΠυ •
͏গ͠ߨࢣͷུྺ 4 2011/3 BDfB]^d7C\GRV 2011/4 )1ZSIerRV= 0 / +ZR&D
1$/(1/eb_<`8/F9IH 0O2L6IH 2016/1 ,-1.19S 0:JM[@Q(Qass) 0;T1NX/NXIH Raico, Fleet, '@Q,,HRTech(ATS, EMS, KOT), *! "Lite, Simpos 0MANTONX & /53 53g KY?W baEU(@IT/ThinkIt) #/PA(CloudNativeDays ) %( c>(Rancher JP)
l %FW0QTͬͯԿʁ l %FW0QTͱ l %FW0QTͷཱ֬ʹཱͭςΫϊϩδʔ l %FW0QTͷཱ֬ʹඞཁͳจԽతಛੑ l %FW0QTಋೖࢦೆ
ʙٕज़ฤʙ ΞδΣϯμ
DevOps?
γεςϜͷ։ൃ৫ Ҏ߱%FW ͱ ӡ༻৫ Ҏ߱0QT Ͱରཱ͋͠͏ͷͰͳ͘ɺ ڠௐ ߹ʹΑͬͯ༥߹ ͠ͳ͕ΒϏδωεతΛ ୡ͢ΔͨΊͷߟ͑ํɺ৫తͳจԽ
%FW0QTͬͯԿʁ Dev Ops Dev Ops DevOps DevOps
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ &
" $!% # DevOpsLean
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ &
" $!% # DevOpsLean
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ &
" $!% # DevOpsLean
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT
%FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ & " $!% # DevOpsLean
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ ҎԼͷ؍Ͱ ༗ҙͳ͕ࠩ͋ͬͨ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ ҎԼͷ؍Ͱ ༗ҙͳ͕ࠩ͋ͬͨ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ
%FW0QTΛ࣮ફͰ͖ͨ߹ɺҎԼ͕࣮ݱͰ͖Δ %FW0QTΛ࣮ફͨ͠߹ͷҰൠతͳޮՌ
%FW0QTΛ࣮ફͰ͖ͨ߹ɺҎԼ͕࣮ݱͰ͖Δ %FW0QTΛ࣮ફͨ͠߹ͷҰൠతͳޮՌ " !
DevOps
ຊ֨తʹޠΒΕΔ͜ͱ͕૿͑ͨͷࣸਅڞ༗αʔϏεͷGMJDLS͕ ͷ03FJMMZ7FMPDJUZΧϯϑΝϨϯεͰߦͳͬͯൃදҎ߱ %FW0QTͷྺ࢙ ݪ https://www.slideshare.net/jallspaw/10-deploys-per-day- dev-and-ops-cooperation-at-flickr
ຊ֨తʹޠΒΕΔ͜ͱ͕૿͑ͨͷࣸਅڞ༗αʔϏεͷGMJDLS͕ ͷ03FJMMZ7FMPDJUZΧϯϑΝϨϯεͰߦͳͬͯൃදҎ߱ %FW0QTͷྺ࢙ ݪ https://www.slideshare.net/jallspaw/10-deploys-per-day- dev-and-ops-cooperation-at-flickr
Ops ! Dev Dev
Ops %FWͱ0QTͷରཱ Dev Ops
҉తʹΓࠐ·Ε֤ͨϩʔϧͷͷҧ͍ʹىҼ ͳͥରཱ͕ى͜Δͷ͔ Dev/! )+.0 " #* Ops/!
%&-', "1$2 #*3( 2
҉తʹΓࠐ·Ε֤ͨϩʔϧͷͷҧ͍ʹىҼ ͳͥରཱ͕ى͜Δͷ͔ DevK3 ?BIL2 & %!5-. 6@2 OpsK3 !#(9:H/;D
& %!5-M8N 6@O< N A GE4 !"',+)*$JC & & %!=10F>7
େతΛୡ͢Δ֬ΛߴΊΔʹ %FWͱ0QTͷରཱΛղফ͢Δඞཁ͕͋Δ ରཱΛղফ͢ΔͨΊʹ ① ②
େతΛୡ͢Δ֬ΛߴΊΔʹ %FWͱ0QTͷରཱΛղফ͢Δඞཁ͕͋Δ ରཱΛղফ͢ΔͨΊʹ ① ②
ຊདྷࢦ͍ͨ͠ͷ৫ͱͯ͠ͷจԽͷཱ֬ ςΫϊϩδʔͦͷ࣮ݱΛࢧԉ͢ΔͨΊͷΈ %FW0QTʹ͓͚ΔςΫϊϩδʔͷཱͪҐஔ
શ һ ᘳ ਓ શһ͕ਓͰ͋Δඞཁ͕͋Δ ςΫϊϩδʔ͕ͳ͍߹
ଟ छ ଟ ༷ શ һ ᘳ ਓ
શһ͕ਓͰ͋Δඞཁ͕͋Δ ͦΕɺ͋Γ͑ͳ͍ͷͰςΫϊϩδʔͷྗΛआΓΔ ςΫϊϩδʔ͕ͳ͍߹ ( )
ओʹ࣠ ςΫϊϩδʔͰओʹॿ͚Δࣄฑ
① ( ) ओʹ࣠ ςΫϊϩδʔͰओʹॿ͚Δࣄฑ
② (("- %) ① #) ., ($!
0*/ &'1+) ओʹ࣠ ςΫϊϩδʔͰओʹॿ͚Δࣄฑ
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
ίʔυ͔ΒΠϯϑϥؚΊͨڥߏஙΛࣗಈతʹ࣮ࢪͰ͖Δ Α͏ʹ͢Δ͜ͱ ࣗಈԽ͞ΕͨΠϯϑϥ
͢ͰʹϨΠϠʔ͝ͱʹ༷ʑͳςΫϊϩδʔ͕ଘࡏ͢Δ
࣮֬ʹޡΓͳ͘୯७࡞ۀΛਓؒ͜ͳ͢͜ͱ͕Ͱ͖Δ͔ʁ ͳͥࣗಈԽ͞ΕͨΠϯϑϥ͕ඞཁ͔ʁ
࣮֬ʹޡΓͳ͘୯७࡞ۀΛਓؒ͜ͳ͢͜ͱ͕Ͱ͖Δ͔ʁ ͷԾϚγϯΛखಈͰߏஙɾςετ͢Δɻ ਓ࣮ؒ֬ʹޡΓͳ࣮͘ߦͰ͖Δ͔ʁ ͳͥࣗಈԽ͞ΕͨΠϯϑϥ͕ඞཁ͔ʁ
࣮֬ʹޡΓͳ͘୯७࡞ۀΛਓؒ͜ͳ͢͜ͱ͕Ͱ͖Δ͔ʁ ͷԾϚγϯΛखಈͰߏஙɾςετ͢Δɻ ਓ࣮ؒ֬ʹޡΓͳ࣮͘ߦͰ͖Δ͔ʁ ͳͥࣗಈԽ͞ΕͨΠϯϑϥ͕ඞཁ͔ʁ
ਓؒ୯७࡞ۀΛޡΓͳ࣮֬͘ʹ࣮ߦ͢Δʹෆ҆ఆ͗͢Δ ͳͥࣗಈԽ͞ΕͨΠϯϑϥ͕ඞཁ͔
!
ਓؒ୯७࡞ۀΛޡΓͳ࣮֬͘ʹ࣮ߦ͢Δʹෆ҆ఆ͗͢Δ ͳͥࣗಈԽ͞ΕͨΠϯϑϥ͕ඞཁ͔ -1# ! &8( 352 4 .% $*
+/ 9 ), + '7" 60+ 7
୯७ͳ܁Γฦ͠࡞ۀ͕ಘҙ େྔ୯७࡞ۀʹ͓͚Δܭࢉػ
୯७ͳ܁Γฦ͠࡞ۀ͕ಘҙ େྔ୯७࡞ۀʹ͓͚Δܭࢉػ
୯७ͳ܁Γฦ͠࡞ۀ͕ಘҙ େྔ୯७࡞ۀʹ͓͚Δܭࢉػ $ # "
or " !%
େྔͷ୯७࡞ۀ ܭࢉػʹͤͨํ͕దࡐదॴ ͦͷͨΊͷπʔϧग़ଗ͍ͭͭ͋Δ େྔ୯७࡞ۀܭࢉػʹͤΔ
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
ίʔυΛίʔυϦϙδτϦͰཧ͢Δ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ
ίʔυΛίʔυϦϙδτϦͰཧ͢Δ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ
ίʔυΛίʔυϦϙδτϦͰཧ͢Δ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ =
l %PDLFSGJMF l ,VCFSOFUFTͷϚχϑΣετ l "OTJCMFͷQMBZCPPL l 5FSSBGPSNͷUGϑΝΠϧɾUGWBSTϑΝΠϧ l $*$%ͷύΠϓϥΠϯఆٛϑΝΠϧ
ͳͲ Πϯϑϥίʔυ
ڥ͝ͱʹσϓϩΠ͞Ε͍ͯΔ ΞϓϦέʔγϣϯ֤छߏΛѲ͢ΔͨΊ ͳͥڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ͕ඞཁ͔
શһ͕͍࣋ͬͯΔίʔυόϥόϥ ݹ͔ͬͨΓ৽͔ͬͨ͠Γ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ͕ͳ͍ঢ়گΛߟ͑Δ ࣟ ࣠ ࣡
ࣣ ࣕ ࣖ ࣗ ࣘ ŋŏ
શһ͕͍࣋ͬͯΔίʔυόϥόϥ ݹ͔ͬͨΓ৽͔ͬͨ͠Γ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ͕ͳ͍ঢ়گΛߟ͑Δ ࣟ ࣠ ࣡
ࣣ ࣕ ࣖ ࣗ ࣘ ŋŏ
શһ͕͍࣋ͬͯΔίʔυόϥόϥ ݹ͔ͬͨΓ৽͔ͬͨ͠Γ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ͕ͳ͍ঢ়گΛߟ͑Δ ࣟ ࣠ ࣡
ࣣ ࣕ ࣖ ࣗ ࣘ ŋŏ ʊਓਓਓਓਓਓਓਓʊ ʼ ଋ͞Εͨࢮ ʻ ʉY^Y^Y^Y^Y^Y^Y ʉ
Ͳͷίʔυ͕࠷৽ͳͷ͔ຊ൪ڥͰಈ͍͍ͯΔͷ͔ΛѲͰ͖Δ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ͕͋Ε มߋ༰ Λू σϓϩΠ
ڞ༗͞Ε͍ͯͳ͍όʔδϣϯίϯτϩʔϧ దͳίϛϡχέʔγϣϯɺোରԠΛ્͢Δ Ξϯνύλʔϯ ڞ༗͞Εͳ͍όʔδϣϯίϯτϩʔϧ Ops Dev
) (
γεςϜΛߏ͢Δίʔυ શͯޓ͍ʹݟ͑Δॴʹஔ͠ɺڞ༗͢Δ Ξϯνύλʔϯ ڞ༗͞Εͳ͍όʔδϣϯίϯτϩʔϧ Ops Dev
γεςϜΛߏ͢Δίʔυ શͯޓ͍ʹݟ͑Δॴʹஔ͠ɺڞ༗͢Δ Ξϯνύλʔϯ ڞ༗͞Εͳ͍όʔδϣϯίϯτϩʔϧ Ops Dev
(Single source of truth )
ڥʹͲͷ࣌ͷίʔυ͕σϓϩΠ͞Ε͍ͯΔ͔ɺ ͦͷίʔυΛϝϯόʔશһ͕ಉ͡Α͏ʹӾཡͰ͖Δ͜ͱ͕ ίϛϡχέʔγϣϯΛԁʹ͢Δͱͱʹɺ ൃੜ࣌ͷղܾ·Ͱͷ࣌ؒ .553 Λॖ͢Δ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ·ͱΊ
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
ϏϧυͱσϓϩΠʹ͍ͭͯπʔϧΛ׆༻ͯ͠ ՄೳͳݶΓγϯϓϧͳϓϩηε Ͱࣗಈ࣮ߦͰ͖ΔΑ͏ʹ͢Δ͜ͱ ϫϯεςοϓϏϧυͱσϓϩΠ
ϫϯεςοϓϏϧυͱσϓϩΠͰ࣮ݱ͍ͨ͜͠ͱ ② (")! 0 $.'- ③ %
# *+ ① /' ,&
ϫϯεςοϓϏϧυͱσϓϩΠͷ༗ແʹΑΔࠩҟΛߟ͑Δ ϫϯεςοϓϏϧυͱσϓϩΠͷ༗ແ #$! "+* '/-4 ("$&$ ) !%" $
-('/ !" +* ("$&$ ) !%" '/-4.)2 0,1'/3
ϫϯεςοϓϏϧυͱσϓϩΠͷ༗ແʹΑΔࠩҟΛߟ͑Δ ϫϯεςοϓϏϧυͱσϓϩΠͷ༗ແ -.&%+" &,97 2@<H ( &, .(0#.!) %+"/ &,
'.* <42@ %+" &,97 ( &, .(0#.!) %+"/ &, 2@<H?6C A;B2@G >)F J 137$0.= :8IDE5 J
࡞ۀͷखॱΛύΠϓϥΠϯԽ͢Δ͜ͱͰɺ ࡞ۀͷ࠶ݱੑΛߴΊΔ ᶃ ϏϧυɾσϓϩΠϓϩηεΛ࣮֬ʹվળͰ͖ΔΑ͏ʹ͢Δ Dev Ops
$ " ( ' ) & $ % " ! Ops Dev " #
࡞ۀͷखॱΛύΠϓϥΠϯԽ͢Δ͜ͱͰɺ ࡞ۀͷ࠶ݱੑΛߴΊΔ ᶃ ϏϧυɾσϓϩΠϓϩηεΛ࣮֬ʹվળͰ͖ΔΑ͏ʹ͢Δ Dev Ops
$ " ( ' ) & $ % " ! Ops Dev " # %#,! "(' ) $ -* %& $ +.
ϫϯεςοϓϏϧυͱσϓϩΠ͕ͳ͍߹Λߟ͑Δ ᶄ ଐਓੑΛԼ͛Δ A A ? B
ϫϯεςοϓϏϧυͱσϓϩΠ͕ͳ͍߹Λߟ͑Δ ᶄ ଐਓੑΛԼ͛Δ ) A (
ϫϯεςοϓϏϧυͱσϓϩΠ͕ͳ͍߹Λߟ͑Δ ᶄ ଐਓੑΛԼ͛Δ ) A (
ϫϯεςοϓϏϧυͱσϓϩΠ͕͋Δ߹Λߟ͑Δ ᶄ ଐਓੑΛԼ͛Δ A ) ) ( ) B
୭͕͍ͭԿΛͲΜͳతͰ σϓϩΠͨ͠ͷ͔ѲͰ͖ΔΑ͏ʹ͢Δ ೝূɾೝՄͷΈΛύΠϓϥΠϯʹΈࠐΉ ᶅ ΨόφϯεΛޮ͔ͤΒΕΔΑ͏ʹ͢Δ
ܰ͘ৼΓฦΓ ڞ༗͞Εͨόʔδϣϯίϯτϩʔϧ ϫϯεςοϓϏϧυͱσϓϩΠ มߋ༰ Λू Ϗϧυ σϓϩΠ
ϫϯεςοϓϏϧυͱσϓϩΠͰ࣮ݱ͍ͨ͜͠ͱ ࠶ܝ ② (")! 0 $.'- ③
% # *+ ① /' ,&
҆શ͔࣮ͭ֬ʹΞϓϦέʔγϣϯڥΛϏϧυ͠ɺ σϓϩΠ͢Δɺ·ࣦͨഊ͔ΒͷվળΛ༰қ͔ͭண࣮ʹ࣮ ࢪ͢Δ্ͰϫϯεςοϓϏϧυͱσϓϩΠॏཁ ϫϯεςοϓϏϧυͱσϓϩΠͷ·ͱΊ
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
ಛఆͷػೳͷ༗ޮɾແޮΛΓସ͑ͨΓ Ұ෦ͷਓͷΈʹఏڙ͢ΔͨΊͷϑϥά ϑΟʔνϟʔϑϥάͱ
ᶃ Ұ෦ͷϢʔβ͚ʹػೳΛఏڙ͢Δ ᶄ ҆શʹػೳͷϦϦʔεΛߦ͏ ϑΟʔνϟʔϑϥάͷత
l ϓϥΠϕʔτϕʔλ l Ұ෦ͷࢦఆͨ͠ϢʔβʹͷΈػೳΛެ։͢Δ l "#ςετ l ൺΛఆΊͯػೳ৽͍͠6*Λެ։͠ɺڹΛௐΔ l μʔΫϩʔϯν
l ϢʔβͷϦΫΤετΛෳٖͯ͠ࣅతʹॲཧΛߦ͏ ϑΟʔνϟʔϑϥάͷओͳख๏
l ϓϥΠϕʔτϕʔλ l Ұ෦ͷࢦఆͨ͠ϢʔβʹͷΈػೳΛެ։͢Δ l "#ςετ l ൺΛఆΊͯػೳ৽͍͠6*Λެ։͠ɺڹΛௐΔ l μʔΫϩʔϯν
l ϢʔβͷϦΫΤετΛෳٖͯ͠ࣅతʹॲཧΛߦ͏ ϑΟʔνϟʔϑϥάͷओͳख๏
<ิղઆ>μʔΫϩʔϯν
!
<ิղઆ>μʔΫϩʔϯν ! ! "
" # !
<ิղઆ>μʔΫϩʔϯν
" !
<ิղઆ>μʔΫϩʔϯν
! !
<ิղઆ>μʔΫϩʔϯν $ ,) # - . .
/ / 0 * " '%(! ,) &+
Ծઆݕূࢼߦࡨޡ 㲈খ͘͞ࢼͯ͠খࣦ͘͞ഊ ͕͘͠ͳΔ ϑΟʔνϟʔϑϥά͕ͳ͍߹
Ծઆݕূࢼߦࡨޡ 㲈খ͘͞ࢼͯ͠খࣦ͘͞ഊ ͕͘͠ͳΔ ϑΟʔνϟʔϑϥά͕ͳ͍߹ (-+)& %
* , $ ! # "' "'
Ծઆݕূࢼߦࡨޡ 㲈খ͘͞ࢼͯ͠খࣦ͘͞ഊ ͕༰қʹͳΔ ϑΟʔνϟʔϑϥά͕͋Δ߹ "
! # $
Ծઆݕূࢼߦࡨޡ 㲈খ͘͞ࢼͯ͠খࣦ͘͞ഊ ͕༰қʹͳΔ ϑΟʔνϟʔϑϥά͕͋Δ߹ "
! # $
Ծઆݕূɾࢼߦࡨޡͱ҆શʹ࣮ࢪ͢Δ্Ͱ ϑΟʔνϟʔϑϥάಛʹॏཁ ϑΟʔνϟʔϑϥά
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
%FWͱ0QTͰҧ͏ࢦඪΛݟ͍ͯΔ Α͋͘Δ !
%FWͱ0QTͰҧ͏ࢦඪΛݟ͍ͯΔ Α͋͘Δ ! %!$ #"
%FWͱ0QTͰҧ͏ࢦඪΛݟ͍ͯΔ Α͋͘Δ ! &5,1.+4 32 % )'* $0 -
#!" 4(/
ϊϋՄೳͳݶΓू͠ɺ ಉ͡ใݯΛ͔ͭͬͯٞΛ͢Δ ಉҰͷใΛݟͳ͕Βٞ͢Δ Ops Dev ू or ฒଘ ཁٞ
ϊϋՄೳͳݶΓू͠ɺ ಉ͡ใݯΛ͔ͭͬͯٞΛ͢Δ ಉҰͷใΛݟͳ͕Βٞ͢Δ Ops Dev ू or ฒଘ ཁٞ
ϛείϛϡχέʔγϣϯΛݮΒͨ͢Ίʹ ϩʔϧ͕ҟͳΔ߹Ͱಉ͡ใΛ ݟΕΔঢ়ଶͰ͖ٞ͢ ૬ख͕Γಘͳ͍ใΛجʹٞΛ ల։͢Δ͜ͱίϛϡχέʔγϣϯతʹ/( ڞ༗͞ΕͨϝτϦΫε·ͱΊ
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
$*ɺΞϥʔτ͚ͩͰͳ͘ɺϏδωε্ͷ࣮ͳͲΛ νϟοτϘοτΛͬͯνϟοτج൫ʹྲྀ͠·͠ΐ͏ νϟοτͷͨΊͷج൫ͱνϟοτϘοτΛੵۃతʹ׆༻͢Δ CI
ใΛϓογϡܕͰఏࣔͯ͠ɺ ͓͖ͬͯ͘ใΛੵۃతʹΠϯϓοτ͢ΔͨΊͷΈΛඋ͑Δ ʹϝϯόʔͷ͍ͬͯΔใΛಉظͤ͞Δʣ νϟοτͷͨΊͷج൫ͱνϟοτϘοτΛੵۃతʹ׆༻͢Δ
ใΛϓογϡܕͰఏࣔͯ͠ɺ ͓͖ͬͯ͘ใΛੵۃతʹΠϯϓοτ͢ΔͨΊͷΈΛඋ͑Δ ʹϝϯόʔͷ͍ͬͯΔใΛಉظͤ͞Δʣ νϟοτͷͨΊͷج൫ͱνϟοτϘοτΛੵۃతʹ׆༻͢Δ ?
l ϝʔϧϓϧܕͷใऔಘ l ͔ࣗΒݟʹߦ͘ඞཁ͕͋Δ l શһ͕͓͖ͬͯ͘ใͷఏࣔʹ ͋·Γ ͍͍ͯͳ͍ ϝʔϧͰͩΊͰͳ͍͕ɺগ͠Ή͔͍ͣ͠ ඇಉظ
ίϛϡχέʔγϣϯ (ׂࠐ߹͍/ઐ༗߹͍͕͍) ಉظ ίϛϡχέʔγϣϯ (ׂࠐ߹͍/ઐ༗߹͍͕ߴ͍) E Slack Teams PagerDuty
l ใͷྲྀ௨ܗଶΛ͓͖ͯͬͯ͘͠ใΛͬͯ ͓͖͘ਓ͕ೝࣝͰ͖ΔΑ͏ʹ͢Δ l ࠓճͷࣄྫͷ߹ϓογϡܕͷ΄͏͕͍͍ͯΔ νϟοτͱνϟοτϘοτ·ͱΊ
จԽΛࢧ͑ΔͨΊͷςΫϊϩδʔ·ͱΊ M=>5(0 <G &7/55#372 45! )'2$ ")3 (7-7(0 <G,#1 -
# - #* # @FLJ8 (A; :OHN 6C9DPI) +.%7/5#8 (E?K9 B)
จԽΛࢧ͑ΔͨΊͷςΫϊϩδʔ·ͱΊ M=>5(0 <G &7/55#372 45! )'2$ ")3 (7-7(0 <G,#1 -
# - #* # @FLJ8 (A; :OHN 6C9DPI) +.%7/5#8 (E?K9 B)
େతΛୡ͢Δ֬ΛߴΊΔʹ %FWͱ0QTͷରཱΛղফ͢Δඞཁ͕͋Δ ରཱΛղফ͢ΔͨΊʹ ① ②
ڞ௨ͷత Ϗδωεͷޭͱརӹͷ֦େ Λ࣮ݱʹ͚ͯྗ͢Δʹɺ ݁ہͷͱ͜Ζਓͱਓ͕ԁʹڠྗ͠ձ͑ΔҙࣝΛ࣋ͭඞཁ͕͋Δ %FW0QTͱ৫จԽ
ڞ௨ͷత Ϗδωεͷޭͱརӹͷ֦େ Λ࣮ݱʹ͚ͯྗ͢Δʹɺ ݁ہͷͱ͜Ζਓͱਓ͕ԁʹڠྗ͠ձ͑ΔҙࣝΛ࣋ͭඞཁ͕͋Δ %FW0QTͱ৫จԽ " !$ #
!$ &"$ %
৫͕εέʔϧͯ͠ಉ͡తʹ͔ͬͯ ڠྗ͋͑͠ΔΑ͏ʹ͢Δʹʁ
ݪయͰड़ΒΕ͍ͯΔͷҎԼͷ̐ͭ %FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
ݪయͰड़ΒΕ͍ͯΔͷҎԼͷ̐ͭ %FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
%FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
ઌೖ؍Λ࣋ͨͳ͍ ଞऀͷઐࣝɾҙݟɾΛଚॏ͢Δ ϊʔͱ͍͏͚ͩͷ͜ͱ͠ͳ͍ Ӆ͠ࣄ͠ͳ͍ ґཔ͢ΔલʹΔ͜ͱɾߟ͑Δ͜ͱΛͪΌΜͱΔ
૬ޓͷϦεϖΫτ
l ͋ͷਓ͍ͭYYYͳͷͰZZZ͠Α͏/( l ࣌ؒܦաʹ͍ਓͷதมΘΔ͠ঢ়گมΘΔ l ؆୯Ͱྑ͍ͷͰ͖ͪΜͱ֬ೝ͢Δ l ಉ͡ࣄฑͰঢ়گλΠϛϯάʹΑͬͯճมΘΔՄೳੑ͕ ͋ΔͷͰ؆୯ʹͰྑ͍ͷͰ֬ೝ͠·͠ΐ͏ ͦͷͨΊͷίϛϡχέʔγϣϯج൫ͱͯ͠4MBDL
+*3"$POGMVFODF͕උ͞Ε͍ͯΔ ઌೖ؍Λ࣋ͨͳ͍
l શͯʹ͓͍͕ͯࣗউ͍ͬͯΔͳΜͯ͜ͱͳ͍ l ઐྖҬ͕ҟͳΔ͠ɺ๊͍͑ͯΔϛογϣϯҟͳΔͷͰई ͕ͦͦҧ͏ l ଞਓҟͳΔࢹඞ͍ͣ࣋ͬͯΔͷͰҙݟଚॏ͢Δ ଞऀͷઐࣝɾҙݟɾΛଚॏ͢Δ
l શͯʹ͓͍͕ͯࣗউ͍ͬͯΔͳΜͯ͜ͱͳ͍ l ઐྖҬ͕ҟͳΔ͠ɺ๊͍͑ͯΔϛογϣϯҟͳΔͷͰई ͕ͦͦҧ͏ l ଞਓҟͳΔࢹඞ͍ͣ࣋ͬͯΔͷͰҙݟଚॏ͢Δ ଞऀͷઐࣝɾҙݟɾΛଚॏ͢Δ
Why
l શͯʹ͓͍͕ͯࣗউ͍ͬͯΔͳΜͯ͜ͱͳ͍ l ઐྖҬ͕ҟͳΔ͠ɺ๊͍͑ͯΔϛογϣϯҟͳΔͷͰई ͕ͦͦҧ͏ l ଞਓҟͳΔࢹඞ͍ͣ࣋ͬͯΔͷͰҙݟଚॏ͢Δ ଞऀͷઐࣝɾҙݟɾΛଚॏ͢Δ (!1)/.'%
Why& ,- #+*0 $" $
ޓ͍ͷґཔ༰ʹ͍ͭͯϊʔͱ͑Δͱ͖ͷྀࣄ߲ l ڋ൱͢Δࡍʹཧ༝Λࣔ͢ l ͲΜͳཧ༝Ͱ͋Εڋ൱ͷࠜڌΛࣔ͢ l Ͳ͏͢Εڐ༰Ͱ͖Δͷ͔Λࣔ͢ l Ͳ͏͢ΕґཔʹԠ͑Δ͜ͱ͕Ͱ͖Δͷ͔ج४Λࣔ͢ l
ґཔʹର͢Δ8IZΛ۷ΓԼ͛Δ͜ͱ l 8IZ͔Β۷ΓԼ͛Δ͜ͱͰผͷํ๏͕ఏҊͰ͖Δ͔͠Εͳ͍ ϊʔͱ͍͏͚ͩͷ͜ͱ͠ͳ͍
ޓ͍ͷґཔ༰ʹ͍ͭͯϊʔͱ͑Δͱ͖ͷྀࣄ߲ l ڋ൱͢Δࡍʹཧ༝Λࣔ͢ l ͲΜͳཧ༝Ͱ͋Εڋ൱ͷࠜڌΛࣔ͢ l Ͳ͏͢Εڐ༰Ͱ͖Δͷ͔Λࣔ͢ l Ͳ͏͢ΕґཔʹԠ͑Δ͜ͱ͕Ͱ͖Δͷ͔ج४Λࣔ͢ l
ґཔʹର͢Δ8IZΛ۷ΓԼ͛Δ͜ͱ l 8IZ͔Β۷ΓԼ͛Δ͜ͱͰผͷํ๏͕ఏҊͰ͖Δ͔͠Εͳ͍ ϊʔͱ͍͏͚ͩͷ͜ͱ͠ͳ͍
ۀ্ͷࠜڌͳ͘ใΛӅณ͠ͳ͍ l Ͳ͏ͤόϨΔɻόϨͨͱ͖ʹࣦΘΕΔ৴པΛߟ͑Δͱ ͡Ί͔Βެ։͓͍ͯͨ͠΄͏͕ྑ͍ l հͳ΄Ͳੵۃతʹ͑Δ͜ͱ l Ұॹʹղܾ͢ΔͨΊͷखஈΛߟ͑Δ Ӆ͠ࣄ͠ͳ͍
ۀ্ͷࠜڌͳ͘ใΛӅณ͠ͳ͍ l Ͳ͏ͤόϨΔɻόϨͨͱ͖ʹࣦΘΕΔ৴པΛߟ͑Δͱ ͡Ί͔Βެ։͓͍ͯͨ͠΄͏͕ྑ͍ l հͳ΄Ͳੵۃతʹ͑Δ͜ͱ l Ұॹʹղܾ͢ΔͨΊͷखஈΛߟ͑Δ Ӆ͠ࣄ͠ͳ͍
!$"#&14 +'0#/ (,*%. #/32 -)
l ݸผʹย͚ΒΕΔ͜ͱย্͚ͨͰґཔ͢Δ l ґཔ͢Δࡍʹ͓ͬͯ͘͜ͱɾཧ͢Δ͜ͱ ԿΛมߋ͢Δ͔ มߋ͢ΔࡍͷϦεΫ มߋͷޭɾࣦഊͷஅج४ͱ݁Ռͷ௨ํ๏
ࣦഊ࣌ͷରԠํ ґཔ͢ΔલʹΔ͜ͱɾߟ͑Δ͜ͱΛͪΌΜͱΔ
l ݸผʹย͚ΒΕΔ͜ͱย্͚ͨͰґཔ͢Δ l ґཔ͢Δࡍʹ͓ͬͯ͘͜ͱɾཧ͢Δ͜ͱ ԿΛมߋ͢Δ͔ มߋ͢ΔࡍͷϦεΫ มߋͷޭɾࣦഊͷஅج४ͱ݁Ռͷ௨ํ๏
ࣦഊ࣌ͷରԠํ ґཔ͢ΔલʹΔ͜ͱɾߟ͑Δ͜ͱΛͪΌΜͱΔ 1, 2 ( Welcome) 3, 4
%FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
৴པؔΛཱ֬Ͱ͖ͯͳ͍ঢ়ଶͰ݈શͳؔ࡞Εͳ͍ ૬ޓͷ৴པ
৴པؔΛཱ֬Ͱ͖ͯͳ͍ঢ়ଶͰ݈શͳؔ࡞Εͳ͍ ૬ޓͷ৴པ ) ) D ) (
0QT৽ػೳʹ͍ͭͯٞ͢Δࡍ%FWΛ৴པ͢Δ͜ͱ %FWΠϯϑϥߏͷมߋʹ͍ͭͯ0QTΛ৴པ͢Δ͜ͱ ޓ͍ʹಁ໌ੑΛҎͯۀΛਪਐ͢Δ͜ͱ ޓ͍ʹ࠷େݶͷΞΫηεݖݶΛ͠߹͏͜ͱ ૬ޓͷ৴པΛங্͘Ͱॏཁͳ͜ͱ ( ( D ) (
( O
%FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
l ࣦഊඞͣى͖Δzͷͩͱ͍͏ҙࣝΛ࣋ͭ͜ͱ l ࣦഊΛճආ͢Δ͜ͱΛߟ͑ଓ͚͍ͯΔݶΓɺࣦഊʹରԠ ͢Δೳྗ্͠ͳ͍ ࣦഊʹରͯ͠ͷ݈શͳଶ
l ࣦഊඞͣى͖Δzͷͩͱ͍͏ҙࣝΛ࣋ͭ͜ͱ l ࣦഊͷ֬ΛԼ͛ΔͨΊʹzܦࡁతɾతʹ߹ཧతͳൣғz ͰΈΛΈ্͛Δ͜ͱͪΖΜඞཁ l ࣦഊΛճආ͢Δ͜ͱΛߟ͑ଓ͚͍ͯΔݶΓɺࣦഊʹରԠ ͢Δೳྗ্͠ͳ͍ ࣦഊʹରͯ͠ͷ݈શͳଶ
l ࣦഊඞͣى͖Δzͷͩͱ͍͏ҙࣝΛ࣋ͭ͜ͱ l ࣦഊͷ֬ΛԼ͛ΔͨΊʹzܦࡁతɾతʹ߹ཧతͳൣғz ͰΈΛΈ্͛Δ͜ͱͪΖΜඞཁ l ࣦഊΛճආ͢Δ͜ͱΛߟ͑ଓ͚͍ͯΔݶΓɺࣦഊʹରԠ ͢Δೳྗ্͠ͳ͍ l ࣦഊ͕ى͖ͯӨڹ͕ى͖ͳ͍Έ
PS ਝʹ෮چͰ͖ΔΈΛ४උ͓ͯ͘͜͠ͱ ࣦഊʹରͯ͠ͷ݈શͳଶ
l ࣦഊඞͣى͖Δzͷͩͱ͍͏ҙࣝΛ࣋ͭ͜ͱ l ࣦഊͷ֬ΛԼ͛ΔͨΊʹzܦࡁతɾతʹ߹ཧతͳൣғz ͰΈΛΈ্͛Δ͜ͱͪΖΜඞཁ l ࣦഊΛճආ͢Δ͜ͱΛߟ͑ଓ͚͍ͯΔݶΓɺࣦഊʹରԠ ͢Δೳྗ্͠ͳ͍ l ࣦഊ͕ى͖ͯӨڹ͕ى͖ͳ͍Έ
PS ਝʹ෮چͰ͖ΔΈΛ४උ͓ͯ͘͜͠ͱ ࣦഊʹରͯ͠ͷ݈શͳଶ ( ( )
ݪయͰड़ΒΕ͍ͯΔͷҎԼͷ̐ͭ %FW0QTΛҡ͍࣋ͯͨ͘͠ΊʹඞཁͳจԽ
l ͕ൃੜͨ͠ͱ͖ʹݪҼΛಛఆͷਓͷࢿ࣭ʹٻΊͳ͍ l Կ͠ͳ͍͜ͱ͕࠷େͷՌʹͳͬͯ͠·͏ l ҤॖޮՌͰͦͷਓͷύϑΥʔϚϯεΛԼͤ͞Δ l ͕ࣦࣗഊͨ͠ͱ͖ʹͶฦͬͯ͘Δ ݸਓඇͷېࢭ
l ͕ൃੜͨ͠ͱ͖ʹݪҼΛಛఆͷਓͷࢿ࣭ʹٻΊͳ͍ l Կ͠ͳ͍͜ͱ͕࠷େͷՌʹͳͬͯ͠·͏ l ҤॖޮՌͰͦͷਓͷύϑΥʔϚϯεΛԼͤ͞Δ l ͕ࣦࣗഊͨ͠ͱ͖ʹͶฦͬͯ͘Δ ݸਓඇͷېࢭ "
৫ͷେత $4$-ߩݙϏδωεͷޭͱརӹͷ֦େ Λ࣮ݱ͢Δ ֬Λ্͛ΔͨΊʹҎԼͷ̐ͭΛ࣮ݱ͍ͨ͠ దͳ৫จԽͷཱ֬ͱҡ࣋·ͱΊ . .8 "( #
%$ 76/* 43 -,4& 01 )!52 +'
© 2020, Recruit Technologies Co., Ltd. All rights reserved. ΫϥυΞʔΩςΫτ(
౻ݪ ྋഅ %FW0QTಋೖࢦೆ ʙٕज़ฤʙ
େతΛୡ͢Δ֬ΛߴΊΔʹ %FWͱ0QTͷରཱΛղফ͢Δඞཁ͕͋Δ ରཱΛղফ͢ΔͨΊʹ ࠶ܝ ① ②
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
҉తʹΓࠐ·Ε֤ͨϩʔϧͷͷҧ͍ʹىҼ ͳͥରཱ͕ى͜Δͷ͔ DevK3 ?BIL2 & %!5-. 6@2 OpsK3 !#(9:H/;D
& %!5-M8N 6@O< N A GE4 !"',+)*$JC & & %!=10F>7
େ͖͚ͯͭ͘ͷςΫϊϩδʔ͕%FW0QTจԽͷཱ֬Λࢧ ԉ͢ΔͱݴΘΕ͍ͯΔɻ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
Ҏ߱ͰࠊΛਾ͔͑ͯͬ͠Γઆ໌ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
ൺֱతγϯϓϧͳͷͭ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ %"# !$
!$
ൺֱతγϯϓϧͳͷͭ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
ൺֱతγϯϓϧͳͷͭ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
ൺֱతγϯϓϧͳͷͭ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
ൺֱతγϯϓϧͳͷͭ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
͍ͣΕ҆શʹมߋΛߦ͏ͨΊͷΈ ·ͨ҆શʹࣦഊ͢ΔͨΊͷΈ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
͍ͣΕ҆શʹมߋΛߦ͏ͨΊͷΈ ·ͨ҆શʹࣦഊ͢ΔͨΊͷΈ %FW0QTจԽͷཱ֬Λࢧԉ͢ΔςΫϊϩδʔ
҆શʹมߋΛߦ͏ʹʁ ) ( = )
҆શʹมߋΛߦ͏ʹʁ ) ( = )
l ςετۦಈ։ൃ l ܧଓతΠϯςάϨʔγϣϯ l ܧଓతσϓϩΠɾσϦόϦʔ l ϩʔϦϯάσϓϩΠ l ϒϧʔάϦʔϯσϓϩΠ
l ΧφϦΞσϓϩΠ ଞʹ༷ʑͳख๏͋Γ ςετ༰қੑͱσϓϩΠ༰қੑΛߴΊΔͨΊͷखஈ
҆શʹมߋΛߦ͏ʹʁ ) ( = )
l ςετۦಈ։ൃ l ܧଓతΠϯςάϨʔγϣϯ $POUJOVPVT*OUFHSBUJPO$* ᶃ ҙਤͨ͠ͱ͓Γʹಈ࡞͢Δ͜ͱΛ֬ೝ͢Δखஈ
l ςετۦಈ։ൃ l ܧଓతΠϯςάϨʔγϣϯ $POUJOVPVT*OUFHSBUJPO$* ᶃ ҙਤͨ͠ͱ͓Γʹಈ࡞͢Δ͜ͱΛ֬ೝ͢Δखஈ
l ςετۦಈ։ൃ l ܧଓతΠϯςάϨʔγϣϯ $POUJOVPVT*OUFHSBUJPO$* ᶃ ҙਤͨ͠ͱ͓Γʹಈ࡞͢Δ͜ͱΛ֬ೝ͢Δखஈ @t_wada
ܧଓతΠϯςάϨʔγϣϯ
ίʔυϦϙδτϦίϛοτ͞Εͨίʔυʹରͯ͠ҎԼΛߦ͏͜ͱ ᶃ ࣗಈϏϧυ ᶄ ࣗಈςετ ܧଓతΠϯςάϨʔγϣϯ -/ / - -/
/ .
ίʔυϦϙδτϦίϛοτ͞Εͨίʔυʹରͯ͠ҎԼΛߦ͏͜ͱ ᶃ ࣗಈϏϧυ ᶄ ࣗಈςετ ܧଓతΠϯςάϨʔγϣϯ . - - .
-. - - / - :
ᶃ શһ͕ಉ͡खॱͰϏϧυͱςετΛ܁Γฦ͠ߦ͑ΔΑ͏ʹ͢ΔͨΊ ܧଓతΠϯςάϨʔγϣϯ͕ඞཁͳཧ༝
ᶃ શһ͕ಉ͡खॱͰϏϧυͱςετΛ܁Γฦ͠ߦ͑ΔΑ͏ʹ͢ΔͨΊ ܧଓతΠϯςάϨʔγϣϯ͕ඞཁͳཧ༝
ᶃ શһ͕ಉ͡खॱͰϏϧυͱςετΛ܁Γฦ͠ߦ͑ΔΑ͏ʹ͢ΔͨΊ ᶄ ςετ͕ՄೳͳݶΓຊ൪ڥʹ͍ۙڥͰߦΘΕΔΑ͏ʹ͢Δ ܧଓతΠϯςάϨʔγϣϯ͕ඞཁͳཧ༝
ᶃ શһ͕ಉ͡खॱͰϏϧυͱςετΛ܁Γฦ͠ߦ͑ΔΑ͏ʹ͢ΔͨΊ ᶄ ςετ͕ՄೳͳݶΓຊ൪ڥʹ͍ۙڥͰߦΘΕΔΑ͏ʹ͢Δ ܧଓతΠϯςάϨʔγϣϯ͕ඞཁͳཧ༝ !
ᶃ શһ͕ಉ͡खॱͰϏϧυͱςετΛ܁Γฦ͠ߦ͑ΔΑ͏ʹ͢ΔͨΊ ᶄ ςετ͕ՄೳͳݶΓຊ൪ڥʹ͍ۙڥͰߦΘΕΔΑ͏ʹ͢Δ ᶅ ߴ͍සͰςετΛߦ͏ ܧଓతΠϯςάϨʔγϣϯ͕ඞཁͳཧ༝ !
ෆ۩߹͕ࠞೖ͔ͯ͠Βͷ࣌ؒܦա͕ ͘ͳΔ΄ͲରԠίετ૿େ͢ΔͨΊ ߴ͍සͰςετΛߦ͏ඞཁੑ
ෆ۩߹͕ࠞೖ͔ͯ͠Βͷ࣌ؒܦա͕ ͘ͳΔ΄ͲରԠίετ૿େ͢ΔͨΊ ߴ͍සͰςετΛߦ͏ඞཁੑ
$*Λࢧ͑Δ۩ମతͳπʔϧྫͱྨ CI GNU make
go test python -m unittest *
$*Λࢧ͑Δ۩ମతͳπʔϧྫͱྨ CI GNU make
go test python -m unittest *
$*Λࢧ͑Δ۩ମతͳπʔϧྫͱྨ CI GNU make
go test python -m unittest *
$*Λࢧ͑Δ۩ମతͳπʔϧྫͱྨ CI GNU make
go test python -m unittest *
ᶃ Ϗϧυͱςετ͕҆ఆ͠ͳ͍ ᶄ Ϗϧυͱςετͷ࣮ߦ͕͍ ࣮ߦ͕͍࣌ؒ $*ͰΑ͋͘Δ
աڈͷϏϧυʹ͓͚Δ෭ੜɾ෭࡞༻ʹΑͬͯςετ͕҆ఆ͠ͳ͍ ҙਤͤͣʹͬͨதؒϑΝΠϧ%#ͷঢ়ଶͳͲʹىҼ ᶃ Ϗϧυͱςετ͕҆ఆ͠ͳ͍
աڈͷϏϧυʹ͓͚Δ෭ੜɾ෭࡞༻ʹΑͬͯςετ͕҆ఆ͠ͳ͍ ҙਤͤͣʹͬͨதؒϑΝΠϧ%#ͷঢ়ଶͳͲʹىҼ ᶃ Ϗϧυͱςετ͕҆ఆ͠ͳ͍
աڈͷϏϧυʹ͓͚Δ෭ੜɾ෭࡞༻ʹΑͬͯςετ͕҆ఆ͠ͳ͍ ҙਤͤͣʹͬͨதؒϑΝΠϧ%#ͷঢ়ଶͳͲʹىҼ ᶃ Ϗϧυͱςετ͕҆ఆ͠ͳ͍ CIDocker
DB docker-compose
ςεταΠζͷ֓೦Λͬͯޮతʹςετ͢Δ l ςετ͕ࣦഊ͢Δׂ͘Β͍ͭ·Βͳ͍ݪҼ l -JOUωοτϫʔΫ௨৴ͷൃੜ͠ͳ͍ߴͳςετͰચ͍ग़ͤΔ ᶄ Ϗϧυͱςετͷ࣮ߦ͕͍࣌ؒ 3 3 +9
)3 6 9 ( 3 3 3 3 0 3 3 3 6 3 39 3 3 3 3 3 3 39 6 3 3 ) 6 3 3 3 3 + 33 393 3 3 + 39 3 63 3 3 693 696 3 https://testing.googleblog.com/2010/12/test-sizes.html
ͳΔ͘ૣ͍λΠϛϯάͰࣦഊͤ͞ ϑΟʔυόοΫαΠΫϧΛߴͰճͤΔΑ͏ʹ͢Δ ςεταΠζͷ֓೦ʹ߹Θͤͨ$*ύΠϓϥΠϯ࣮ྫ 3 & & & & 8 3
8 3 & 8 & 1 2 3 & 1 2
ϏϧυࣗମΛߴԽ͢Δ ᶄ Ϗϧυͱςετͷ࣮ߦ͕͍࣌ؒ https://speakerdeck.com/orisano/docker-build-battle https://speakerdeck.com/orisano/better-docker-image https://speakerdeck.com/orisano/docker-build-battle https://www.slideshare.net/AkihiroSuda/cndt-docker
ϏϧυࣗମΛߴԽ͢Δ ᶄ Ϗϧυͱςετͷ࣮ߦ͕͍࣌ؒ https://speakerdeck.com/orisano/docker-build-battle https://speakerdeck.com/orisano/better-docker-image https://speakerdeck.com/orisano/docker-build-battle https://www.slideshare.net/AkihiroSuda/cndt-docker
ᶃ Ϗϧυͱςετ͕҆ఆ͠ͳ͍ l ରࡦϏϧυ͓ΑͼςετຖͷಠཱੑΛߴΊɺڥґଘੑΛԼ͛Δ ᶄ ςετͷ࣮ߦ͕͍࣌ؒ l ରࡦςεταΠζͷ֓೦ΛͬͯͳΔ͘ૣ͍ஈ֊Ͱࣦഊͤ͞Δ l ରࡦϏϧυࣗମΛߴԽ͢Δ
$*ͰΑ͋͘ΔͱରԠͷߟ͑ํ
҆શʹมߋΛߦ͏ʹʁ ) ( = )
҆શʹϦϦʔε͢Δͱʁ ᶄ҆શʹػೳΛϦϦʔε͢ΔͨΊͷखஈ !
҆શʹϦϦʔε͢Δͱʁ ᶄ҆શʹػೳΛϦϦʔε͢ΔͨΊͷखஈ !
)( ( ) , ) ;
҆શʹϦϦʔε͢Δͱʁ ᶄ҆શʹػೳΛϦϦʔε͢ΔͨΊͷखஈ !
)( ( ) , ) ;
ίʔυมߋʹͱͳͬͯ ࣗಈతʹ࣮ՔಇڥͷϦϦʔε४උ͕࣮ߦ͞ΕΔ͜ͱ l ܧଓతσϦόϦ l ϦϦʔεʹࡍͯ͠ঝೝϓϩηεΛڬΉ l ܧଓతσϓϩΠ l ϦϦʔε·Ͱͯࣗ͢ಈͰߦΘΕΔ
ܧଓతσϦόϦɾσϓϩΠͱ -/ / - -/ / .
ͳͥܧଓతσϦόϦɾσϓϩΠ͕ඞཁ͔
खಈ࡞ۀͱσϓϩΠΛίʔυԽͨ͠߹Λൺֱ +
खಈ࡞ۀͱσϓϩΠΛίʔυԽͨ͠߹Λൺֱ +
खಈ࡞ۀͱσϓϩΠΛίʔυԽͨ͠߹Λൺֱ +
खಈ࡞ۀͱσϓϩΠΛίʔυԽͨ͠߹Λൺֱ +
खಈ࡞ۀͱσϓϩΠΛίʔυԽͨ͠߹Λൺֱ +
σϓϩΠͷίʔυԽʹࡍͯ͠ߟ͑Δ͜ͱ
σϓϩΠͷίʔυԽʹࡍͯ͠ߟ͑Δ͜ͱ
σϓϩΠͷίʔυԽʹࡍͯ͠ߟ͑Δ͜ͱ 0 ' # . 2
% & / " (0 1 ≒ * !+) ') ,$-(
σϓϩΠͷίʔυԽʹࡍͯ͠ߟ͑Δ͜ͱ 7% . * 5 9
, # " # " - 6! $' (7%8 ≒ 1 &2) .0 3+4/ () 6!
l ༏ઌॱҐΛ্͚ͭͨͰࣗಈԽ͢Δ l ස Y࡞ۀͷεςοϓ Ͱ༏ઌΛஅ ܧଓతσϦόϦɾσϓϩΠ
҆શʹϦϦʔε͢Δͱʁ ᶄ҆શʹػೳΛϦϦʔε͢ΔͨΊͷखஈ !
)( ( ) , ) ;
l ϩʔϦϯάσϓϩΠ l ϒϧʔάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ l ΧφϦΞϦϦʔε ͜͜Ͱղઆ͢ΔσϓϩΠɾϦϦʔεख๏
ଟ͋ΔԽ͞ΕͨίϯϙʔωϯτΛঃʑʹೖΕସ͑Δख๏ ϩʔϦϯάσϓϩΠ APP ver.1.0 APP ver.1.0 APP ver.1.0 APP ver.1.0
Loadbalancer Database
ଟ͋ΔԽ͞ΕͨίϯϙʔωϯτΛঃʑʹೖΕସ͑Δख๏ ϩʔϦϯάσϓϩΠ APP ver.1.1 APP ver.1.0 APP ver.1.0 APP ver.1.0
Loadbalancer Database
ଟ͋ΔԽ͞ΕͨίϯϙʔωϯτΛঃʑʹೖΕସ͑Δख๏ ϩʔϦϯάσϓϩΠ APP ver.1.1 APP ver.1.1 APP ver.1.0 APP ver.1.0
Loadbalancer Database
ଟ͋ΔԽ͞ΕͨίϯϙʔωϯτΛঃʑʹೖΕସ͑Δख๏ ϩʔϦϯάσϓϩΠ APP ver.1.1 APP ver.1.1 APP ver.1.1 APP ver.1.0
Loadbalancer Database
ଟ͋ΔԽ͞ΕͨίϯϙʔωϯτΛঃʑʹೖΕସ͑Δख๏ ϩʔϦϯάσϓϩΠ APP ver.1.1 APP ver.1.1 APP ver.1.1 APP ver.1.1
Loadbalancer Database
ᶃ ೖସͷྀ ᶄ σʔλͷόʔδϣϯؒޓੑ ͷྀ ϩʔϦϯάσϓϩΠͷҙ APP ver.1.1 APP ver.1.0
APP ver.1.0 APP ver.1.0 Loadbalancer Database APP ver.1.1 APP ver.1.1 APP ver.1.0 APP ver.1.0 Loadbalancer Database interval APP ver.1.1 APP ver.1.1 APP ver.1.0 APP ver.1.0 Loadbalancer Database ,'! ! * " (* 0&%- .$) # / !+
໘Λͭ ϒϧʔάϦʔϯ ༻ҙ͠ɺΓସ͑Δ ϒϧʔɾάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ APP ver.1.0 APP ver.1.0 APP
ver.1.0 APP ver.1.0 Loadbalancer Database
໘Λͭ ϒϧʔάϦʔϯ ༻ҙ͠ɺΓସ͑Δ ϒϧʔɾάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ APP ver.1.1 APP ver.1.1 APP
ver.1.0 APP ver.1.0 Loadbalancer Database
໘Λͭ ϒϧʔάϦʔϯ ༻ҙ͠ɺΓସ͑Δ ϒϧʔɾάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ APP ver.1.1 APP ver.1.1 APP
ver.1.0 APP ver.1.0 Loadbalancer Database
໘Λͭ ϒϧʔάϦʔϯ ༻ҙ͠ɺΓସ͑Δ ϒϧʔɾάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ APP ver.1.1 APP ver.1.1 Loadbalancer
Database " % $ #!
ᶃ Ϧιʔείετ l ڥΛ໘ҡ࣋͢Δίετ l ػϦιʔείετ͕ؾʹͳΔ߹ ΠϛϡʔλϒϧσϓϩΠΛݕ౼ ᶄ ସϙΠϯτ l
ޙड़ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS Loadbalancer
Web AP
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS Web
AP
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS AP
τϥϑΟοΫΛίϯτϩʔϧ͢ΔϙΠϯτ͕ଟଘࡏ͢Δ ϒϧʔɾάϦʔϯσϓϩΠͷߟྀࣄ߲ ସϙΠϯτ CDN Loadbalancer Web AP DNS
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.0.9 APP
ver.0.9 Loadbalancer Database 100%
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.1.1 APP
ver.1.1 Loadbalancer Database 100%
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.1.1 APP
ver.1.1 Loadbalancer Database 75% 25%
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.1.1 APP
ver.1.1 Loadbalancer Database 50% 50%
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.1.1 APP
ver.1.1 Loadbalancer Database 25% 75%
ঃʑʹ৽͍͠όʔδϣϯʹτϥϑΟοΫΛྲྀͯ͠ ΤϥʔͷมಈͳͲΛݟͭͭɺ҆શʹϦϦʔε͢Δख๏ ΧφϦΞϦϦʔε APP ver.1.0 APP ver.1.0 APP ver.1.1 APP
ver.1.1 Loadbalancer Database 100%
l (P4UPQج४ͷ໌֬Խ l ߴ࣭ͳࢹɾϞχλϦϯάج൫ඞਢ 6*69ɺγεςϜ؍྆໘ ΧφϦΞϦϦʔεͷߟྀࣄ߲
҆શͳσϓϩΠɾϦϦʔεͷͨΊͷख๏ͱͯ͠ҎԼΛղઆͨ͠ l ϩʔϦϯάσϓϩΠ l ϒϧʔάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ l ΧφϦΞϦϦʔε σϓϩΠɾϦϦʔεख๏·ͱΊ
҆શͳσϓϩΠɾϦϦʔεͷͨΊͷख๏ͱͯ͠ҎԼΛղઆͨ͠ l ϩʔϦϯάσϓϩΠ l ϒϧʔάϦʔϯσϓϩΠ ΠϛϡʔλϒϧσϓϩΠ l ΧφϦΞϦϦʔε σϓϩΠɾϦϦʔεख๏·ͱΊ ଞʹ༷ʑͳख๏͕͋Γɺ
ࡉʑͱͨ͠ςΫχοΫଊ͑ํ͕͋ΔͷͰͦ͜ ʑࢼߦࡨޡ͠ͳ͕ΒֶΜͰ͍ͩ͘͞
Ͳ͏࣭ͬͯΛຏ͖ࠐΉ͔ ܧଓతσϓϩΠɾσϦόϦʔͷ՝
Ͳ͏࣭ͬͯΛຏ͖ࠐΉ͔ ܧଓతσϓϩΠɾσϦόϦʔͷ՝ ΞϓϦέʔγϣϯίʔυͱಉ༷ʹ ຏ͖ࠐΈ 㲈ࣦഊɾࢼߦࡨޡ ͕ڐ͞ΕΔڥΛ४උɾ׆༻͢Δ
Ͳ͏࣭ͬͯΛຏ͖ࠐΉ͔ ܧଓతσϓϩΠɾσϦόϦʔͷ՝ ΞϓϦέʔγϣϯίʔυͱಉ༷ʹ ຏ͖ࠐΈ 㲈ࣦഊɾࢼߦࡨޡ ͕ڐ͞ΕΔڥΛ४උɾ׆༻͢Δ ։ൃڥɾεςʔδϯάڥͷσϓϩΠຊ൪ͱಉ͡खॱͰߦ͏
ಉ͡खॱͰσϓϩΠ͢Δ σϓϩΠϓϩηεͷ౷Ұ ։ൃ εςʔδϯά ຊ൪
ڥࠩΛՄೳͳݶΓഉআ͢Δ σϓϩΠϓϩηεΛ౷Ұ͢Δ্ͰͷϙΠϯτ DNS e.g. Route53Private DNS
ڥࠩΛՄೳͳݶΓഉআ͢Δ σϓϩΠϓϩηεΛ౷Ұ͢Δ্ͰͷϙΠϯτ DNS e.g. Route53Private DNS
ڥࠩΛ༰қʹຒΊΒΕΔΑ͏ʹ ΞϓϦέʔγϣϯΛ࡞Δ ΞϓϦέʔγϣϯઃఆํ๏ Good Bad 1, #"$ ## 1,1,!+4& /)*.1,23*
*%-05 (' 1,! #
l ϓϩηεΛຏ͖ࠐΉͨΊͷΛ֬อ͢Δ l ຏ͖ࠐΈΛҙຯ͋Δͷʹ͢ΔͨΊ ڥؒͷࠩΛ࠷খʹอͭ ܧଓతσϓϩΠɾσϦόϦʔ՝ͷ·ͱΊ
%FW0QTΛ࣮ફͯ͠ҎԼΛ࣮ݱ͢ΔͨΊͷ֤छख๏Λղઆͨ͠ ·ͱΊ " !
%FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT
%FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ %FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ & " $!% # DevOpsLean
'0:"1 26) '0:"1 $ %FW0QTΛ࣮ફͰ͖͍ͯΔاۀ WT %FW0QTΛ࣮ફͰ͖͍ͯͳ͍اۀ
%FW0QTΛ࣮ફͰ͖ͨ࣌ͷޮՌ & " $!% # DevOpsLean3'/&-5 ,*4 # 98 ( %. +!7
҉తʹΓࠐ·Ε֤ͨϩʔϧͷͷҧ͍ʹىҼ ͳͥରཱ͕ى͜Δͷ͔ DevK3 ?BIL2 & %!5-. 6@2 OpsK3 !#(9:H/;D
& %!5-M8N 6@O< N A GE4 !"',+)*$JC & & %!=10F>7
҉తʹΓࠐ·Ε֤ͨϩʔϧͷͷҧ͍ʹىҼ ͳͥରཱ͕ى͜Δͷ͔ DevK3 ?BIL2 & %!5-. 6@2 OpsK3 !#(9:H/;D
& %!5-M8N 6@O< N A GE4 !"',+)*$JC & & %!=10F>7 ϛογϣϯͷҧ͍Λཧղ্ͨ͠Ͱ ҆શʹมߋ͢ΔͨΊͷํ๏Λߟ͑ͯຏ͘ ͍·ͦͷͨΊͷಓ۩ຏͨ͘Ίͷख๏ͨ͘͞Μ͋Δ
ΧελϚʔΫϥΠΞϯτͷߩݙ ͱ͔ͦ͜ΒͨΒ͞ΕΔ Ϗδωεͷޭͱརӹͷ֦େ
ΧελϚʔΫϥΠΞϯτͷߩݙ ͱ͔ͦ͜ΒͨΒ͞ΕΔ Ϗδωεͷޭͱརӹͷ֦େ ͍͖ͬͯ
THE TWELVE-FACTOR APP
l ηοτΞοϓͷࣗಈԽͷͨΊʹએݴతͳϑΥʔϚοτΛ͍ɺ ϓϩδΣΫτʹ৽͘͠ՃΘͬͨ։ൃऀ͕ཁ͢Δ࣌ؒͱίετΛ࠷খԽ͢Δ l Լͷ04ͷґଘؔΛ໌֬Խ͠ɺ࣮ߦڥ͍͋ͩͰͷҠ২ੑΛ࠷େԽ͢Δ l ϞμϯͳΫϥυϓϥοτϑΥʔϜ্ͷσϓϩΠʹద͓ͯ͠Γɺ αʔόཧɺγεςϜཧΛෆཁͳͷʹ͢Δ l ։ൃڥͱຊ൪ڥͷࠩҟΛ࠷খݶʹ͠ɺΞδϦςΟΛ࠷େԽ͢ΔܧଓతσϓϩΠΛՄೳʹ͢Δ
l πʔϧɺΞʔΩςΫνϟɺ։ൃϓϥΫςΟεΛେ෯ʹมߋ͢Δ͜ͱͳ͘εέʔϧΞοϓͰ͖Δ 5)&58&-7&'"$503"11ͱ https://12factor.net/ja/
5IF5XFMWF'BDUPST *ίʔυϕʔε όʔδϣϯཧ͞Ε͍ͯΔͭͷίʔυϕʔεͱ ෳͷσϓϩΠ **ґଘؔ ґଘؔΛ໌ࣔతʹએݴ͢͠Δ ***ઃఆ ઃఆΛڥมʹ֨ೲ͢Δ *7όοΫΤϯυαʔϏε όοΫΤϯυαʔϏεΛΞλον͞ΕͨϦιʔε
ͱͯ͠ѻ͏ 7ϏϧυɾϦϦʔεɾ࣮ߦ ϏϧυɾϦϦʔεɾ࣮ߦͷͭͷεςʔδΛݫີ ʹ͢Δ 7*ϓϩηε ΞϓϦέʔγϣϯΛͭ͘͠ෳͷεςʔτ Ϩεͳϓϩηεͱ࣮ͯ͠ߦ 7**ϙʔτόΠϯσΟϯά ϙʔτόΠϯσΟϯάΛ௨ͯ͠αʔϏεΛެ։͢Δ 7***ฏߦੑ ϓϩηεϞσϧʹΑͬͯεέʔϧΞτ͢Δ *9ഇغ༰қੑ ߴͳىಈͱάϨʔεϑϧγϟοτμϯͰݎ࿚ੑΛ࠷ େԽ͢Δ 9։ൃຊ൪Ұக ։ൃɺεςʔδϯάɺຊ൪ڥΛͰ͖Δ͚ͩҰகͤͨ͞ ঢ়ଶΛอͭ 9*ϩά ϩάΛΠϕϯτετϦʔϜͱͯ͠ѻ͏ 9**ཧϓϩηε ཧλεΫΛճݶΓͷϓϩηεͱ࣮ͯ͠ߦ͢Δ
5IF5XFMWF'BDUPST *ίʔυϕʔε όʔδϣϯཧ͞Ε͍ͯΔͭͷίʔυϕʔεͱ ෳͷσϓϩΠ **ґଘؔ ґଘؔΛ໌ࣔతʹએݴ͢͠Δ ***ઃఆ ઃఆΛڥมʹ֨ೲ͢Δ *7όοΫΤϯυαʔϏε όοΫΤϯυαʔϏεΛΞλον͞ΕͨϦιʔε
ͱͯ͠ѻ͏ 7ϏϧυɾϦϦʔεɾ࣮ߦ ϏϧυɾϦϦʔεɾ࣮ߦͷͭͷεςʔδΛݫີ ʹ͢Δ 7*ϓϩηε ΞϓϦέʔγϣϯΛͭ͘͠ෳͷεςʔτ Ϩεͳϓϩηεͱ࣮ͯ͠ߦ 7**ϙʔτόΠϯσΟϯά ϙʔτόΠϯσΟϯάΛ௨ͯ͠αʔϏεΛެ։͢Δ 7***ฏߦੑ ϓϩηεϞσϧʹΑͬͯεέʔϧΞτ͢Δ *9ഇغ༰қੑ ߴͳىಈͱάϨʔεϑϧγϟοτμϯͰݎ࿚ੑΛ࠷ େԽ͢Δ 9։ൃຊ൪Ұக ։ൃɺεςʔδϯάɺຊ൪ڥΛͰ͖Δ͚ͩҰகͤͨ͞ ঢ়ଶΛอͭ 9*ϩά ϩάΛΠϕϯτετϦʔϜͱͯ͠ѻ͏ 9**ཧϓϩηε ཧλεΫΛճݶΓͷϓϩηεͱ࣮ͯ͠ߦ͢Δ Dev, Ops" !
5IF5XFMWF'BDUPST *ίʔυϕʔε όʔδϣϯཧ͞Ε͍ͯΔͭͷίʔυϕʔεͱ ෳͷσϓϩΠ **ґଘؔ ґଘؔΛ໌ࣔతʹએݴ͢͠Δ ***ઃఆ ઃఆΛڥมʹ֨ೲ͢Δ *7όοΫΤϯυαʔϏε όοΫΤϯυαʔϏεΛΞλον͞ΕͨϦιʔε
ͱͯ͠ѻ͏ 7ϏϧυɾϦϦʔεɾ࣮ߦ ϏϧυɾϦϦʔεɾ࣮ߦͷͭͷεςʔδΛݫີ ʹ͢Δ 7*ϓϩηε ΞϓϦέʔγϣϯΛͭ͘͠ෳͷεςʔτ Ϩεͳϓϩηεͱ࣮ͯ͠ߦ 7**ϙʔτόΠϯσΟϯά ϙʔτόΠϯσΟϯάΛ௨ͯ͠αʔϏεΛެ։͢Δ 7***ฏߦੑ ϓϩηεϞσϧʹΑͬͯεέʔϧΞτ͢Δ *9ഇغ༰қੑ ߴͳىಈͱάϨʔεϑϧγϟοτμϯͰݎ࿚ੑΛ࠷ େԽ͢Δ 9։ൃຊ൪Ұக ։ൃɺεςʔδϯάɺຊ൪ڥΛͰ͖Δ͚ͩҰகͤͨ͞ ঢ়ଶΛอͭ 9*ϩά ϩάΛΠϕϯτετϦʔϜͱͯ͠ѻ͏ 9**ཧϓϩηε ཧλεΫΛճݶΓͷϓϩηεͱ࣮ͯ͠ߦ͢Δ % &') Dev, Ops-, $# $# = !'"%( *+
ϦϙδτϦͰཧ͞Ε͍ͯͳ͍ίʔυσϓϩΠ͠ͳ͍ *ίʔυϕʔε
ϦϙδτϦͰཧ͞Ε͍ͯͳ͍ίʔυσϓϩΠ͠ͳ͍ ୯ҰͷϦϙδτϦ͔ΒϩʔΧϧɾ։ൃɾ εςʔδϯάɾຊ൪ʹσϓϩΠͰ͖ΔΑ͏ʹ͓ͯ͘͠ ڥ͝ͱʹར༻͍ͯ͠ΔϦϙδτϦ͕ҟͳΒͳ͍Α͏ʹ͢Δ *ίʔυϕʔε
ϦϙδτϦͰཧ͞Ε͍ͯͳ͍ίʔυσϓϩΠ͠ͳ͍ ୯ҰͷϦϙδτϦ͔ΒϩʔΧϧɾ։ൃɾ εςʔδϯάɾຊ൪ʹσϓϩΠͰ͖ΔΑ͏ʹ͓ͯ͘͠ ڥ͝ͱʹར༻͍ͯ͠ΔϦϙδτϦ͕ҟͳΒͳ͍Α͏ʹ͢Δ *ίʔυϕʔε %$.) " /( "!"',
( +"# vim0 "&- *1 = )
ΞϓϦέʔγϣϯΛಈ্͔͢Ͱ ඞཁͳཁૉͷґଘ͕ؔ໌ࣔతʹఆٛ͞Ε͍ͯΔ͜ͱ **ґଘؔ 3VCZ (FNˠ (FNGJMF /PEFKT ˠ QBDLBHFKTPO 1ZUIPO
1ZQJ ˠ SFRVJSFNFOUTUYU +BWB ˠ QPNYNM %PDLFS ˠ %PDLFSGJMF
ΞϓϦέʔγϣϯΛಈ্͔͢Ͱ ඞཁͳཁૉͷґଘ͕ؔ໌ࣔతʹఆٛ͞Ε͍ͯΔ͜ͱ **ґଘؔ 3VCZ (FNˠ (FNGJMF /PEFKT ˠ QBDLBHFKTPO 1ZUIPO
1ZQJ ˠ SFRVJSFNFOUTUYU +BWB ˠ QPNYNM %PDLFS ˠ %PDLFSGJMF ϩʔΧϧ։ൃͷࡍʹՃͷखॱ͕ൃੜ͢Δ߹ Կ͔͠ΒͷΛ๊͍͑ͯΔͱߟ͑ͨํ͕ྑ͍ ͪΖΜݴޠڥͷߏஙͦͷͷআ͘ FHNBWFOͰηοτΞοϓͨ͠ޙʹԿ͔Α͘Θ͔Βͳ͍KBSϑΝΠϧΛґଘؔʹೖΕΔͳͲ
ઃఆΛΞϓϦέʔγϣϯίʔυ͔ΒݫີʹͰ͖ΔΑ͏ʹ͢Δ ***ઃఆ
ઃఆΛΞϓϦέʔγϣϯίʔυ͔ΒݫີʹͰ͖ΔΑ͏ʹ͢Δ ***ઃఆ "(#!// ) )
N G ( ( G (
ΞϓϦέʔγϣϯ͕ΞΫηε͢ΔϦιʔεॴͳͲΛҙ ࣝ͢Δ͜ͱͳ͘ΞΫηεͰ͖ΔΑ͏ʹ͢Δ͜ͱ ΞϓϦέʔγϣϯίʔυΛมߋ͢Δ͜ͱͳ͘ɺ ଓઌͷϦιʔεΛมߋͰ͖ΔΑ͏ʹ͢Δ͜ͱ *7όοΫΤϯυαʔϏε
ϏϧυɾϦϦʔεɾ࣮ߦͷϓϩηεΛ໌֬ʹ͚Δ 7ϏϧυɾϦϦʔεɾ࣮ߦ ίʔυ ࣮ߦՄೳͳ όΠφϦ ઃఆ ϑΝΠϧ PSڥม ઃఆ
ϑΝΠϧ PSڥม ࣮ߦՄೳͳ όΠφϦ Ϗϧυ ϦϦʔε ࣮ߦ ෆ۩߹ݕ PS৽ػೳཁٻ ϦϑΝΫλϦϯά͋ΔΑ ίʔυमਖ਼ ɾՃ
ϏϧυɾϦϦʔεɾ࣮ߦͷϓϩηεΛ໌֬ʹ͚Δ 7ϏϧυɾϦϦʔεɾ࣮ߦ ίʔυ ࣮ߦՄೳͳ όΠφϦ ઃఆ ϑΝΠϧ PSڥม ઃఆ
ϑΝΠϧ PSڥม ࣮ߦՄೳͳ όΠφϦ Ϗϧυ ϦϦʔε ࣮ߦ ෆ۩߹ݕ PS৽ػೳཁٻ ϦϑΝΫλϦϯά͋ΔΑ ίʔυमਖ਼ ɾՃ -', (&.+ (%!"!#* ! !#* " )$ )
ΞϓϦέʔγϣϯΛ୯Ұɺ͘͠ ෳͷεςʔτϨεͳϓϩηεͱ࣮ͯ͠ߦ͢Δ 7*ϓϩηε
ΞϓϦέʔγϣϯΛ୯Ұɺ͘͠ ෳͷεςʔτϨεͳϓϩηεͱ࣮ͯ͠ߦ͢Δ 7*ϓϩηε
ΞϓϦέʔγϣϯΛ୯Ұɺ͘͠ ෳͷεςʔτϨεͳϓϩηεͱ࣮ͯ͠ߦ͢Δ 7*ϓϩηε ! (Redis, Memcached, RDB
)
ΞϓϦέʔγϣϯϓϩηεͦͷͷ͕ ϙʔτόΠϯσΟϯάΛ௨ͯ͡αʔϏεΛެ։͢Δ ࢦఆ͞Εͨ5$16%1ϙʔτ൪߸ΛͬͯαʔϏεΛެ։͢Δ 7**ϙʔτόΠϯσΟϯά
εέʔϧΞτϓϩηεϞσϧʹΑͬͯߦΘΕΔ 7***ฒߦੑ
εέʔϧΞτϓϩηεϞσϧʹΑͬͯߦΘΕΔ 7***ฒߦੑ " !#
l ϓϩηε͕04͔Βͷ4*(5&3.γάφϧड͚औͬͨࡍʹά Ϩʔεϑϧ ʹγϟοτμϯͰ͖ΔΑ͏ʹ͢Δ l ఀࢭͷࡍʹෳࡶͳखଓ͖Λ͍Βͳ͍Α͏ʹ͢Δ l ىಈ࣌ؒΛ࠷খԽ͢Δ l ϓϩηε͕ىಈ͔ͯ͠ΒͰ͖Δ͚ͩ࣌ؒͰॲཧΛ։࢝Ͱ͖ΔΑ͏ʹ͢Δ
*9ഇغ༰қੑ *
։ൃεςʔδϯάຊ൪ΛͰ͖Δ͚ͩҰகͤͨ͞ঢ়ଶΛอͭ l ߏཁૉଗ͑Δ l ຊ൪ʹ͔͠ଘࡏ͠ͳ͍ίϯϙʔωϯτ͕ͳ͍Α͏ʹ͢Δ l ϥΠηϯείετͷ߹Ͱͦ͏ͳ͍ͬͯΔͳΒͦͦͷߏΛݟ͢ l εέʔϧ·Ͱଗ͑Δ͔༧ࢉͱ૬ஊ l
ෛՙࢼݧ࣌ͷΈΦϯσϚϯυʹଗ͑ΒΕΔΑ͏ʹ͓ͯ͘͠ͱ͍ͬͨΞϦ l Ұக͍ͯ͠ͳ͍෦໌จԽ͢Δ l ڥ͝ͱͷࠩ໌จԽ͠ɺ༰қʹؾ͚ΔΑ͏ʹ͢Δ l ύϒϦοΫΫϥυͰ͋ΕJOUFSOBM%/4Λ͏·͘׆༻Ͱ͖Δͱ͔ͳΓڧྗ 9։ൃຊ൪Ұக
ϩάGMVFOUEMPHTUBTIͳͲͷπʔϧΛ ༻͍ͯಛఆͷॴʹू͢Δ 9*ϩά ेʙඦͷαʔόʔ ेʙඦͷαʔόʔ ू
ϩάͷूΛ͍ͯ͠ͳ͍߹ ϩάͷूΛ͍ͯ͠Δ߹
ϩάGMVFOUEMPHTUBTIͳͲͷπʔϧΛ ༻͍ͯಛఆͷॴʹू͢Δ 9*ϩά ेʙඦͷαʔόʔ ेʙඦͷαʔόʔ ू
ϩάͷूΛ͍ͯ͠ͳ͍߹ ϩάͷूΛ͍ͯ͠Δ߹ ( MTTR)
ཧλεΫ %#ͷઃఆมߋͳͲ ΛҰճݶΓͷϓϩηεͱ࣮ͯ͠ߦ͢Δ ྫ͑ɺ%#ͷϚΠάϨʔγϣϯλεΫίʔυͱηοτʹͳ͓ͬͯΓɺ ϦϦʔε࣌ʹ࣮ߦ͞ΕΔΑ͏ʹͳ͍ͬͯΔ 9**ཧϓϩηε QZUIPO %KBOHP QZUIPONBOBHFQZNJHSBUF 3VCZ
3P3 SBLFECNJHSBUF HP TRMNJHSBUF TRMNJHSBUFVQ
ཧλεΫ %#ͷઃఆมߋͳͲ ΛҰճݶΓͷϓϩηεͱ࣮ͯ͠ߦ͢Δ ྫ͑ɺ%#ͷϚΠάϨʔγϣϯλεΫίʔυͱηοτʹͳ͓ͬͯΓɺ ϦϦʔε࣌ʹ࣮ߦ͞ΕΔΑ͏ʹͳ͍ͬͯΔ 9**ཧϓϩηε QZUIPO %KBOHP QZUIPONBOBHFQZNJHSBUF 3VCZ
3P3 SBLFECNJHSBUF HP TRMNJHSBUF TRMNJHSBUFVQ ਓؒϛεΛ͢ΔͷͰՄೳͳݶΓ 42-ΛͦͷͰ࣮ߦ͢ΔͳͲͷ ෳࡶͳ࡞ۀͤ͞ͳ͍Α͏ʹ͢Δ͜ͱ