Slide 1

Slide 1 text

.JDSPTFSWJDFTͷ֓ཁͱద༻

Slide 2

Slide 2 text

ઈࢍɺαʔϏε։ൃΤϯδχΞืूதͰ͢ʂ

Slide 3

Slide 3 text

.JDSPTFSWJDFTͱ͸Կ͔ʁ

Slide 4

Slide 4 text

No content

Slide 5

Slide 5 text

In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. — James Lewis and Martin Fowler

Slide 6

Slide 6 text

Our main aim in writing this article is to explain the major ideas and principles of microservices. … We have recently built several systems using the style and know of others who have used and favor this approach. Those we know about who are in some way pioneering the architectural style include Amazon, Netflix, The Guardian, the UK Government Digital Service, realestate.com.au, Forward and comparethemarket.com. — James Lewis and Martin Fowler

Slide 7

Slide 7 text

ͳΜ͔ͩ஌Βͳ͍͚Ͳɺ͜Μͳײ͡ͷ͍ͬͺ͍͋Δ ˠ͡Ό໊͋લΛ෇͚ͯهड़ͯ͠ΈΑ͏ʂ

Slide 8

Slide 8 text

Banquet Cuisine Venue Banquet Cuisine Venue Banquet Cuisine Venue Load Balancer Venue Service Cuisine Service Banquete Service API Gateway Monolithic Architecture Microservices Architecture Database Database Database Database

Slide 9

Slide 9 text

αʔϏεʹΑΔίϯϙʔωϯτԽʗϏδωεέΠύϏϦςΟ ʹجͮ͘૊৫ԽʗϓϩδΣΫτͰ͸ͳ͘ϓϩμΫτʗεϚʔ τΤϯυϙΠϯτɺμϜύΠϓʗ෼ࢄΨόφϯεʗ෼ࢄσʔ λ؅ཧʗΠϯϑϥετϥΫνϟࣗಈԽʗো֐ͷͨΊͷઃܭ ʗਐԽతઃܭ .JDSPTFSWJDFTʹΈΒΕΔ۝ͭͷಛ௃

Slide 10

Slide 10 text

αʔϏεʹΑΔίϯϙʔωϯτԽ .POPMJUI"SDIJUFDUVSF Πϯϓϩηεͷϝιουݺ ͼग़͠ʢϥΠϒϥϦʣʹΑ ͬͯίϯϙʔωϯτͱͯ͠ ར༻͢Δɻ .JDSPTFSWJDFT"SDIJUFDUVSF ผϓϩηεͰಈ࡞͢Δαʔ ϏεΛωοτϫʔΫ௨৴ʹ Αͬͯίϯϙʔωϯτͱ͠ ͯར༻͢Δɻ

Slide 11

Slide 11 text

ϏδωεέΠύϏϦςΟʹجͮ͘૊৫Խ .POPMJUI"SDIJUFDUVSF ٕज़ϨΠϠʔʹج͍ͮͯν ʔϜΛ૊৫͢Δɻͦͷ݁ ՌɺΞϓϦέʔγϣϯ͸ٕ ज़ϨΠϠʔͰ෼ׂ͞ΕΔɻ .JDSPTFSWJDFT"SDIJUFDUVSF ϏδωεέΠύϏϦςΟʹ ج͍ͮͯαʔϏεΛ෼ׂ͢ ΔɻνʔϜ͸ΫϩεϑΝϯ ΫγϣφϧͱͳΔɻ

Slide 12

Slide 12 text

ϓϩδΣΫτͰ͸ͳ͘ϓϩμΫτ .POPMJUI"SDIJUFDUVSF ΞϓϦέʔγϣϯ͸ɺϓϩ δΣΫτͱͯ͠։ൃ͞Ε Δɻ׬੒ޙʹνʔϜ͸ղࢄ ͠ɺӡ༻νʔϜʹҾ͖ܧ͕ ΕΔɻ .JDSPTFSWJDFT"SDIJUFDUVSF ΞϓϦέʔγϣϯ͸ɺϓϩ μΫτͱͯ͠։ൃ͞ΕΔɻ νʔϜ͸ɺӡ༻΋ؚΊαʔ Ϗεͷ͢΂ͯʹ੹೚Λ࣋ ͭɻ

Slide 13

Slide 13 text

εϚʔτΤϯυϙΠϯτͱμϜύΠϓ .POPMJUI"SDIJUFDUVSF ૬ޓ઀ଓʹ&4#Λར༻͢ Δɻ&4#͸ϧʔςΟϯάɺ ίϨΦάϥϑΟɺτϥϯε ϑΥʔϝʔγϣϯͳͲચ࿅ ͞ΕͨػೳΛ࣋ͭɻ .JDSPTFSWJDFT"SDIJUFDUVSF ૬ޓ઀ଓʹ͸)551΍ܰྔ ϝοηʔδΩϡʔΛར༻͢ Δɻܦ࿏͸୯७ͳμϜύΠ ϓͰΤϯυϙΠϯτͷΈ͕ ػೳΛ΋ͭɻ

Slide 14

Slide 14 text

෼ࢄΨόφϯε .POPMJUI"SDIJUFDUVSF ඪ४ԽʹΑͬͯɺͻͱͭͷ ٕज़ϓϥοτϑΥʔϜʹߜ ΓࠐΉɻ .JDSPTFSWJDFT"SDIJUFDUVSF αʔϏεຖʹ࠷దͳٕज़͕ બ୒͞ΕΔɻ·ͨɺඪ४Խ Ͱ͸ͳ͘Φʔϓϯιʔεత ͳ΍Γํ͕ͱΒΕΔɻ

Slide 15

Slide 15 text

෼ࢄσʔλ؅ཧ .POPMJUI"SDIJUFDUVSF ͻͱͭͷσʔλϕʔεΛΞ ϓϦέʔγϣϯʹΘͨͬͯ ڞ༗͢ΔɻҰ؏ੑ͸σʔλ ϕʔετϥϯβΫγϣϯʹ ΑΓ୲อ͞ΕΔɻ .JDSPTFSWJDFT"SDIJUFDUVSF σʔλ͸ʮڥք͚ͮΒΕͨ ίϯςΩετʯͰ෼ׂ͞Ε Δɻ·ͨɺϙϦάϩοτӬ ଓԽϞσϧɺ݁Ռ੔߹ੑ΋ ࠾༻͞ΕΔɻ

Slide 16

Slide 16 text

ΠϯϑϥετϥΫνϟࣗಈԽ .POPMJUI"SDIJUFDUVSF ܧଓతσϦόϦ͕࣮ݱ͞Εɺ ࣗಈςετɺࣗಈσϓϩΠ ͳͲ͕࠾༻͞Ε͍ͯΔɻ .JDSPTFSWJDFT"SDIJUFDUVSF ܧଓతσϦόϦ͕࣮ݱ͞Εɺ ࣗಈςετɺࣗಈσϓϩΠ ͳͲ͕࠾༻͞Ε͍ͯΔɻ

Slide 17

Slide 17 text

ো֐ͷͨΊͷઃܭ .POPMJUI"SDIJUFDUVSF ϚΠΫϩαʔϏεʹൺ΂ͯ ෳࡶ͞͸গͳ͍ɻΠϯϓϩ ηεͷݺͼग़͠Ͱ͸ϦΞϧ λΠϜͳ؂ࢹ͸ͦΕ΄Ͳॏ ཁͰ͸ͳ͍ɻ .JDSPTFSWJDFT"SDIJUFDUVSF ΞϓϦέʔγϣϯ͸αʔϏ εͷো֐ʹ଱ੑΛ࣋ͭΑ͏ ʹઃܭ͞ΕΔɻαʔϏεؒ ݺͼग़͠ͷϦΞϧλΠϜͳ ؂ࢹ͕ॏཁͱͳΔɻ

Slide 18

Slide 18 text

ਐԽతઃܭ .POPMJUI"SDIJUFDUVSF ܭըతઃܭ͕ͱΒΕ͕ͪɻ ͲΜͳมߋ΋ϑϧϏϧυͱ શମͷσϓϩΠ͕ඞཁͱͳ Δɻ .JDSPTFSWJDFT"SDIJUFDUVSF ਐԽతઃܭ͕࠾༻͞ΕΔɻ αʔϏε෼ׂ͸มԽΛՃ଎ ͤ͞ΔͨΊͷπʔϧͱͯ͠ Έͳ͞ΕΔɻ

Slide 19

Slide 19 text

Banquet Cuisine Venue Banquet Cuisine Venue Banquet Cuisine Venue Load Balancer Venue Service Cuisine Service Banquete Service API Gateway Monolithic Architecture Microservices Architecture Database Database Database Database

Slide 20

Slide 20 text

͍ͭ.JDSPTFSWJDFTΛద༻͢΂͖͔ʁ

Slide 21

Slide 21 text

don’t even consider microservices unless you have a system that's too complex to manage as a monolith. — Martin Fowler

Slide 22

Slide 22 text

IUUQNBSUJOGPXMFSDPNCMJLJ.JDSPTFSWJDF1SFNJVNIUNM

Slide 23

Slide 23 text

͜ΕͰɺNJDSPTFSWJDFT͕෼͔ͬͨਓʁ

Slide 24

Slide 24 text

࣮͸ɺ.BSUJO'PXMFSͷهࣄ͚ͩͰ͸ɺ NJDSPTFSWJDFTͷ࣮ଶ͸෼͔Γ·ͤΜʂ

Slide 25

Slide 25 text

Banquet Cuisine Venue Banquet Cuisine Venue Banquet Cuisine Venue Load Balancer Venue Service Cuisine Service Banquete Service API Gateway Monolithic Architecture Microservices Architecture Database Database Database Database

Slide 26

Slide 26 text

Service Service Service Microservices Architecture Service Service Service Service Service

Slide 27

Slide 27 text

Service Service Service Microservices Architecture Service Service Service Service Service ೝূೝՄͲ͏͢Δͷʁ ௨৴ϓϩτίϧ͸ʁ αʔϏεσΟεΧόϦͲ͏͢Δʁ ઃఆมߋΛͲ͏؅ཧ͢Δʁ εϩοτϦϯάඞཁͩΑͶʁ Τϥʔ؂ࢹͲ͏͢Δʁ ϦΫΤετ͸࣮ࡍʹͲͷϊʔυͰॲཧ͞Εͨͷʁ ϘτϧωοΫͲ͜ʁ ϑΝϯΞ΢τͯ͠ϦΫΤετ૿͑ͯΔʁ αʔΩοτϒϨʔΧʔඞཁͩΑͶʁ ςετͲ͏͢Μͷʁ ίϯςφʁɹϋΠύʔόΠβʔʁ αʔϏεΠϯɾΞ΢τͲ͏͢Μͷʁ ৑௕ԽͲ͏͢Δʁ ฒྻϦΫΤετͲ͏͢Δʁ αʔϏεͷґଘؔ܎ͬͯʁ

Slide 28

Slide 28 text

Service Service Service Microservices Architecture Service Service Service Service Service ೝূೝՄͲ͏͢Δͷʁ ௨৴ϓϩτίϧ͸ʁ αʔϏεσΟεΧόϦͲ͏͢Δʁ ઃఆมߋΛͲ͏؅ཧ͢Δʁ εϩοτϦϯάඞཁͩΑͶʁ Τϥʔ؂ࢹͲ͏͢Δʁ ϦΫΤετ͸࣮ࡍʹͲͷϊʔυͰॲཧ͞Εͨͷʁ ϘτϧωοΫͲ͜ʁ ϑΝϯΞ΢τͯ͠ϦΫΤετ૿͑ͯΔʁ αʔΩοτϒϨʔΧʔඞཁͩΑͶʁ ςετͲ͏͢Μͷʁ ίϯςφʁɹϋΠύʔόΠβʔʁ αʔϏεΠϯɾΞ΢τͲ͏͢Μͷʁ ৑௕ԽͲ͏͢Δʁ ฒྻϦΫΤετͲ͏͢Δʁ αʔϏεͷґଘؔ܎ͬͯʁ ͦ΋ͦ΋Կʹࠔͬͯͨͷʁ

Slide 29

Slide 29 text

I am sorry to disappoint my fellow techies, but the reason we migrated to microservices had to do much more with productivity than pure technical matters. — Phil Calçado

Slide 30

Slide 30 text

ࣄྫɿ/FUqJY

Slide 31

Slide 31 text

w ಈը഑৴ͷձࣾͰ"84ͷେޱސ٬ w ΠϯλʔωοτͷଳҬͷΛ઎ΊΔ w .JDSPTFSWJDFTͷ୅දతࣄྫ w ελοΫΛ044ͱͯ͠ެ։

Slide 32

Slide 32 text

No content

Slide 33

Slide 33 text

ڞ௨ϥϯλΠϜαʔϏεͱϥΠϒϥϦʔ ŠŠϚΠΫϩαʔϏεΛՃ଎͢ΔϥϯλΠϜίϯςφʔͱϥΠϒϥϦʔɺαʔϏεɻ Ϋϥ΢υϓϥοτϑΥʔϜ͸ɺ/FUqJYͷେ෦෼Λ઎ΊΔαʔϏε܈ͷجૅͰ͋ΓɺςΫϊϩδʔελοΫͰ͢ɻ Ϋϥ΢υϓϥοτϑΥʔϜ͸ɺΫϥ΢υαʔϏε΍ΞϓϦέʔγϣϯϥΠϒϥϦɺΞϓϦέʔγϣϯίϯς φ͔Βߏ੒͞Ε·͢ɻಛʹϓϥοτϑΥʔϜʹΑͬͯɺ&VSFLBʹΑΔαʔϏεσΟεΧόϦɺ"SDIBJVTʹΑΔ ෼ࢄઃఆ؅ཧɺ3JCCPOʹΑΔϨδϦΤϯεͰΠϯςϦδΣϯτͳϓϩηεʗαʔϏεؒ௨৴ͳͲ͕ɺఏڙ͞ Ε·͢ɻ୯ҰͷαʔϏεݺͼग़͠ʹͱͲ·Βͳ͍৴པੑΛఏڙ͢ΔͨΊʹɺ)ZTUSJYʹΑͬͯϥϯλΠϜͰಠ ཱͨ͠଱ϨΠςϯγͱ଱ো֐ੑ͕ఏڙ͞Ε·͢ɻ͜ΕΒͷϥΠϒϥϦʔ΍αʔϏε͸ɺ+7.ϕʔείϯςφͰ ͋Ε͹ͲͷΑ͏ͳ؀ڥͰ΋ಈ࡞͠·͢ɻ ·ͨɺϓϥοτϑΥʔϜ͸+7.ίϯςφαʔϏεΛɺ,BSZPOͱ(PWFSOBUPSɺඇ+BWBϥϯλΠϜ؀ڥ޲͚ʹ͸ 1SBOBαΠυΧʔʹΑΓɺఏڙ͠·͢ɻ1SBOB͕Πϯελϯε಺ͰϓϩΩγػೳΛఏڙ͢Δͷʹର͠ɺ;VVM ʢ)ZTUSJYͱ&VSFLBɺ3JCCPOͷϓϩηεؒ௨৴ػೳΛ౷߹͢Δ΋ͷʣ͸ɺΫϥ΢υ؀ڥͷڥքʹ͓͚Δಈతʹ εΫϦϓτʹΑ੍ͬͯޚՄೳͳϓϩΩγΛఏڙ͠·͢ɻ

Slide 34

Slide 34 text

ύϧεͷϑΝϧγͷϧγ͕ύʔδͰ ίΫʔϯʘ ?P? ʗ

Slide 35

Slide 35 text

ڞ௨ϥϯλΠϜαʔϏεͱϥΠϒϥϦʔ ŠŠϚΠΫϩαʔϏεΛՃ଎͢ΔϥϯλΠϜίϯςφʔͱϥΠϒϥϦʔɺαʔϏεɻ Ϋϥ΢υϓϥοτϑΥʔϜ͸ɺ/FUqJYͷେ෦෼Λ઎ΊΔαʔϏε܈ͷجૅͰ͋ΓɺςΫϊϩδʔελοΫͰ͢ɻ Ϋϥ΢υϓϥοτϑΥʔϜ͸ɺΫϥ΢υαʔϏε΍ΞϓϦέʔγϣϯϥΠϒϥϦɺΞϓϦέʔγϣϯίϯς φ͔Βߏ੒͞Ε·͢ɻಛʹϓϥοτϑΥʔϜʹΑͬͯɺ&VSFLBʹΑΔαʔϏεσΟεΧόϦɺ"SDIBJVTʹΑΔ ෼ࢄઃఆ؅ཧɺ3JCCPOʹΑΔϨδϦΤϯεͰΠϯςϦδΣϯτͳϓϩηεʗαʔϏεؒ௨৴ͳͲ͕ɺఏڙ͞ Ε·͢ɻ୯ҰͷαʔϏεݺͼग़͠ʹͱͲ·Βͳ͍৴པੑΛఏڙ͢ΔͨΊʹɺ)ZTUSJYʹΑͬͯϥϯλΠϜͰಠ ཱͨ͠଱ϨΠςϯγͱ଱ো֐ੑ͕ఏڙ͞Ε·͢ɻ͜ΕΒͷϥΠϒϥϦʔ΍αʔϏε͸ɺ+7.ϕʔείϯςφͰ ͋Ε͹ͲͷΑ͏ͳ؀ڥͰ΋ಈ࡞͠·͢ɻ ·ͨɺϓϥοτϑΥʔϜ͸+7.ίϯςφαʔϏεΛɺ,BSZPOͱ(PWFSOBUPSɺඇ+BWBϥϯλΠϜ؀ڥ޲͚ʹ͸ 1SBOBαΠυΧʔʹΑΓɺఏڙ͠·͢ɻ1SBOB͕Πϯελϯε಺ͰϓϩΩγػೳΛఏڙ͢Δͷʹର͠ɺ;VVM ʢ)ZTUSJYͱ&VSFLBɺ3JCCPOͷϓϩηεؒ௨৴ػೳΛ౷߹͢Δ΋ͷʣ͸ɺΫϥ΢υ؀ڥͷڥքʹ͓͚Δಈతʹ εΫϦϓτʹΑ੍ͬͯޚՄೳͳϓϩΩγΛఏڙ͠·͢ɻ

Slide 36

Slide 36 text

ରԠσόΠε͕ଟ͘ɺϝϞϦ͕ݶΒΕͨσόΠε ΋͋Δɻ·ͨɺϞόΠϧར༻΋૝ఆͯ͠ɺ௨৴ճ ਺ΛݮΒ͍ͨ͠ɻ

Slide 37

Slide 37 text

ΫϥΠΞϯτ 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε 3FTPVSDFCBTFE"1* ΫϥΠΞϯτ͕ϦιʔεΛऩूɾ ੔ܗͯ͠දࣔ

Slide 38

Slide 38 text

ΫϥΠΞϯτ 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε "1*(BUFXBZ &YQFSJFODFCBTFE"1* ;VVMΫϥ΢υ؀ڥͷڥքʹ͓͚Δಈతʹ εΫϦϓτʹΑ੍ͬͯޚՄೳͳϓϩΩγ "1*(BUFXBZ͕ϦιʔεΛऩूɾ ੔ܗɺΫϥΠΞϯτ͕දࣔ

Slide 39

Slide 39 text

Ұ෦ͷαʔϏεͷো֐Λશମʹ೾ٴͤ͞Δ͜ͱͳ͘ αʔϏεશମͷϨδϦΤϯεΛߴΊ͍ͨɻ

Slide 40

Slide 40 text

ΫϥΠΞϯτ 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε "1*(BUFXBZ ͻͱͭͷαʔϏεʹো֐͕͋Δͱ શମͷαʔϏε͕ো֐ͱͳΔ Մ༻ੑͷαʔϏε͕ݸ ʹˠ ʹສϦΫΤετˠສΤϥʔ

Slide 41

Slide 41 text

ΫϥΠΞϯτ 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε 3&45GVM"1* Ϧιʔε "1*(BUFXBZ )ZTUSJY଱ϨΠςϯγͱ଱ো֐ੑ αʔϏεϨϕϧͷάϨʔεϑϧɾ σάϨʔγϣϯΛ࣮ݱ ϑΣΠϧϑΝετʗϑΣΠϧαΠϨϯτʗϑΥʔϧ όοΫɺαʔΩοτϒϨʔΧʔ

Slide 42

Slide 42 text

αʔϏε਺͕૿͑ΔʹͭΕͯ ಺෦ϩʔυόϥϯαʔͷ؅ཧ͕ࠔ೉ʹͳΔ

Slide 43

Slide 43 text

ϩʔυόϥϯα "1*(BUFXBZ αʔϏε ϊʔυ αʔϏε ϊʔυ αʔϏε ϊʔυ αʔϏεͷ਺͚ͩ಺෦ϩʔυόϥϯαΛ؅ཧ͢Δ
 ඞཁ͕͋Δ ಺෦ϩʔυόϥϯα

Slide 44

Slide 44 text

"1*(BUFXBZ αʔϏε ϊʔυ αʔϏε ϊʔυ αʔϏε ϊʔυ 3JCCPOΫϥΠΞϯταΠυϩʔυόϥ ϯγϯάʹΑΔϨδϦΤϯεͰΠϯςϦ δΣϯτͳϓϩηεʗαʔϏεؒ௨৴ ΫϥΠΞϯταΠυ
 ϩʔυόϥϯγϯά

Slide 45

Slide 45 text

ϊʔυΛ௥Ճ͢Δ͚ͩͰαʔϏεΛ εέʔϧͰ͖ΔΑ͏ʹ͢Δ

Slide 46

Slide 46 text

&VSFLBαʔϏεσΟεΧόϦʹΑΔ
 ಈతͳϊʔυͷొ࿥ͱཁٻ "1*(BUFXBZ αʔϏε ϊʔυ αʔϏε ϨδετϦ ొ࿥ Ұཡ αʔϏεϨδετϦʹΑΔ
 σΟεΧόϦ

Slide 47

Slide 47 text

,BSZPOαʔϏεϨδετϦ΁ͷొ࿥ͳͲΛ
 ఏڙ͢Δ+7.ίϯςφαʔϏε αʔϏε ϨδετϦ ొ࿥ ϔϧενΣοΫ ίϯςφαʔϏε ΞϓϦέʔγϣϯ ίϯςφαʔϏεͷಋೖ

Slide 48

Slide 48 text

1SBOBαΠυΧʔύλʔϯ ʹΑΓଞαʔϏεϊʔυʹ ରͯ͠Πϯελϯε಺Ͱϓ ϩΩγػೳΛఏڙ αʔϏε ϨδετϦ 1SBOB BQQSC αʔϏε ϊʔυ αʔϏε ϊʔυ ϦΫΤετ ϦΫΤετ ొ࿥ ϔϧενΣοΫ ϦΫΤετ ϔϧε νΣοΫ αΠυΧʔύλʔϯ

Slide 49

Slide 49 text

;VVM 3JCCPO)ZTUSJY &VSFLB ,BSZPO 1SBOB ϦΫΤετ ΫϥΠΞϯτ ΞϓϦέʔγϣϯ "1*(BUFXBZ αʔϏε ϨδετϦ Ϩεϙϯε ొ࿥ ϦΫΤετ Ұཡ Ϩεϙϯε ΞϓϦέʔγϣϯ ίϯςφαʔϏε ΞϓϦέʔγϣϯ ίϯςφαʔϏε ϩʔυόϥϯγϯάʴ ଱ϨΠςϯγɾ଱ো֐ϨΠϠʔ ϦΫΤετͷͳ͕Ε

Slide 50

Slide 50 text

ࣄྫɿ$PPLQBE

Slide 51

Slide 51 text

w ϨγϐαΠτͰ"84ͷސ٬ w ʙ୅ঁੑͷ΄ͱΜͲ͕ར༻ w ࠃ಺Ͱ͸3VCZPO3BJMTͷ୅දతࣄྫ w ελοΫΛ044ͱͯ͠ެ։

Slide 52

Slide 52 text

No content

Slide 53

Slide 53 text

w ࣄۀྖҬ͕֦େ͠αʔϏε͕૿͑ΔʹͭΕͯɺ σʔλ࿈ܞͷχʔζ͕ߴ·͖ͬͯͨ w ϞόΠϧΞϓϦͷ୆಄ʹΑͬͯϞόΠϧϑΝʔ ετΛલఏͱͨ͠։ൃʢʹ"1*લఏʣ͕ॏཁʹ ͳ͖ͬͯͨ

Slide 54

Slide 54 text

w ෳ਺αϒγεςϜؒͰͷίʔυͷڞ༗ʹΑΓί ʔυϕʔε͕ڊେʹͳΓɺશମ͕೺ѲͰ͖ͳ͍ w ܧଓతΠϯςάϨʔγϣϯͰ෼ؒϏϧυΛक ΔͨΊʹଟେͳίετ͕͔͔Δ w Ұ෦ػೳͷͨΊʹશମͷσϓϩΠϝϯτ͕Ͱ͖ ͳ͔ͬͨΓɺϩʔϧόοΫ͢Δඞཁ͕ൃੜ͢Δ

Slide 55

Slide 55 text

.POPMJUIJDBSDIJUFDUVSFͷ΋ͱͷෳࡶੑͷݶք ˠ.JDSPTFSWJDFTBSDIJUFDUVSF΁ͷ଩औΓ

Slide 56

Slide 56 text

͍͔ʹͯ͠"1*Λఏڙ͢Δ͔ʁ ˠ3&45GVM)ZQFSNFEJB"1*ͷಋೖ

Slide 57

Slide 57 text

(BSBHF w )"5&0"4ʹݱ࣮తͳϨϕϧͰରԠ w 3VCZPO3BJMTʹϦιʔεͷ֓೦Λಋೖ͢Δ
 ʹઃܭࢥ૝ɾγϦΞϥΠθʔγϣϯܗࣜͷ౷Ұ w 0"VUIͱ౷߹͞ΕͨΞΫηε੍ޚ w ಉ͡ΫϥΠΞϯτϥΠϒϥϦ͕ར༻Մೳ

Slide 58

Slide 58 text

࣮ࡍʹ"1*࿈ܞͯ͠ΈΔͱʜʜ w Ұ෦ͷαʔϏεো֐͕શମʹ೾ٴͯ͠͠·͏ w αʔϏεؒ௨৴͕஗͍ ˠΫϥΠΞϯτʹ଱ো֐ੑɺ଱ϨΠςϯγʔ͕ඞཁ ˠΫϥΠΞϯτʹฒྻϦΫΤετػೳ͕ඞཁ

Slide 59

Slide 59 text

&YQFEJUPS w /FUqJYͷIZTUSJYΛΠϯεύΠΞ w ඇಉظ࣮ߦɺϑΥʔϧόοΫɺλΠϜΞ΢τɺ ϦτϥΠɺεϨουϓʔϧɺαʔΩοτϒϨΠ ΧʔͳͲΛ࣮૷

Slide 60

Slide 60 text

ϩʔυόϥϯαʔʢ&-#ʣΛར༻͍͕ͯͨ͠ʜʜ w αʔϏεͷ਺͚ͩ಺෦ϩʔυόϥϯαʔ͕ඞཁͱ ͳΓɺ؅ཧίετ͕૿େ͢Δ w શମͷαʔϏεϨϕϧ͕&-#ʹґଘͯ͠͠·͏ ˠ&-#͔ΒΫϥΠΞϯταΠυϩʔυόϥϯγϯά΁

Slide 61

Slide 61 text

Load Balancer ELB Service Service Client ELB Service Service

Slide 62

Slide 62 text

Client-side Load Balancing Client HAProxy Service HAProxy Service HAProxy Service HAProxy Service HAProxy

Slide 63

Slide 63 text

ΫϥΠΞϯτϩʔυόϥϯγϯάΛಋೖ͕ͨ͠ʜʜ w αʔϏεϊʔυͷ௥Ճ࣌ʹશϊʔυͷ)"1SPYZͷ ઃఆΛมߋ͢Δඞཁ͕͋Δ ˠ෼ࢄઃఆ؅ཧͷಋೖ

Slide 64

Slide 64 text

෼ࢄઃఆ؅ཧ w FUDE ʜઃఆ৘ใ؅ཧͷͨΊͷσʔϞϯ w FUDWBVMUʜಁաతͳ҉߸ԽΛఏڙ w FUDFOW ʜEPUFOWɺEPDLFSFOWϑΝΠϧʹରԠ

Slide 65

Slide 65 text

αʔϏεΛؾܰʹ௥ՃͰ͖ΔΑ͏ʹͳ͕ͬͨʜʜ w αʔϏε͝ͱɺεςʔδ͝ͱʢ։ൃɾςετɾε ςʔδϯάɾϓϩμΫγϣϯɾόονʣͷ؀ڥߏ ங͕൥ࡶʹͳͬͯ͠·͏ ˠ%PDLFSίϯςφʔͷར༻֦େ

Slide 66

Slide 66 text

؀ڥߏங͸ίϯςφʔԽ͞Ε͕ͨʜʜ w αʔϏεؒ࿈ܞͷςετ͕೉͍͠ w ϞοΫΛར༻͢ΔͱαʔόαΠυͷมߋʹؾ෇͘ ͜ͱ͕Ͱ͖ͣʹࣦഊ͢Δ ˠ3BDL7$3ͷಋೖ

Slide 67

Slide 67 text

3BDL7$3 w 7$3͸ϦΫΤετϞοΫ༻ϥΠϒϥϦ w αʔόαΠυ͕ΫϥΠΞϯτʹ͔ͭΘ͍ͤͨσʔ λΛੜ੒͓ͯ͘͠ w ΫϥΠΞϯταΠυ͸ςετલʹςετσʔλΛ μ΢ϯϩʔυ͔ͯ͠ΒςετΛ࣮ߦ

Slide 68

Slide 68 text

.JDSPTFSWJDFTద༻ͷϙΠϯτ

Slide 69

Slide 69 text

αʔϏεʹΑΔίϯϙʔωϯτԽʗϏδωεέΠύϏϦςΟ ʹجͮ͘૊৫ԽʗϓϩδΣΫτͰ͸ͳ͘ϓϩμΫτʗεϚʔ τΤϯυϙΠϯτɺμϜύΠϓʗ෼ࢄΨόφϯεʗ෼ࢄσʔ λ؅ཧʗΠϯϑϥετϥΫνϟࣗಈԽʗো֐ͷͨΊͷઃܭ ʗਐԽతઃܭ .JDSPTFSWJDFTʹΈΒΕΔ۝ͭͷಛ௃

Slide 70

Slide 70 text

Service Service Service Microservices Architecture Service Service Service Service Service ೝূೝՄͲ͏͢Δͷʁ ௨৴ϓϩτίϧ͸ʁ αʔϏεσΟεΧόϦͲ͏͢Δʁ ઃఆมߋΛͲ͏؅ཧ͢Δʁ εϩοτϦϯάඞཁͩΑͶʁ Τϥʔ؂ࢹͲ͏͢Δʁ ϦΫΤετ͸࣮ࡍʹͲͷϊʔυͰॲཧ͞Εͨͷʁ ϘτϧωοΫͲ͜ʁ ϑΝϯΞ΢τͯ͠ϦΫΤετ૿͑ͯΔʁ αʔΩοτϒϨʔΧʔඞཁͩΑͶʁ ςετͲ͏͢Μͷʁ ίϯςφʁɹϋΠύʔόΠβʔʁ αʔϏεΠϯɾΞ΢τͲ͏͢Μͷʁ ৑௕ԽͲ͏͢Δʁ ฒྻϦΫΤετͲ͏͢Δʁ αʔϏεͷґଘؔ܎ͬͯʁ

Slide 71

Slide 71 text

w ઌୡͨͪͷ஌ݟΛ׆༻͢Δ w ·͡Ίʹٕज़తͳ͜ͱʹऔΓ૊Ή w ʢ΋͘͠͸ɺ"84͕Կͱ͔͢ΔͷΛ଴ͭʣ

Slide 72

Slide 72 text

ઈࢍɺαʔϏε։ൃΤϯδχΞืूதͰ͢ʂ