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
Rebuild Team - 急成長プロダクトのDev&Opsで生じる悪循環とその解決策 / ...
Search
yuzutas0
PRO
October 13, 2017
Technology
8
54k
Rebuild Team - 急成長プロダクトのDev&Opsで生じる悪循環とその解決策 / 20171013
SPI Japan 2017の発表資料です。
refs.
https://yuzutas0.hatenablog.com/entry/2017/10/16/093000
yuzutas0
PRO
October 13, 2017
Tweet
Share
More Decks by yuzutas0
See All by yuzutas0
OLSにおける推定量β1=共分散÷分散の導出 / 20230517
yuzutas0
PRO
1
490
民間企業におけるデータ整備の課題と工夫 / 20220305
yuzutas0
PRO
14
7k
累計参加者8,500名! #DataEngineeringStudy の43スライドから学ぶ、データエンジニアリングの羅針盤 / 20220224
yuzutas0
PRO
15
5k
あの人の自分戦略を聞きたい!2022 #devsumi / 20220218
yuzutas0
PRO
3
3.8k
データ基盤による利益最大化と初期構築プロセス / 20220209
yuzutas0
PRO
10
6.3k
Engineer Career Lounge#1「エンジニアの成長戦略を考える」 #ECLounge カンニングペーパー / 20211217
yuzutas0
PRO
3
1.4k
Data Management Guide - 事業成長を支えるデータ基盤のDev&Ops #TechMar / 20211210
yuzutas0
PRO
17
23k
[投影資料]『実践的データ基盤への処方箋』の刊行にあたって #TechMar / 20210210-2
yuzutas0
PRO
1
3.3k
DXを妨げる要因と実現へのアプローチ by @yuzutas0 / 20211022
yuzutas0
PRO
55
46k
Other Decks in Technology
See All in Technology
新卒1年目のフロントエンド開発での取り組み/New grad front-end efforts
kaonavi
0
130
Multitenant 23ai の全貌 - 機能・設計・実装・運用からマイクロサービスまで
oracle4engineer
PRO
2
150
チームビルディング「脅威モデリング」ワークショップ
koheiyoshikawa
0
180
ソフトウェアプロジェクトの成功率が上がらない原因-「社会価値を考える」ということ-
ytanaka5569
0
140
Cline、めっちゃ便利、お金が飛ぶ💸
iwamot
20
19k
自分の軸足を見つけろ
tsuemura
1
150
サーバシステムを無理なくコンテナ移行する際に伝えたい4つのポイント/Container_Happy_Migration_Method
ozawa
1
120
初めてのPostgreSQLメジャーバージョンアップ
kkato1
0
520
3/26 クラウド食堂LT #2 GenU案件を通して学んだ教訓 登壇資料
ymae
1
240
Vision Language Modelを活用した メルカリの類似画像レコメンドの性能改善
yadayuki
9
1.3k
「ラベルにとらわれない」エンジニアでいること/Be an engineer beyond labels
kaonavi
0
220
DevinはクラウドエンジニアAIになれるのか!? 実践的なガードレール設計/devin-can-become-a-cloud-engineer-ai-practical-guardrail-design
tomoki10
3
1.5k
Featured
See All Featured
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
Writing Fast Ruby
sferik
628
61k
4 Signs Your Business is Dying
shpigford
183
22k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
28
1.6k
Documentation Writing (for coders)
carmenintech
69
4.7k
It's Worth the Effort
3n
184
28k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
12
630
Side Projects
sachag
452
42k
Become a Pro
speakerdeck
PRO
27
5.2k
Visualization
eitanlees
146
16k
Gamification - CAS2011
davidbonilla
81
5.2k
Navigating Team Friction
lara
184
15k
Transcript
Rebuild Team ٸϓϩμΫτͷDev&OpsͰੜ͡Δѱ॥ͱͦͷղܾࡦ 2017-10-13 (Fri) SPI Japan 2017
presented by @yuzutas0 IUUQTXXXQFYFMTDPNQIPUPDPMMFBHVFTDPPQFSBUJPOpTUCVNQpTUT
90ຕ / 20min ͲΜͲΜ͍͖·͢
ɹSho Yokoyama (@yuzutas0) ɹɹ • ϦΫϧʔτςΫϊϩδʔζ •
ೝఆεΫϥϜϚελʔ • ΤϯδχΞνʔϜͷ্ཱͪ͛ɾཱͯ͠
ɹຊͷ༰ “ٸʹ͏௧Έ” Λ1ͭ1ͭղফͯ͠ νʔϜΛ҆ఆԽͨ͠ࣄྫΛڞ༗͠·͢
ɹఆ͢Δର ٸϑΣʔζͷϓϩμΫτ։ൃɾӡ༻ʹؔ৺ͷ͋Δ • ιϑτΣΞΤϯδχΞ • νʔϜϦʔμʔ • ৫Ϛωʔδϟʔ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹ௧ʹۤ͠ΉϓϩμΫτ ձࣾͷ࣍Λ୲͏ࣄۀͱͯ͠ͷظ νʔϜཱͯ͠ͷඞཁੑ ϝϯόʔ2ഒ/Q εέʔϧظ ച্3ഒ/ άϩʔε ো2݅/Ӧۀ
ةػతঢ়گ
ɹ“0→1” ͕ੜΜͩෛ࠴ ώοτ͢Δ͔ෆ֬ఆͰίετΛׂ͚ͳ͔ͬͨ ֎ʹؙ͛ γεςϜ࣭ γεςϜͷݶք ϐʔΫ࣌ؒଳͷԠ͕20sec ࢢ֦େ Ϣʔβʔ૿Ճ
ɹ“1→10” ʹඋ͑ͨ࠶ߏங ϐʔΫ࣌ؒଳͷϨεϙϯελΠϜΛ0.05secʹ400ഒͷվળ ɹɹɹɹɹɹɹɹɹɹɹɹΦϯϓϨ ϨϯμϦϯάHTMLͱ jQueryͷଟॏಡࠐ → VirtualDOMɾSPA ʢඇಉظϕʔεͷ௨৴ʣ
֤αʔόͷεέʔϧΞοϓˍεέʔϧΞτ DBΩϟογϡ → KVSҠ ϚϧνϚελߏʹWriteࢄ ඇਖ਼نԽ&Ϛελςʔϒϧഇࢭ ʹJoinεΩϟϯΛݮ ϙʔϦϯά࠷దԽ ΤϯυϙΠϯτΛࢄ ϩδοΫશॻ͖͠ JPA؆қੜΫΤϦ → ࣗલSQLͰ࠷దԽ
ɹ“1→10” ʹඋ͑ͨԽ αϒγεAͷ࠶ߏங ՔಇதγεςϜͷ อकӡ༻ αϒγεAͷ ड͚͠ ʴαϒγεAͷ ػೳՃΛ࠶։
ʴαϒγεBͷ ػೳՃΛ࠶։ αϒγεBͷ࠶ߏங αϒγεCͷ࠶ߏங αϒγεBͷ ड͚͠ γεςϜ࠶ߏஙνʔϜ ։ൃˍӡ༻νʔϜ ػೳՃΛҰ࣌ఀࢭ͢Δܭը͕ͩͬͨࣄۀ෦ͷཁٻͰ࣮ࢪ γεςϜ෦ͷϚωδϝϯτ͕ະհࡏͷ··Γ࢝Ίͨ ֎Λഇࢭ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϛογϣϯ • ։ൃɾӡ༻νʔϜΛཱͯ͢͜ͱ • ͞ΒͳΔͷΛߏங͢Δ͜ͱ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
γεςϜো͕Ӧۀ͋ͨΓ2݅ൃੜ͢Δঢ়گ͕1ϲ݄ଓ͍ͨ → શνʔϜͷ͋ΒΏΔ։ൃΛࢭΊͯ੩Խ ঃʑʹऩଋ͕ͨ͠ • ߃ٱରԠਃ͠ૹΓ • िʹԿճ͔࣌ݶര͕രൃ • ϦϦʔεͷʹ৽ͨͳো͕ൃੜ
ɹͳʹͱ͋ΕՐΛফ͢ https://www.pexels.com/photo/water-outside-fire-hose-69934/
ɹѱ॥Λଧ։͢Δվળ׆ಈ վળαΠΫϧΛͻͨ͢Βճ͠ଓ͚ͨ ݱঢ়ͷՄࢹԽ ಁ໌ੑ ϘτϧωοΫͷಛఆ ݕࠪ ϓϥΫςΟεͷద༻ దԠ
ɹ˞ٕज़؍ίπίπվળ͠ͳ͕Β ίʔυ࣭ͷ୲อ ϒϥϯνઓུͷಋೖ QAࢧԉɾςετڧԽ ϦϦʔε࡞ۀͷࣗಈԽ ཁ݅ϑΥʔϚοτඋ ςετ͚ࢿཧ IUUQTPOJDTPGUTPMVUJPOTJORVBMJUZBTTVSBODFBOEUFTUJOHIUNMɹɹɹIUUQOWJFDPNQPTUTBTVDDFTTGVMHJUCSBODIJOHNPEFM
݁Ռతʹʮݱ͚ͩͰແཧʹղܾ͠ͳ͍ʯʮ૬ஊ͢ΕղܾͰ͖Δ͜ͱ͋Δʯͷϝοηʔδʹͳͬͨ ɹ˞֎෦ϦιʔεͰෆΛิ͍ͳ͕Β ࢿɿϗϫΠτϘʔυϞχλʔ ࣝɿಛఆͷઐՈαϙʔτ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϘτϧωοΫ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര τϥϒϧ ମྗɾϝϯλϧʹܸ ͗Α͏͕ͳ͍
ɹࠞཚͨ͠··োʹରቂ͢Δ
• ܰඍͳෆ۩߹ͰͷΦϯίʔϧۀରԠ͕ൃੜ͍ͯͨ͠ • ෆదͳରԠʹΑΔೋ࣍ࡂ͕গͳ͔Βͣൃੜ͍ͯͨ͠ ɹোͷੳ͔Βணख
• ࣭ɾোରԠʹ͓͚Δؔऀͷઢ߹Θͤ • ఆٛͦͷͷ < “ఆظతͳձ” Λ௨ͨ͡ڞ௨ೝࣝͷৢ ɹαʔϏεϨϕϧΛఆٛ
ɹͲͷ͘Β͍ ”͍” Ϩϕϧ͔ SLA ػೳ ηΩϡϦςΟɾ๏ ίΞػೳ αϒػೳ ඇػೳ
৴པੑɾՄ༻ੑ ੑೳɾΩϟύγςΟ OLA ʴ Өڹൣғ ར༻ऀɾγΣΞ ࣌ؒଳ αϙʔτڥ ʹ ରԠ ଈ࣌ରԠ - ϕετΤϑΥʔτ ༏ઌରԠʢʼػೳՃʣ ௨ৗରԠʢʹػೳՃʣ ӡ༻ ఆظతͳධՁ → ࠶ൃࢭ + ࣄલ༧ αʔϏεϨϕϧఆٛࣗମͷݟ͠ ࢀরʰαʔϏεϨϕϧɿઃܭͱӡ༻ͷϓϥΫςΟεʱ http://yuzutas0.hatenablog.com/entry/2017/05/23/073000
ಋೖ࣌ʹաڈࣄྫΛ౿·͑ͨγϛϡϨʔγϣϯͰઆ໌ ྫྷ੩ʹ͢ͱʮ͜ͷϨϕϧͷෆ۩߹Ͱʯʮ௨͠ͷରԠΛͯ͠ʯ ʮೋ࣍ࡂ͕ى͖ͨ͜ͱʯͷ೦͕͞ු͖ூΓʹͳΔʢஅج४ͷඞཁੑʣ ɹʮ͜ΕΛܾΊͯԿͷҙຯ͕͋Δͷʁʯ ͜ͷτϥϒϧͩͱ ͜ͷରԠʹͳΔ ͜ͷτϥϒϧͩͱ ͜ͷରԠʹͳΔ
͜ͷτϥϒϧͩͱ ͜ͷରԠʹͳΔ
αʔϏεϨϕϧΛஅͷدΔลͱͯ͠গͣͭ͠ఆணͤ͞Δ ɹײযΓͰҙࢥܾఆ͕ͳ͞Ε͕ͪ ɹʮαʔϏεϨϕϧఆٛͩͱ ɹɹ͜ͷΑ͏ʹஅͰ͖·͢Ͷʯ ҙࢥܾఆͷʹډ߹ΘͤΔ γεςϜ෦ͷ৬ऀΛঌש͢Δ τϥϒϧൃੜ࣌ ϝϯόʔʹΛֻ͚ͯΒ͏
৺ཧత҆શੑ ʮ૬ஊ͢ΕؒରԠͤͣʹࡁΉʯ ϝϯόʔ͕ҰํతʹෆརӹΛ ඃΒͳ͍Α͏ʹίϛϡχέʔγϣϯ
ܗ֚ԽɾߗԽΛ͙ͨΊͷӡ༻ઃܭ • ݄࣍ͷৼΓฦΓͰఆٛࣗମΛՃචɾमਖ਼ • աେɾաগͳΦϖϨʔγϣϯϨϕϧͰରԠ → ͔࣍ΒదͳϨϕϧͱ͢Δձ • Ξοϓσʔτ͍͢͠Α͏ʹίϥϘϨʔγϣϯπʔϧʢConfluenceʣʹهࡌ
ɹॳߟྀ֎ͩͬͨ৽؍͕ग़Δ
ɹదͳϨϕϧͰ࣭ʹରቂ͢Δ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϘτϧωοΫ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ർฐ ”୲ऀ”ͷ๊͑Δ ՝ΛΓ։͘
ɹ“୲ऀ”͚͕ͩ՝ʹରቂ͢Δ
ɹ1on1ʹͯώΞϦϯά IUUQTXXXQFYFMTDPNQIPUPBEVMUCFBSECFWFSBHFCMVS
ɹɹɹɹɹ • ϝϯόʔ͝ͱʹҟͳΔ՝ҙࣝΛ๊͍͑ͯΔ ɹɹɹɹɹ • ͦͷ “” Λ͓ޓ͍ʹൃ৴͍͋͑ͯ͠ͳ͍ ɹɹɹɹɹ •
νʔϜͱͯ͠ “” ͷݕɾղܾ͕Ͱ͖͍ͯͳ͍ ɹܧଓతͳ՝ͷݕ͕Ͱ͖͍ͯͳ͍ IUUQXXXJSBTVUPZBDPNCMPHQPTU@IUNM
•ʮߴ͍༏ઌʯͩΒ͚ͷܭը •ʮߴ͍༏ઌʯͩΒ͚ͷׂΓࠐΈ࡞ۀ • “୲ऀ” ͕ՔಇΛ૿͢͜ͱͰܭըʹ࣮ଶΛ߹ΘͤΑ͏ͱͨ͠ ɹ༏ઌॱҐʹԠͯ͡࡞ۀͰ͖͍ͯͳ͍
νʔϜ෦ͷձΛ׆ੑԽ → ಁ໌ੑΛอͭ → ݕࠪɾదԠͷαΠΫϧΛճ͢ ɹεϓϦϯτηϨϞχʔΛ։࠵ What ԿΛ͢Δ͔ How
Ͳ͏ͬͯ͢Δ͔ ि࣍ϨϏϡʔ ࡞ۀ݁ՌϑΟʔυόοΫ σΠϦʔMTG ࡞ۀͷ࠶ܭը ि࣍ϓϥϯχϯά Ҋ݅ͷ࠶ܭը ϨτϩεϖΫςΟϒ ϓϩηεͷ࠶ܭը What ԿΛ͢Δ͔ How Ͳ͏ͬͯ͢Δ͔
ɹηϨϞχʔʹ͏ΞΠςϜͷඋ ɹϓϩμΫτόοΫϩά ɹݶΒΕͨਓһͰ༏ઌॱҐʹԠͯ͡࡞ۀ͢ΔΩϡʔ ɹোϦετ ɹϨτϩεϖΫςΟϒͰՄࢹԽ͞Εͨ՝ ɹεϓϦϯτόοΫϩά ɹݱঢ়ͷ࡞ۀਐḿΛՄࢹԽ͢ΔΧϯόϯ
*ྫʮ͋ͷَిͷதͰखॱॻΛ࡞ͬͯϨϏϡʔͰ͖ͨʂೋ࣍ࡂ͕ى͖ͳ͍Α͏ʹಈ͚ͨͷྑ͔ͬͨʂʯ ɹKPTʹΑΔৼΓฦΓ͔Βணख Keep ݫ͍͠ঢ়گ͔ͩΒͦ͜ൃش͞Εͨ ྑ͍Λ͔ͬ͠Γͱশ͑߹ͬͨ* Problem ʢͦͷ্Ͱʣ֤ϝϯόʔ͕ ײ͍ͯ͡Δ՝Λચ͍ग़ͨ͠ IUUQXXXJSBTVUPZBDPNCMPHQPTU@IUNM
ɹTryͱͯ͠ϓϥΫςΟεΛঃʑʹಋೖ ݱ͕ແཧͳ͘ड͚ೖΕΒΕΔॱ൪ͰΞδϟΠϧख๏Λద༻ʢ͍͖ͳΓεΫϥϜͩͱߏ͑ΒΕΔʣ 1ʹ͋Ε͜Ε ରԠ͢Δͷແཧͩʂ ༏ઌॱҐͷΩϡʔཧ όοΫϩάΛಋೖ Problem Try Ωϡʔͷݟ͠Λ
ͨ͠΄͏͕ྑ͍ͷͰʁ ݟ͠ػձͱͯ͠ ϓϥϯχϯάձٞΛಋೖ Problem Try ଞͷҊ݅ΛΒͳ͍ͷͰ αϙʔτͰ͖ͳ͍ʂ σΠϦʔMTG ि࣍ϨϏϡʔΛಋೖ Problem Try
ɹʮΓํ͕ίϩίϩมΘΔʯ ϓϥΫςΟεͷద༻͕ٸ͗͢Δͱɺݱͷϝϯόʔ͕뱌Ͱ͖ͳ͍ • ೲಘͰ͖ΔൣғΛฉ͖ग़͢ → શһ͕ೲಘͰ͖Δ෦͔Βಋೖ • ͜ͷνʔϜʹ·ͩૣ͗ͨ͢ →
ʮͬͺΓΊ·͠ΐ͏ʯͰΓ͠ • த్ͳద༻Ώ͑ͷProblem͕ڍ͕Δ → TryͰ͞Βʹຊ֨ద༻ •ʮࠜຊͷߟ͑ํΛΓ͍ͨʯͱ͍͏ҙݟ → رऀʹରͯ͠ࢀߟਤॻͷҊ
ɹ“ݱͷৼΓฦΓ”Λجʹ্Ґ࿈ܞ Slack #kpt ʹߘ ؾ͍͙ͨ͢ڞ༗ ߘΛࢀߟʹͯ͠ ϨτϩεϖΫςΟϒ Try Λચ͍ग़͢
Ϛωδϝϯτձٞ Ͱ ্ҐʹαϚϦʔใࠂ ͦͷProblem νʔϜͰରॲՄೳ͔ʁ Yes No ࢀরʰΤεΧϨΛࢧ͑Δٕज़ - ΞδϟΠϧͳใ࿈૬ͱใྲྀ௨ʱ http://yuzutas0.hatenablog.com/entry/2017/08/10/090000 Lean Escalation ͷ࠲Έ
ɹνʔϜͱͯ͠՝ͱରቂ͢Δ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϘτϧωοΫ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ KPTΛ௨ͯ͠՝͕ු্ ʢνʔϜͷॏ՝ͱͯ͠߹ҙܗʣ ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁ ہॴ࠷ద
• શମ૾Λશ͘Βͳ͍ • શମ૾ʹΞΫηεͰ͖ͳ͍ ɹہॴ࠷దͷ༠Ҽ
͋ΒΏΔ։ൃɾӡ༻ۀͷɺ͋ΒΏΔఔʹ ͋ΒΏΔProblem͕Ϛοϐϯά͞Εͨ ཁٻཧ ཁ݅ఆٛ ઃܭ ࢼݧ ग़ՙ ӡ༻ Problem
Problem Problem Problem Problem Problem Problem Problem Problem Problem Problem Problem Problem ɹʮԿͱͳ͘ʯͷ࡞ۀͩΒ͚
Tryͷ༏ઌॱҐܾΊ૬ޓαϙʔτ͕ࠔ • ୲ऀҎ֎ʢ୲ऀࣗͰ͑͞ʣ֤ʑͷۀϑϩʔΛѲͰ͖ͳ͍ • ۀ༰ͷͲ͜ʹɺͲͷΑ͏ͳϜμɾϜϥɾϜϦ͕ੜ͡Δ͔ݟ͑ͳ͍ ɹશମ૾͕ෆಁ໌
࡞ۀ࣌ؒɾͪ࣌ؒखΓͷ࣮ଶΛચ͍ग़͢ ϜμɾϜϥɾϜϦ͕ੜ͡ΔՕॴΛಛఆ ɹόϦϡʔετϦʔϜϚοϓʢVSMʣΛ࡞ Ҿ༻ݩʮຊͷDevOpsมֵΛଅਐ͢ΔόϦϡʔετϦʔϜϚοϐϯάʯ http://gihyo.jp/dev/column/01/devops/2017/value-stream-mapping
ݟ͑ʹ͍͘෦ʹ͕ͦ͜જΉ ʹ શۀΛՄࢹԽ͢Δ͜ͱ͕େ ɹ֤ۀ͝ͱʹผͷVSMΛ࡞Δ ػೳՃͷ։ൃ γεςϜোରԠ ΧελϚʔ͔Βͷ ͍߹ΘͤରԠ ଞ෦ॺ͔Βͷ
࡞ۀґཔରԠ γεςϜอकۀ ྫɿEOSLରԠ γεςϜӡ༻ۀ ྫɿΩϟύγςΟܭଌ http://gihyo.jp/dev/column/01/devops/2017/value-stream-mapping
1. ೲಘͯ͠Β͏ • ҙࣝɾଧͪखΛઆ໌ • ࣾͰͷVSM׆༻ࣄྫΛհ 2. શһͰVSMΛ࡞ •
֤୲ऀ͕આ໌͠ͳ͕ΒۀͷྲྀΕΛॻ͘ • “ϜμɾϜϥɾϜϦ” ”ϝϯόʔؒͷೝࣝͷࠩ” ΛՄࢹԽ • ·͞ʹਐߦதͩͬͨҊ݅ͷϦεΫΛͦͷͰݕͰ͖ͨʢޭମݧʣ ɹશһࢀՃܕϫʔΫγϣοϓ͔Β࢝ΊΔ ࣮Ԛ͍Ͱ͢ʜʜ
ɹʮ߆ଋ͕࣌ؒ͗͢Δʯ ϫʔΫγϣοϓͰ શһ͕ཧղ͍͢͠ ʮػೳՃʯΛର Γ୲ऀʹ ώΞϦϯά VSMΛ࡞ ʹ՝ͷՄࢹԽ ͙͢Ͱ͖ΔՕॴ͔Β
ۀϑϩʔΛվળ վળޮՌ͕ݟ͑Δ ʹඞཁੑɾೲಘײ
ɹۀͷશମ૾ΛΔ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϘτϧωοΫ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ KPTΛ௨ͯ͠՝͕ු্ ʢνʔϜͷॏ՝ͱͯ͠߹ҙܗʣ ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁ ہॴ࠷ద
• શମ૾Λશ͘Βͳ͍ • શମ૾ʹΞΫηεͰ͖ͳ͍ ɹہॴ࠷దͷ༠Ҽ
վળ׆ಈΛ௨ͯ͠ٸܹʹϧʔϧɾϓϩηε͕ܾ·͍͕ͬͯ͘ ҙࢥܾఆͷεϐʔυʹυΩϡϝϯτԽ͕ؒʹ߹Θͳ͍ ɹʮͲ͜ΛݟΕ͔Δʁʯ ※ຊߘʹ͓͚ΔʮυΩϡϝϯτʯূɾܖతͰͳ͘ɺۀඪ४Խͷʮ࡞ۀखॱॻʯʮΠϯϑϥڥҰཡʯͱ͍ͬͨͷ
• υΩϡϝϯτԽʴߋ৽͠ଓ͚Δ͜ͱͷॏཁੑKPTͰڧௐ • ʑͷίϛϡχέʔγϣϯͰʮͥͻจॻԽ͍ͯͩ͘͠͞ʯʮߋ৽͍ͯͩ͘͠͞ʯ • ଅਐҊΛืΔ → ϝϯόʔओମͰଅਐbotνέοτӡ༻ͷࢼߦࡨޡ ɹʢҊࣗମଓ͔ͳ͔͕ͬͨϝϯόʔ͕ࣗൃతʹจॻԽ͢ΔΑ͏ʹͳͬͨʣ
ɹνʔϜશһʹਪਐऀͱͯ͠ৼͬͯΒ͏
• ϝϯόʔ͕ओମతʹจॻԽ → ผͷॴʹࣅͨυΩϡϝϯτ͕ॏෳ ɹ࣮ྫ: A͞Μ͕োΛड͚ͯϦϦʔεखॱॻΛߋ৽ → B͞ΜผͷखॱॻͰಉ͡ϛε →
C͞Μ • ໎ͬͨͱ͖ʹɺͲ͜ΛݟΕʢʹͲ͜ʹॻ͚ʣྑ͍͔͔Βͳ͍ ɹʮͲΕ͕ਖ਼͍͠ʁʯ ϦϦʔεखॱॻA "͞Μ োൃੜ ϦϦʔε࡞ۀΛ࣮ࢪ ࡞ۀ࿙ΕΛө ϦϦʔεखॱॻA ʢөࡁΈʣ ϦϦʔεखॱॻB ʢະөʣ #͞Μ "͞Μ ಉ͡ো͕ൃੜ ϦϦʔε࡞ۀΛ࣮ࢪ ࡞ۀ࿙ΕΛө ϦϦʔεखॱॻA ʢөࡁΈʣ "͞Μ ϦϦʔεखॱॻB ʢөࡁΈʣ #͞Μ ϦϦʔεखॱॻC ʢະөʣ $͞Μ ·ͨಉ͡ো͕ൃੜ ϦϦʔε࡞ۀΛ࣮ࢪ
ɹϨΨγʔυΩϡϝϯτ मਖ਼͕͍ͭޙճ͠ ԿΛॻ͚͍͍͔໎͏ Ͳ͜ʹॻ͚͍͍͔໎͏ Write ݟ͔ͭΒͳ͍ ใ͕ݹ͍ɾޡΓ ࣅͨ༰͕ࢄࡏ͍ͯ͠Δ Read
·͞ʹϨΨγʔίʔυͱಉ͡ ର͕ࣗવݴޠʢ͘͠දɾਤʣʹͳ͚ͬͨͩʂ ↓ ઃܭɾमਖ਼ͷΓํϓϩάϥϛϯάͱಉ͡Ͱʁ
ɹMVCΞʔΩςΫνϟͷద༻ ґଘؔʹج͍ͮͨυΩϡϝϯτઃܭ View ϦϦʔε࡞ۀखॱॻ ΠϯϑϥڥҰཡ JenkinsϩάΠϯใ ϦϦʔεه_201704XX Controller
Model
܁Γฦ͠ϖʔδҰׅཧ ɹIteratorύλʔϯ(GoF)ͷద༻ View ϦϦʔε࡞ۀखॱॻ ΠϯϑϥڥҰཡ JenkinsϩάΠϯใ ϦϦʔεه_201704XX Controller
Model ϦϦʔεه_201704XX ϦϦʔεه_201705XX ϦϦʔεه_201706XX
ɹDocument as Code - υΩϡϝϯτΛιʔείʔυͷΑ͏ʹѻ͏ ɹ • ϘʔΠεΧτݪଇɿ๚Εͨϝϯόʔ͕Ճචɾमਖ਼ ɹɹɹɹɹจॻΛݟΔલΑΓɺݟͨޙͷ΄͏͕៉ྷͳঢ়ଶͱͳ͍ͬͯΔͷ͕·͍͠ ɹ
• ίʔυϨϏϡʔɿߏʹΜͩΒ૬ஊ ɹɹɹɹɹʮ͜͏͍͏ҙਤͰ͜͜ʹॻ͜͏ͱࢥ͏ʂͲ͏ࢥ͏ʁʯΛ૬ஊ͢ΔSlackνϟϯωϧ ʹ ϨϏϡʔ׆ੑԽ Ͳ͜ʹͲͷυΩϡϝϯτ͕͋Δ͖͔Λ ίʔσΟϯάʹྫ͑ͯձ͢Δ ↓ ߟ͑ํ࡞ۀͷਐΊํʹͯ·Δ IUUQTQJYBCBZDPNFOMJCSBSZCPPLTNPOUFTTPSJTIFMG
• Ϣʔεέʔεੳ • ϦϑΝΫλϦϯά • ϖΞϓϩάϥϛϯά • Ϟϒϓϩάϥϛϯά •
όʔδϣϯཧ ɹυΩϡϝϯτΛίʔυͷΑ͏ʹѻ͏16ͷύλʔϯ (Document Design Pattern) • ΞʔΩςΫτνʔϜ • ίϯΣΠͷ๏ଇ ମ੍ͷύλʔϯ • ٕज़తෛ࠴ • ϙʔτϑΥϦΦ • ίʔσΟϯάΛଅ͢ • ίʔυϨϏϡʔ • ϘʔΠεΧτ • Rule of Three จԽͷύλʔϯ • MVCϞσϧ • GoFσβΠϯύλʔϯ • ܧଓతσϦόϦʔ / ΠςϨʔγϣϯ ߏͷύλʔϯ ࡞ۀͷύλʔϯ ˞ମ੍จԽσβΠϯʢઃܭʣʹӨڹΛ༩͑ΔͷͰσβΠϯύλʔϯʹؚΊ͍ͯ·͢ ࢀরʰDevOpsͱυΩϡϝϯτσβΠϯύλʔϯʱ http://yuzutas0.hatenablog.com/entry/2017/07/06/083000
ɹใͷΞΫηγϏϦςΟ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹϘτϧωοΫʁ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ ݁Ռతʹྑ͘ͳΔ෦ͳͷͰ ͷΞϓϩʔνͳ͠ ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ ࣭ྼԽ
1. എܠɾ՝ 2. վળ׆ಈ ᶃαʔϏεϨϕϧ ᶄηϨϞχʔ ᶅόϦϡʔετϦʔϜ ᶆυΩϡϝϯτ
3. ৼΓฦΓ ɹΞδΣϯμ
• ։ൃɾӡ༻νʔϜΛཱͯ͢͜ͱ • ͞ΒͳΔͷΛߏங͢Δ͜ͱ ɹϛογϣϯ
ɹDev&OpsͰੜͨ͡௧Έ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ
ɹ௧ΈΛ੍͢Δ ػೳෆશͷѱ॥ ϓϨογϟʔ → “୲ऀͷ” ઌͷ࡞ۀΛͲ͏ʹ͔͠ͳ͚Ε ޓ͍ͷࣄΛΒͳ͍ αϙʔτɾϨϏϡʔͰ͖ͳ͍ ୲ऀ͚ͩͰࣗݾ݁
ఆ֎ͷ༷ ߟྀෆͷ։ൃ ͦͷ྇͗ͷӡ༻ γεςϜোͷଟൃ ػೳՃͷԆ ਂରԠɾٳग़ࣾͷৗଶԽ “0→1” ͷ࣌ݶര ࣝܧঝͳ͖νʔϜ֦େ ͞ΒͳΔ࣭ѱԽͷݒ೦ τϥϒϧ ർฐ ہॴ࠷ద ࣭ྼԽ αʔϏεϨϕϧ ηϨϞχʔ όϦϡʔετϦʔϜ υΩϡϝϯτ
ɹάϩʔεΛ࣋ଓՄೳʹ͢Δ॥ Dev ❤ Ops “0→1” ͷ࣌ݶര νʔϜ֦େͷ४උ
ࣝͷܧঝ γεςϜো: 0.5݅/݄ʹݮগ ܰඍͳෆ۩߹: ਂٳରԠ0ʹ ҆ఆԽ ηϨϞχʔʹΑΔݕࠪͱదԠ VSM/υΩϡϝϯτʹΑΔۀܕԽ ՄࢹԽ ୲֎ϝϯόʔ͕ॿݴɾαϙʔτ ࣄલʹΛݕ→࣭༧ શମ࠷ద ঃʑʹݮΔ
ɹ৽نࢀըऀͷ @KPTͰͷձ Կ͔ฉ͍ͨΒશ෦ʮܾ·͍ͬͯͳ͍ʯ ͜ΜͳʹԿܾ·͍ͬͯͳ͍ݱॳΊͯ υΩϡϝϯταϙʔτ͕ॆ࣮͍ͯͨ͠ ͜ΜͳʹεϜʔζʹ্ཱ͕ͪΕͨݱॳΊͯ 4Q Joinϝϯόʔ 1Q
Joinϝϯόʔ
1. ૣ͍ஈ֊Ͱ༏लͳएखࣾһΛԿ໊͔ଞ෦ॺ͔ΒҾ͖ൈ͍ͨ 2. அج४ͱͨ͠ਓࡐཁ݅ = അྗ͕͋Δ͜ͱ ɹ • ఏىɾվળਪਐͰ͖Δࣗൃੑɹ͜ͷΞαΠϯਪਐΛ૿ͨ͢ΊͷଧͪखͳͷͰ ɹ
• ৬ೳԣஅࢤɹτϥϒϧԣஅՕॴͰى͖ΔͨΊʢྫɿiOSͱWebAPIΛ྆ํݟΔඞཁ͕͋Δʣ ɹ • Կ͔͠Β1ͭͷݴޠɾFWͷۀར༻ܦݧɹ1ͭεΩϧͷϕʔε͕͋ΕଞͷεΩϧֶΔͨΊ ɹ • ιʔείʔυʹ৮Εͣ͘͢Ϳ͍ͬͯΔ͜ͱɹݏͰຖιʔείʔυΛಡΈॻ͖Ͱ͖ΔमཏΛఏڙͰ͖ΔΑʂ ʮՖܗ෦ॺɾՖܗۀͰͳ͍ʯʮ্͕٧·͍ͬͯΔʯͳͲͷཧ༝Ͱ֘͢Δएखଟ͍ͩΖ͏ͱ͍͏ൃ ϝϯόʔͷҰһͱͯ͠ ॥ͷγϑτΛܦݧ Qຖͷମ੍֦େʹ߹Θͤ ͞ΒʹνʔϜΛׂ ֤νʔϜϦʔμʔͱͯ͠ ਪਐʹͳͬͯΒ͏ ɹεέʔϧʹ͚ͨਪਐ
ɹ॥Λճͨ͢Ίʹඅͨ͠ίετ ݱϝϯόʔͷίϛϡχέʔγϣϯίετΛେ෯ʹඅͨ͠ ɹ • ظతʹσϦόϦʔʹϚΠφεӨڹʢʹݟ͑Δɿલఔͷ࣭୲อͰ݁Ռతʹϓϥεʣ ɹ • ͲͷΈͪѱ॥ΛࢭΊΔͨΊʹඞཁͳίετͩͱ্Ґ৫ɾൃදऀೝ͍ࣝͯ͠Δ
εςʔΫϗϧμʔશମͱͷѲΓऑ͔ͬͨ ɹ • ঢ়گ͕ঢ়گͳͷͰʮνʔϜͷ՝ΛΓ։͘͜ͱʯʮ্Ґ৫ʹୡ͢Δ͜ͱʯ͕࠷༏ઌ ɹ • ֎͔Βͷݟ͑ํʮোΛग़ͨ͠ɾ։ൃ͕Ε͍ͯΔͷʹɺखΛࢭΊͯϫʔΫγϣοϓΛ࢝ΊΔνʔϜʯ ɹ • ݏຯΛݴΘΕͨͷ12Ͱͳ͍ → ͜ͷѹྗ͕ѱ॥ͷਅҼ → कΓखͱͯ͠ͷΤϯδχΞ෦ॺͷҙٛ ্Ґ৫ˍଞ෦ॺϝϯόʹཪͰϑΥϩʔ͍ͨͩ͘ܗͱͳͬͨ ɹ • ಛʹʮ։ൃܦݧ͋ΓʯʮϏδωε෦ʹॴଐʯͷϝϯόʔ͕؇িࡐͱͳͬͨͷ͕େ͖͍
ɹ͞ΒͳΔͷͨΊʹ Ծઆ ऩӹ Dev&Ops࠷దԽͷ༨ ྫɿνʔϜͷΫϩεϑΝϯΫγϣφϧԽ γεςϜ؍Ͱͷߏங ྫɿաͳٕज़తෛ࠴Λ༧͢ΔΈ Biz Dev
Ops ɹBizΛ౿·͑ͨ ɹ શମ࠷దԽ ɹ • γεςϜ ɹ • ϓϩηε ɹ • ࢪࡦɾཁ݅
ɹBizDevOpsʹ͚ͨऔΓΈ “෦ॺɾ৬Λ͑ͨϝτϦΫεͷڞ༗” ͱ “σʔλ׆༻จԽͷண” ࢀরʰJupyterͱBigQueryʹΑΔσʔλੳج൫ͷDevOpsʱ http://yuzutas0.hatenablog.com/entry/2017/09/12/203000 σʔλج൫
ɹϏδωεՁʹ͚ͨվળ
࠷ޙʹ
ɹProduct Growth εϐʔυײΛେࣄʹ͢Δ • രΛආ͚ͳ͕ΒલʹΓଓ͚Δͱ͍͏͜ͱ • രʹ͔ࣗΒಥͬࠐΉ͜ͱͰͳ͍ → ෛই͢Δ΄Ͳ͘ͳΔ ΤϯδχΞ͔ͩΒͦ͜ؾ͚Δ͜ͱ
• ʮ͜͜যͬͯμϝͩʂʯʮരͩʂஸೡʹਐΉͧʂʯͱ͍͏໘ • खΛಈཱ͔͢ʢ͔ͭͯखΛಈ͔ͨ͠ܦݧऀʣͰͳ͍ͱ͔Βͳ͍ • ٸϓϩμΫτͰͦͷ໘͕ͻͨ͢Βଓ͘ IUUQTXXXQFYFMTDPNQIPUPDBSFGSFFDIJMEDIJMEIPPEDPVOUSZTJEF
ɹٯઆͷΤϯδχΞϦϯά ϕετϓϥΫςΟεײత • ΫΦϦςΟΛߴΊΔͨΊʹɺଈ࣌ରԠΛݮΒ͢ • ΞδϦςΟΛߴΊΔͨΊʹɺखΛࢭΊͯ͠߹͏ ߟ͑ΔͱͨΓલͷ͜ͱ • যͬͨ··ࣄΛଓ্͚ͯख͘ߦ͘Θ͚͕ͳ͍ ɹɹ৸ෆͷૢॎ͕࢜୲͢ΔඈߦػʹΓ͍͔ͨʁɹύχοΫঢ়ଶͷ֎Պҩʹखज़͞Ε͍͔ͨʁ
ɹɹάϩʔεϑΣʔζ͔ͩΒͱ͍ͬͯѱ॥Λ์ஔ͍͍ͯ͠ཧ༝ʹͳΒͳ͍ • νʔϜʹಁ໌ੑͱݕࠪͱదԠ͕ඞཁ IUUQTXXXQFYFMTDPNQIPUPBEVMUBEWFOUVSFCBDLQBDLEBZMJHIU
ʮ͜Ε͓͔ͬͯ͘͠ͳ͍Ͱ͔͢ʁʯ ୭͔͕Λ্͛Δ͜ͱ͕ɺվળͷୈҰา ʮ͜ΕͬͯͲ͏ͳ͍ͬͯ·͔͢ʁʯ ୭͔ʹΛֻ͚Δ͜ͱ͕ɺಁ໌ੑͷୈҰา νʔϜͷҰһͷׂͰ͢ ࠓ͜͜ʹ͍ΔࢲͨͪࣗͷׂͰ͢
νʔϜͱͯ͠ϓϩηεΛվળ͠Α͏ νʔϜͱͯ͠γεςϜΛվྑ͠Α͏ νʔϜͱͯ͠ϓϩμΫτΛͤ͞Α͏
νʔϜͷ҆ఆͷ্ʹͦ͜ ܧଓతͳސ٬Ձͷఏڙ͕ ʢͦͷ݁Ռͱͯ͠Ϗδωεͷ͕ʣ ࣮ݱͰ͖Δͷͩͱࢥ͍ͬͯ·͢
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠ presented by @yuzutas0 IUUQTXXXQFYFMTDPNQIPUPDPMMFBHVFTDPPQFSBUJPOpTUCVNQpTUT
- ࢼߦࡨޡɾࣦഊࣄྫ - ࢀߟࢿྉ - Special Thanks ɹAppendix
ɹվળ͕࠷ίʔυΛॻ͍ͯ͠·ͬͨ தʹ1ਓͰίʔσΟϯά͢ΔӋʹͳͬͨ • ࠷ॳͷࠒϝϯόʔࣗͷ୲ൣғ͔͔͠Βͳ͔ͬͨ • αϒγεςϜԣஅͰઃܭɾ࣮Ͱ͖Δਓࡐ͕͍ͳ͍ঢ়ଶ എதΛݟͤΔ͜ͱͷޫͱӄ • ணૣʑʹқͷߴ͍ઃܭɾ࣮Λͬͯͷ͚͔ͨΒͦ͜ɺϝϯόʔͷ৴པΛಘͨଆ໘͋Δ •
վળʹྗΛׂ͚ͣɺਓҭͨͣɺνʔϜ͕ػೳ͠ͳ͍ʢϓϨΠϯάϚωʔδϟʔͷΞϯνύλʔϯʣ ࣗΛଅͯ͠ঃʑʹ݈શԽ • एखࣾһͷҾ͖ൈ͖ ʴ ձͷ׆ੑԽ ʴ ܧଓతͳ࡞ۀ༰ͷϑΟʔυόοΫʢि࣍ϨϏϡʔʣ
ɹBizDevOpsͷଅਐ - ૣ͗ͨ͢ࢪࡦ 1. νʔϜϏδϣϯɺΫϨυɺ։ൃKPIͷࡦఆ • Ծઆɿඪ૾ج४͕͋Εվળͷํੑ͕ݟ͑ͯϝϯόʔ͕ࣗൃతʹಈ͚Δ • ݁ՌɿϚΠφεΛθϩʹ͍ͯ͠Δ్தͳͷͰɺকདྷͷֆۭࣄɾݱ࣮ຯ͕ͳ͍៉ྷࣄ 2.
Ϗδωεߏɾঢ়گʹ͍ͭͯͷษڧձ • Ծઆɿ୲֎ͷۀͷΛฉ͘͜ͱͰBizͷછΈग़͠Λޙԡ͠Ͱ͖Δ • ݁Ռɿ໘നͦ͏͚ͩͲࠓͦΕͲ͜ΖͰͳ͍ͷͰϑϥετϨʔγϣϯ → ࠷ۙʹͳͬͯ࠶νϟϨϯδ • ʮ2าઌΛݟਾ্͑ͨͰɺ1าઌΛଅ͘͢Β͍͕ͪΐ͏Ͳ͍͍ʯ by ϝϯλʔ 7JTJPO .JTTJPO 7BMVF
ɹࢀߟࢿྉ ॻ੶ɾPDF ʰϦʔϯ։ൃͷຊ࣭ - ιϑτΤΞ։ൃʹ׆͔͢7ͭͷݪଇʱɹʰεΫϥϜΨΠυ - εΫϥϜશΨΠυ: ήʔϜͷϧʔϧʱ ʰ৫ύλʔϯ -
νʔϜͷʹΑΓΞδϟΠϧιϑτΣΞ։ൃͷมֵΛଅ͢ʱʰΤΫετϦʔϜϓϩάϥϛϯά - Embrace Changeʱ ʰΣϒΦϖϨʔγϣϯ - αΠτӡ༻ཧͷ࣮ફςΫχοΫʱʰڧ͍ձࣾ͜͏ͯ͠࡞ΒΕΔʂ - ITIL࣮ફͷమଇʱ εϥΠυ • ݁ՌతʹεΫϥϜʹͳͬͯΔʂͳͷ͕͍͍ͱࢥ͏ʂɹhttps://speakerdeck.com/bufferings/jie-guo-de-nisukuramuninatuteru-nafalsegaiitosi-u-number-rsgt2017 • ޮՌతͳࣗಇԽΛࢦ͢ʂ Value Stream Mapping ࣮ફϫʔΫγϣοϓ https://docs.com/ushio-tsuyoshi/8263 • ৽نࣄۀ͕ରቂ͢Δݱ࣮͔ΒΤϯδχΞϦϯάΛ၆ᛌ͢Δ https://www.slideshare.net/i2key/devsumib • αʔϏεϨϕϧɿઃܭͱӡ༻ͷϓϥΫςΟε http://yuzutas0.hatenablog.com/entry/2017/05/23/073000 • ΤεΧϨΛࢧ͑Δٕज़ - ΞδϟΠϧͳใ࿈૬ͱใྲྀ௨ http://yuzutas0.hatenablog.com/entry/2017/08/10/090000 • DevOpsͱυΩϡϝϯτσβΠϯύλʔϯ http://yuzutas0.hatenablog.com/entry/2017/07/06/083000 • JupyterͱBigQueryʹΑΔσʔλੳج൫ͷDevOps http://yuzutas0.hatenablog.com/entry/2017/09/12/203000 IUUQFDOJLLFJCQDPKQJUFNCPPLT1IUNM
ɹSpecial Thanks ൴Βͷ৺ڧ͍ࢧ͕͔͑͋ͬͨΒͦ͜ɺνʔϜཱͯ͠ʹઐ೦͢Δ͜ͱ͕Ͱ͖·ͨ͠ɻ ຖͷ ٽ͖ࣄ ૬ஊʹ೪Γڧ͘ରԠ͠ଓ͚ͯͩͬͨ͘͜͞ͱΛײँ͓ͯ͠Γ·͢ɻ Satoshi UejimaɹɹࢸΒͳ͔ͬͨΛཪͰϑΥϩʔ͍͖ͨͩ·ͨ͠ɻʮ͏ແཧͬ͢ʯͷʹɺ ɹɹɹɹɹɹɹɹɹ ݟ͍ۤ͠ݴ͍༁ͷ1ͭ1ͭͱஸೡʹ͖߹ͬͯ͘Εͨ࠷ߴͷ্࢘Ͱͨ͠ɻ
Itsuki KurodaɹɹɹνʔϜͷ࣮จ຺Λ౿·্͑ͨͰɺվળͷଧͪखɾਐΊํʹ͍ͭͯ ɹɹɹɹɹɹɹɹɹ ຊ࣭త͔ͭੜ࢈తͳΞυόΠεΛ͍͖ͨͩ·ͨ͠ɻ Kenichi Takahashiɹ৫໘Ͱͷ੯͠Έͳ͍όοΫΞοϓΛ௨ͯ͠ ɹɹɹɹɹɹɹɹɹ ج൫උҊ݅։ൃͷيಓ͕ΔΑ͏ʹαϙʔτ͍͖ͨͩ·ͨ͠ɻ