Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Envoy externals and ideas (builderscon 2018)

Yosuke Tomita
September 06, 2018

Envoy externals and ideas (builderscon 2018)

builderscon 2018での発表資料になります。
資料からのリンクは以下にまとまっています。
https://qiita.com/seikoudoku2000/items/62aabc1dc28062d195ad

Yosuke Tomita

September 06, 2018
Tweet

Other Decks in Technology

Transcript

  1. Envoy externals and ideas
    builderscon 2018
    ෌ాཅհ

    View Slide

  2. © ChatWork
    ࣗݾ঺հ
    ▸ ෌ాཅհ (@seikoudoku2000)
    ▸ “Dev”͔Β”Ops” ΁ (྆ํͷؾ͕࣋ͪ෼͔Δͭ΋Γ)
    ▸ Navitime (ϩάղੳνʔϜ / ࣾ಺ڞ௨APIͷ։ൃ)
    ▸ Gengo (όοΫΤϯυ։ൃ / AWS, chef, Postgresql)
    ▸ ChatWork (ΠϯϑϥϚωδϝϯτ෦ → SRE෦)
    ▸ ࠷ۙͷςʔϚɿ૊৫ͰγεςϜΛ”͍͍ײ͡”ʹ։ൃɾӡ༻͍ͨ͠

    View Slide

  3. © ChatWork
    EnvoyͷଘࡏΛ஌Δ

    View Slide

  4. © ChatWork
    ౓؊Λൈ͔Εͨ
    ▸ Microservices ͷ՝୊ʹιϑτ΢ΣΞΛॻ͍ͯਅͬ޲͔Βཱͪ޲͔͏
    ▸ ୯ͳΔPoCͰ͸ͳ͘ɺ͕ͬͭΓಋೖ͢Δॴ·Ͱ΍Γ੾Δ
    ▸ > 100 service / > 10,000 hosts / All service to service traffic
    ▸ ൃ૝͕ҧ͍͗͢Δ / ΋ͷੌ͍Ϩϕϧࠩ…
    ▸ e.g. ELB/ALB ࢖ΘͣɺόϥϯαʔΛࣗલͰ࣮૷ʂʁ
    ▸ ϨϕϧࠩΛײ͡ΕΔΑ͏ʹͳͬͨ…? / ϛυϧ΢ΣΞ։ൃ΁ͷڵຯ

    View Slide

  5. © ChatWork
    ࠓ೔ͷ໨ඪ
    ɾEnvoy ੌ͍ʂ͍ͬͯ͏ײಈͷڞ༗
    ɾDev / OpsΛ໰Θͣʹɺࣗ෼ͷ૊৫΍
    γεςϜͷڥքઢΛߟ͑Δ͖͔͚ͬʹ

    View Slide

  6. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍
    ▸ Envoyͱ͍͏”ΞΠσΞ”
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  7. © ChatWork
    ࠓ೔࿩͞(ͤ)ͳ͍͜ͱ
    ▸ Envoy deep dive / ࡉ͔ͳ༻ޠఆٛ
    ▸ Matt͞ΜͷൃදΛฉ͜͏
    ▸ ChatWorkʹ͓͚Δಋೖࣄྫ
    ▸ It’s a loooong way…
    ▸ ຊ৔LyftͷൃදɺcookpadͷൃදΛฉ͜͏

    View Slide

  8. © ChatWork
    ૝ఆλʔήοτ
    ▸ ΤϯδχΞશൠʂ

    View Slide

  9. © ChatWork

    View Slide

  10. © ChatWork
    “͍͍ײ͡” ʹ։ൃɾӡ༻͢Δͱ͸ʁ

    View Slide

  11. © ChatWork
    “͍͍ײ͡”ʁ
    ▸ ੹೚ͱݖݶ͕ద੾ʹ෼ׂ͞Ε͍ͯΔ / ద੾ͳڥքઢ͕͋Δ
    ▸ ࣗ෼ͷέπΛࣗ෼Ͱ࣋ͬͯνϟϨϯδͰ͖Δ / εϐʔυײ
    ▸ ਓͷέπΛ࣋ͭͷ΋ҧ͏ / ݖҖతʹͳΒͳ͍(ͳΓͨ͘ͳ͍)
    ▸ ໎ͬͨΒ݈શͳํ by mirakui͞Μ
    ▸ devops, 2 pizza rule, microservices

    View Slide

  12. © ChatWork

    View Slide

  13. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ
    ▸ Envoyͱ͍͏”ΞΠσΞ”
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ / ϜζΧγϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  14. ▸ $MPVE5SFOETCZ"ESJBO$PDLDSPGU
    ▸ l*U`TTUJMMBQSPCMFNCVUBOFBTJFS
    QSPCMFNUPTPMWFz
    ▸ &BTJFSQSPCMFNʹͳΒͳ͍ͳΒߟ͑ͳͯ͘
    ྑ͍ ʁ

    ▸ αʔϏε͕ͲΜͲΜେ͖͘ͳ͍ͬͯ͘ͳΒɺ
    ͍ͣΕඞཁʹͳΔɺͱ͍͏લఏͰ࿩ΛਐΊ
    ͍͖ͯ·͢
    © ChatWork
    Microservicesඞཁʁ

    View Slide

  15. © ChatWork
    Microservicesͷಛ௃
    ▸ Fault Tolerant / Resilient
    ▸ Ͳ͔͜མͪͯ΋શ෦͸མͪͳ͍Αʂ
    ▸ Կ͔͋ͬͯ΋͍͍ײ͡ʹճ෮͍ͯ͘͠Αʂ
    ▸ Autonomy
    ▸ ֤αʔϏε͸খ͍͞ͷͰࣗ཯తʹͲΜͲΜಈ͚ΔΑʂ

    View Slide

  16. © ChatWork
    Microservices

    View Slide

  17. © ChatWork
    Fault Tolerant
    Ͳ͔͜ͷαʔϏε͕ෆௐʹͳͬͯ
    ΋ɺӨڹൣғ͸ִ཭͞Ε͍ͯΔ

    View Slide

  18. © ChatWork
    Resilient
    ͕࣌ؒܦͭͱ෮چ (ԿΒ͔ͷ࢓૊Έɺ
    ࡞ΓࠐΈ͸ඞཁ)

    View Slide

  19. © ChatWork
    Autonomy
    ֤αʔϏε͸ಠཱ͓ͯ͠Γɺ
    αʔϏεؒͷInterface͚ͩఆٛ͠ɺ
    ͦͷதͰࣗ཯తʹࣗ༝ʹਐԽ

    View Slide

  20. © ChatWork
    ͱݴΘΕ͍ͯΔ͕ɺɺɺ

    View Slide

  21. © ChatWork
    MicroservicesͬΆ͍΍ͭ
    ▸ Vulnerable (Distributed SPOF by Sam Newman)
    ▸ Ͳ͔͜མͪΔͱશ෦མͪΔʂ
    ▸ ऑ఺͋ͬͨΒΨϯΨϯ߈ΊࠐΜͰඃ֐֦େʂ
    ▸ Unhealthy dependency
    ▸ “ͳ͔ͥ”ܨ͕Βͳ͍
    ▸ Կ͕ى͖ͯΔ͔Α͘෼͔Βͣʹٙ৺҉َʹɻɻ

    View Slide

  22. © ChatWork
    Vulnerable

    View Slide

  23. © ChatWork
    Vulnerable

    View Slide

  24. © ChatWork
    Vulnerable

    View Slide

  25. © ChatWork
    (MicroservicesʹݶΒͳ͍)

    View Slide

  26. © ChatWork

    View Slide

  27. © ChatWork

    View Slide

  28. © ChatWork
    ґଘαʔϏεͷSLA͕શ෦99.9%ͱ͢Δͱɺ
    (0.999)^6 ≒ 99.4% → 1೔8෼ɺ݄ʹ4࣌ؒ20෼ͷμ΢ϯ
    Microservices શମͱͯ͠͸αʔϏε਺ͷྦྷ৐ͱͳΔ

    View Slide

  29. © ChatWork
    Unhealthy dependency
    ͜͜ͷ΍ΓऔΓͰΤϥʔ͕ग़ͨɻ

    View Slide

  30. © ChatWork
    Unhealthy dependency
    Կ͔Α͘෼͔Γ
    ·ͤΜ͕ɺϨεϙϯεฦͬͯ
    ͜ͳͯ͘ΤϥʔʹͳͬͨΜͰௐ
    ΂͍ͯͩ͘͞ʙ
    Τϥʔग़ͯͳ͍͠ɺΦϨΒ
    ͷ͍ͤ͡Όͳ͍Αɻ“Πϯϑϥ”
    ͷ͍ͤͰ͠ΐ

    View Slide

  31. © ChatWork
    Unhealthy dependency
    ▸ શମΛ೺ѲͰ͖ͳ͍ / ϒϥοΫϘοΫεͷ෦෼͕͋Δ
    ▸ શମ͕ݟ౉ͤΔΑ͏ͳϩάج൫/μογϡϘʔυ͕͋Δͱ͍͍͕ɺɺ
    ▸ ͓ޓ͍ͷڥքͰकΔ΂͖ϧʔϧ͕ᐆດ
    ▸ શͯΛ਺஋ԽͰ͖ͳ͍ͱఆٛͰ͖ͳ͍
    ▸ 1ݸͷΤϥʔͰ΋ௐ΂Δʁ 5ݸʁ10ݸʁ

    View Slide

  32. ▸ #VJMEJOH.JDSPTFSWJDFT
    ▸ 1SPEVDUJPO3FBEZ.JDSPTFSWJDFT
    ▸ #VJMEJOH'BVMU5PMFSBOU.JDSPTFSWJDFT
    ▸ RJJUB·ͱΊ CZࢲ

    © ChatWork
    Microservices࣮૷/ӡ༻ϊ΢ϋ΢

    View Slide

  33. © ChatWork
    Microservices࣮૷/ӡ༻keyword
    ▸ timeout
    ▸ ઃఆͳ͠/௕͗ͩ͢ͱɺ͙͢ʹThread pool৯͍ͭͿ͢ͷͰઃఆ͢Δ
    ▸ (࠷ద஋͸৬ਓͷצ…ʁ)
    ▸ circuit breakers
    ▸ ͓͔͘͠ͳͬͨαʔϏε΁ͷΞΫηε͸Ұ୴ࢭΊΔ
    ▸ ෮چޙɺաෛՙঢ়ଶʹ͍ؕΔ͜ͱͰͷඃ֐ͷ֦େΛ๷͙

    View Slide

  34. © ChatWork
    Microservices࣮૷/ӡ༻keyword
    ▸ bulkheads
    ▸ Thread poolΛݺͼग़͠αʔϏε͝ͱʹ෼͚Δ
    ▸ ̍ͭͷαʔϏεݺͼग़͠ͰThread poolΛ࢖͍੾ΔͷΛ๷͙
    ▸ monitoring / obserbavility
    ▸ Կ͕ى͖ͯΔ͔ͪΌΜͱ෼͔ΔΑ͏ʹ͢Δ

    View Slide

  35. © ChatWork
    ͦΜͳ೉͘͠ͳ͘ͳ͍ʁ

    View Slide

  36. © ChatWork
    ৭Μͳݴޠ / ϑϨʔϜϫʔΫ
    ֤αʔϏε͸ࣗ཯తͳͷͰɺ޷͖ͳݴޠ/
    ޷͖ͳϑϨʔϜϫʔΫΛબ୒͍ͨ͠

    View Slide

  37. © ChatWork
    ৭ΜͳϥΠϒϥϦ

    View Slide

  38. © ChatWork

    View Slide

  39. © ChatWork

    View Slide

  40. ୭͕ରԠ/୲อ͢Δʁ
    ֤αʔϏεͷDev͕ػೳ։ൃ
    ͷεϐʔυΛམͱͯ͠ɺ“໓ଟʹى͖ͳ͍”
    ͜ͱʹରͯ͠උ͑Δʁ
    Ops͕શݴޠɺશϥΠϒϥϦͷରԠΛ
    ߦ͍ɺϝϯς͠ଓ͚Δɺɺɺʁ

    View Slide

  41. © ChatWork
    Observability

    View Slide

  42. © ChatWork
    Ұ؀ͨ͠τϨʔγϯά͕ࠔ೉

    View Slide

  43. © ChatWork
    Microservicesͷπϥϛ
    ▸ ֤ϊ΢ϋ΢ͷ1ͭ1ͭ͸೉͍֓͠೦Ͱ͸ͳ͍͕ɺશͯͷ࣮૷ݴޠ / ϥΠϒϥ
    ϦͰશͯͷ௨৴ʹڧ੍͠ɺߋ৽͠ଓ͚Δͷ͸૬౰ʹେม
    ▸ ো֐͕ى͖ͯॳΊͯؾͮ͘͜ͱ͕ଟ͍
    ▸ ڥքઢͷ໰୊
    ▸ શମͱͯ͠ͷ҆ఆੑ (Ops) ͕ɺ֤αʔϏεͷ࣮૷(Dev)ʹڧ͘ґଘ
    ▸ Dev͕ػೳ։ൃͷεϐʔυΛ஗Ίͯ·Ͱίετ͔͚ͯରԠʁ
    ▸ OpsͰશαʔϏε΍ΕͬͯݴΘΕͯ΋ݫ͍͠

    View Slide

  44. © ChatWork
    Microservicesͷπϥϛ
    ▸ ௨৴ܦ࿏͕૿͑Ε͹૿͑Δ΄Ͳɺো֐ൃੜ࣌ͷσόοά͕೉͘͠ͳΔ
    ▸ Load Balancer΍৭ʑͳϛυϧ΢ΣΞΛ௨ա͍ͯ͘͠
    ▸ IaaS͕ఏڙ͢ΔBalancer(e.g. ALB / ELB) ʹؔͯ͠͸ɺݶΒΕͨϩά͠
    ͔ݟΕͳ͍

    View Slide

  45. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ”
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  46. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  47. © ChatWork

    View Slide

  48. © ChatWork
    rٶຊໜ
    “ΞΠσΞͱ͍͏ͷ͸ෳ਺ͷ໰୊ΛҰؾʹղܾ͢Δ΋ͷͰ͋Δ”

    View Slide

  49. © ChatWork

    View Slide

  50. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ / ϜζΧγϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  51. © ChatWork
    Envoy
    The network should be transparent to applications.
    When network and application problems do occur ,
    it should be easy to determine the source of the problem.

    View Slide

  52. © ChatWork
    Microservices

    View Slide

  53. © ChatWork
    1ͭͷαʔϏε಺Ͱ΋

    View Slide

  54. © ChatWork
    Dev͸ػೳ։ൃʹूத
    microservicesͷ҆ఆੑʹؔΘΔ
    ͱ͜Ζ͸Ops͕EnvoyͰҰݩ؅ཧ
    Envoy͕service୯ମͱmicroservicesͷ
    ҆ఆӡ༻ͷ”ڥքઢ”ͱͳΔ

    View Slide

  55. © ChatWork
    Envoyͷkeyword
    ▸ Service Mesh
    ▸ Sidecar ύλʔϯ
    ▸ Control plane ͱ Data plane
    ▸ Service mesh data plane vs. control plane
    ▸ ݴ༿͕ࠞಉ͞Ε͍ͯΔهࣄ౳΋ଟ͍

    View Slide

  56. © ChatWork
    Service Mesh
    ▸ Envoy ͷΑ͏ͳ࢓૊ΈΛந৅Խͨ͠ݴ༿
    ▸ ۩ମྫ͔Βೖͬͨํ͕෼͔Γ΍͍͢ (ͱࢥ͏)

    View Slide

  57. ▸ ڞ௨͢ΔपลλεΫΛಠཱͨ͠ίϯϙʔωϯτ
    ʹू໿͠ɺΞϓϦέʔγϣϯͱซઃͯ͠ಈ͔͢
    ▸ Α͋͘ΔྫɿSFWFSTFQSPYZͱͯ͠ͷ/(*/9
    ▸ ΞϓϦέʔγϣϯ 1)1 QZUIPOFUD
    Λ·
    ͍ͨͰ࢖͑ΔQSPYZػೳΛ/HJOYʹ࣋ͨͤΔ
    ▸ &OWPZ.JDSPTFSWJDFTӡ༻ʹඞཁͳػೳΛू
    ΊͨQSPYZ
    © ChatWork
    Sidecarύλʔϯ
    Ұॹʹಈ͘ΞϓϦέʔγϣϯͷ͜ͱ͸
    ؾʹ͠ͳͯ͘ྑ͍

    View Slide

  58. © ChatWork
    Data Plane
    ▸ Sidecar proxy = data planeͦͷ΋ͷ
    ▸ Envoy, NGINX, HAProxyͳͲ (LinkerdͰ͸Controle Plane͕౷߹͞Εͨ)
    ▸ microservices ͰඞཁͳػೳΛఏڙ
    ▸ service discovery
    ▸ health checking
    ▸ routing (timeout, circuit breaking)
    ▸ distributed tracing

    View Slide

  59. © ChatWork
    Control Plane
    ▸ εςʔτϨεͳdata planeͷू·ΓΛ෼ࢄγεςϜ΁ͱมԽͤ͞Δଘࡏ
    ▸ ಈతͳઃఆ৘ใͷఏڙ (e.g. service discovery)
    ▸ Envoyͷ৔߹͸ɺxDS ͱݺ͹ΕΔAPI͕ఆٛ͞Ε͍ͯΔ (ޙड़)
    ▸ ਓ͕ؒͦͷ໾ׂΛ͢Δ৔߹΋͋Δ (ਓྗ Controle Plane)
    ▸ Istio, Nelson, Envoy Manager (Lyft಺੡), cookpad΍booking.com΋ࣗ࡞
    ▸ (Linkerd͸Control planeΛ಺แ)

    View Slide

  60. © ChatWork
    Envoyͷઃఆ֓ཁ
    ▸ ੩తͳconfigurationͱɺAPIʹΑΔಈతͳconfiguration
    ▸ API͸xDS (LDS, RDS, CDS, EDS) ͱݺ͹Ε͍ͯΔ
    ▸ v1(deprecated) ͔Β v2΁ (ωοτ্ͷ৘ใ͕ࠞࡏɻɻ)
    ▸ Protcol BufferͰఆٛ͞Εͯͯ໌֬ͩ͠ɺAPIυΩϡϝϯτ΋ॆ࣮͍ͯ͠
    Δ͕ɺશମͷ֓೦Λઆ໌ͨ͠υΩϡϝϯτݟ͚ͭΒΕͣɻɻ (͜ΕΛ·ͱΊΔ
    ͱਓؾऀʹͳΕΔ͔΋͠Εͳ͍)

    View Slide

  61. © ChatWork
    EnvoyͷػೳΛԿݸ͔
    ▸ Timeout / Retry
    ▸ Circuit Breaking
    ▸ Fault Injection
    ▸ Observability / Distributed Tracing

    View Slide

  62. © ChatWork
    Timeout / Retry
    clusters:
    - name: service2
    connect_timeout: 1s
    "routes": [
    {
    "cluster": "service2",
    "prefix": "/",
    "timeout_ms": 3000
    "retry_policy" {
    "retry_on": 5xx,
    "num_retries": 3
    "per_try_timeout_ms": 300,
    }
    },

    View Slide

  63. © ChatWork
    Circuit breaking
    clusters:
    - name: service2
    connect_timeout: 1s
    circuit_breakers:
    thresholds:
    max_connections: 100
    max_pending_requests: 100
    ᮢ஋Ͱͷopen/closeͷΈɻhalf-openͳ
    ঢ়ଶ͸ଘࡏ͠ͳ͍

    View Slide

  64. © ChatWork
    Fault Injection
    clusters:
    - name: service2
    connect_timeout: 1s
    http_filters:
    - name: envoy.fault
    config:
    delay: {fixed_delay: 20s, percent: 50}
    upstream_cluster: service2
    abort: {percent: 20, http_status: 503}
    upstream_cluster: service2
    ଱ো֐ςετɺো֐࠶ݱࢼݧ͕
    ༰қʹߦ͑Δʂ

    View Slide

  65. © ChatWork
    Observability / Distributed tracing
    Envoy͕distributed tracingͷγ
    εςϜͷ΍ΓऔΓΛ΍ͬͯ͘ΕΔ
    ௥੻༻ͷheaderΛservice಺Ͱઃఆ

    View Slide

  66. © ChatWork
    Observability / Distributed tracing
    ※ NewRelicͱdatadog ΋૬͍࣍Ͱ֘౰ͷػೳΛϦϦʔεɻ
    ετϨʔδ؅ཧɺAPM΍طଘͷmonitoring/alertΛߟ͑Δͱɺ
    ɹ͕ͬͪ͜༗ྗ͔΋ʁ
    Lyft, cookpad ͷࣄྫΛࢀর͍ͯͩ͘͠͞

    View Slide

  67. © ChatWork
    Envoy͕΋ͨΒ͢΋ͷ
    ▸ sidecarͱ͍͏৽͍͠ڥքઢ
    ▸ ௨৴ΛѲΔ͜ͱͰɺmicroservicesʹඞཁͳ༷ʑͳػೳΛ౷Ұతʹఏڙ
    ▸ Timeout / retry / circuit breaking etc…
    ▸ Distributed Tracing
    ▸ Dev ͸serviceͷػೳ։ൃʹ஫ྗ
    ▸ ͨͩ͠ɺద੾ͳΤϥʔϋϯυϦϯά͸ඞਢʂ
    ▸ Ops͸sidecarΛ௨ͯ͠Microservicesͱͯ͠ͷ҆ఆੑʹ஫ྗ

    View Slide

  68. © ChatWork
    ͍͍ײ͡++ʂ

    View Slide

  69. © ChatWork
    ޙ͔ΒΈΔͱɺͦΓΌͦ͏ͩͬͯײ͋Δ͕
    ͦΕ͕ͦ͜”ΞΠσΞ”ͳͷ͔΋͠Εͳ͍

    View Slide

  70. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ
    ▸ Microservices ͷπϥϛ / ϜζΧγϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  71. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν
    ▸ Microservices ͷπϥϛ / ϜζΧγϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  72. © ChatWork
    ͬ͘͟Γ·ͱΊΔͱ
    ▸ ݱঢ়
    ▸ EC2্ͷPHPΞϓϦέʔγϣϯ + k8s্ͷscalaΞϓϦέʔγϣϯ
    ▸ ਐߦத
    ▸ PHPΞϓϦέʔγϣϯͷk8sԽ / ΞϓϦͷ࣮ߦج൫Λk8sʹ౷Ұ
    ▸ ͦͷ࣍
    ▸ service mesh(Envoy) ಋೖ

    View Slide

  73. © ChatWork
    ݱঢ়
    ▸ Kubernetes(scala)ͱɺEC2ʹ௚઀provisioning(PHP)ͷซ༻
    ▸ ChatWorkͷ৽ϝοηʔδϯάγεςϜΛࢧ͑Δٕज़
    ▸ 2016೥ͷ೥຤͔Βซ༻͕࢝·ͬͨ
    ▸ Ҏޙͷ৽نΞϓϦ͸k8s্Ͱಈ͍͍ͯΔ
    ▸ ChatWorkʹ͓͚ΔKubernetes on AWS
    ▸ Kubernetesӡ༻վળ / ϊ΢ϋ΢஝ੵ

    View Slide

  74. © ChatWork
    Dockerfile Dockerfile

    View Slide

  75. © ChatWork
    ਐߦத
    ▸ PHPΞϓϦέʔγϣϯΛKubernetes্Ͱಈ͔͢
    ▸ αʔόӡ༻ͷҰݩԽʹΑΔӡ༻ίετ࡟ݮ
    ▸ ϦϦʔεγεςϜͷվળ
    ▸ DevͱOpsͷڥքઢͷ࠶ઃఆ

    View Slide

  76. © ChatWork
    Dockerfile Dockerfile Dockerfile Dockerfile Dockerfile

    View Slide

  77. © ChatWork
    ͦͷ࣍
    ▸ Envoy / Istio (Service mesh) ಋೖ
    ▸ ͞ΒͳΔαʔϏεͷ҆ఆੑ
    ▸ ػೳ։ൃεϐʔυ޲্
    ▸ ࠓޙͷαʔϏε૿ʹ଱͑͏Δج൫

    View Slide

  78. © ChatWork
    Dockerfile Dockerfile Dockerfile Dockerfile Dockerfile

    View Slide

  79. © ChatWork
    Dockerfile Dockerfile Dockerfile Dockerfile Dockerfile
    Dockerfile Dockerfile Dockerfile Dockerfile Dockerfile

    View Slide

  80. © ChatWork

    View Slide

  81. © ChatWork
    ΤϯδχΞืूத
    http://corp.chatwork.com/ja/recruit/
    ▸ ओମੑΛ࣋ͪɺࣗΒߦಈͰ͖Δ
    ▸ ଞऀΛೝΊɺଚॏͰ͖Δ
    ▸ ৘ใΛूΊɺڞ༗Ͱ͖Δ
    ͱ͍͏ํΛ׻ܴ͠·͢ʂ

    View Slide

  82. © ChatWork

    View Slide

  83. © ChatWork
    ઌʹEnvoy΍Μͳ͍ͷʁ
    ▸ ݱঢ়ͷΞϓϦέʔγϣϯΠϯϑϥͷ̎ॏ؅ཧ͕େม
    ▸ k8sʹ౷Ұͯ͠ӡ༻ίετ࡟ݮ / service meshಋೖίετ࡟ݮ
    ▸ ͳͥkubernetesʹدͤΔʁ
    ▸ kubernetes΋։ൃ/ӡ༻Λ”͍͍ײ͡” ʹͯ͘͠ΕΔπʔϧͰ͋Δ
    ▸ ৄࡉ͸࣍ͷΞδΣϯμʹͯ
    ▸ Istioͱ͍͏kubernetesͱͷ૬ੑͷ͍͍control plane͕ઈࢍਐԽத

    View Slide

  84. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν (ࡁ)
    ▸ Microservices ͷπϥϛ / ϜζΧγϛ ͦͷ̎
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  85. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν (ࡁ)
    ▸ Microservices ͷπϥϛ ͦͷ̎ → Kubernetes͕ඞཁͱͳΔഎܠ
    ▸ Kubernetesͱ͍͏”ΞΠσΞ”
    ▸ ·ͱΊ

    View Slide

  86. © ChatWork
    Microservicesͷߏஙྫ(k8sલ)

    View Slide

  87. © ChatWork
    ໰୊ͦͷ̍
    Dev / Opsͷڥքઢʁ

    View Slide

  88. © ChatWork
    Infrastructure as code
    ▸ ཧ૝ → શͯίʔυԽ͞Ε͍ͯΔͷͰɺDev / OpsڞʹมߋՄೳ
    ▸ devops࣮ݱʂ
    ▸ ݱ࣮ → Infrastructure as codeͷ؅ཧ͕Opsʹूத
    ▸ Ansible / Chef ౳ͷprovisioning toolͷֶशίετ΍؀ڥߏஙίετ
    ▸ ϞχλϦϯά / ؂ࢹ / ϩάసૹ౳ɺશମͷӨڹൣғͷ೺Ѳ͕೉͍͠
    (஫ɿ͋͘·Ͱࢲͷܦݧ/஌͍ͬͯΔൣғͷ࿩Ͱ͢ʣ

    View Slide

  89. © ChatWork
    Ops :
    AWSͷϦιʔε؅ཧ
    Infrastructure as codeͷ source code
    Dev :
    ΞϓϦέʔγϣϯͷSource Code

    View Slide

  90. © ChatWork
    αʔό্Ͱ
    ີ݁߹

    View Slide

  91. © ChatWork
    Dev / Opsͷڥքઢʁ
    ▸ Dev : ৽͍͠ͷ࢖͍͍ͨɺɺ/ αοͱόʔδϣϯΞοϓ͍ͨ͠ɺɺ
    ▸ ΍Γ͍ͨ͜ͱʹରͯ͠ͷίετ͕͔ͳΓߴ͍
    ▸ Ops: ݴޠɺϑϨʔϜϫʔΫ૿͑ΔΜ͔ʙɺɺ / ҆ఆͯ͠ಈ͘ͷʁ
    ▸ ਓͷέπΛ࣋ͨ͞ΕͯΔײ
    ▸ ୭Ͱ΋৮ΕΔΑ͏ʹ͢Δॴ·Ͱͷίετ΋தʑʹେ͖͍

    View Slide

  92. © ChatWork
    ໰୊ͦͷ̎
    αʔόӡ༻ͬͯ͜ΕͰϕετʁ

    View Slide

  93. © ChatWork
    ૬৐Γ͍͚ͤͨ͞Ͳɺɺ

    View Slide

  94. © ChatWork
    αʔόӡ༻ͬͯ͜ΕͰϕετʁ
    ▸ ΞϓϦέʔγϣϯͷ૬৐Γ͕೉͍͠
    ▸ ̍instance = 1ΞϓϦέʔγϣϯ
    ▸ ෳ਺ͷΞϓϦέʔγϣϯ༻ͷprovisioningΛ1 instanceʹྲྀͯ͠ɺશͯ
    ਖ਼ৗʹಈ͘͜ͱΛอূ͢Δͷ͕೉͍͠
    ▸ αʔϏε૿͑Δͱ૊Έ߹Θͤ਺͕രൃ͠ɺ؅ཧͰ͖ͳ͍
    ▸ ΍ͬͨͱ͢Δͱɺ·͢·͢Dev͔Β͸৮ΓͮΒ͍΋ͷʹɻɻ

    View Slide

  95. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν (ࡁ)
    ▸ Microservices ͷπϥϛ ͦͷ̎ → Kubernetes͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Kubernetesͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔKubernetesͷར఺
    ▸ ·ͱΊ

    View Slide

  96. © ChatWork
    ▸ ஫ɿࢲͷ͜Ε·Ͱͷܦݧ ͔Βɺkubernetesͱ͍͏୯ޠΛར༻͍ͯ͠·͢
    ͕ɺίϯςφΦʔέʔετϨʔγϣϯπʔϧ Ұൠʹ౰ͯ͸·Δ(͸ͣͷ)࿩
    Ͱ͢ɻ

    View Slide

  97. © ChatWork
    Microservicesͷߏஙྫ(k8s)

    View Slide

  98. © ChatWork
    ίϯςφͱ͍͏ϙʔλϏϦςΟͷߴִ͍཭؀ڥͷ͓͔͛Ͱɺڥքઢ͕໌
    ֬ʹɻϞχλϦϯάͱ͔͸ؾʹͤͣʹɺΞϓϦέʔγϣϯ࣮ߦʹඞཁͳ؀ڥʹؔ͢Δఆ͚ٛͩ
    ͋Ε͹ྑ͍ͷͰɺϋʔυϧ͕௿͍ɻ
    Dockerfile Dockerfile Dockerfile

    View Slide

  99. © ChatWork
    Ops͸Workerʹڞ௨ͷϞχλϦϯά΍ϩάసૹͷઃఆΛηοτ͢Ε͹ྑ
    ͍ɻݸʑͷWorkerͷଘࡏΛҙࣝ͢Δ͜ͱ͕΄ͱΜͲແ͘ɺར༻ϦιʔεʹԠͨ͡ΞϓϦέʔ
    γϣϯ(pod)഑ஔ΍ɺϓϩηεͷҡ࣋͸kubernetes͕ٓ͘͠΍ͬͯ͘ΕΔɻ

    View Slide

  100. © ChatWork
    ڥքઢ͕͍͍ײ͡ʂ
    ▸ ΞϓϦέʔγϣϯ༻ͷ؀ڥߏங͕׬શʹDevͷकඋൣғʹ
    ▸ Dockerfileͷֶशίετ͸͋Δ͕ɺؾʹ͢Δ͜ͱ͕͙ͬͱগͳ͘ͳͬͨ
    ▸ Ops͸clusterͷ؅ཧɺmonitoring / loggingసૹ౳ͷڞ௨ج൫ʹूத
    ▸ 12 factor app ͱ͍͏ΞϓϦέʔγϣϯͷڞ௨ϧʔϧ
    ▸ pod਺ͷҡ࣋΍ɺϦιʔεঢ়گʹԠͨ͡ίϯςφ഑ஔ͸kubernetes͕
    ΍ͬͯ͘ΕΔ

    View Slide

  101. © ChatWork
    αʔόӡ༻͕͍͍ײ͡ʂ
    ▸ Pet ͔Β Cattle (PHPαʔόɺPythonαʔό…. → k8s Worker)
    ▸ Ϧιʔεͷ༗ޮ׆༻
    ▸ ̍αʔό্Ͱͷෳ਺ΞϓϦέʔγϣϯͷ૬৐Γ

    View Slide

  102. © ChatWork
    ͍͍ײ͡++ʂ

    View Slide

  103. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν (ࡁ)
    ▸ Microservices ͷπϥϛ ͦͷ̎ → Kubernetes͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Kubernetesͱ͍͏”ΞΠσΞ” → πϥϛʹର͢Δkubernetesͷར఺(ࡁ)
    ▸ ·ͱΊ

    View Slide

  104. © ChatWork
    ΞδΣϯμ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν (ࡁ)
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν (ࡁ)
    ▸ Microservices ͷπϥϛ ͦͷ̎ → Kubernetes͕ඞཁͱͳΔഎܠ (ࡁ)
    ▸ Kubernetesͱ͍͏”ΞΠσΞ” → πϥϛʹର͢Δkubernetesͷར఺(ࡁ)
    ▸ ·ͱΊ

    View Slide

  105. © ChatWork
    ࠓ೔࿩ͨ͜͠ͱ
    ▸ Microservices ͷπϥϛ ͦͷ̍ → Envoy͕ඞཁͱͳΔഎܠ
    ▸ Envoyͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔEnvoyͷΞϓϩʔν
    ▸ ChatWorkͷະདྷ༧૝ਤ → ݱঢ়ͱಋೖ΁ͷΞϓϩʔν
    ▸ Microservices ͷπϥϛ ͦͷ̎ → Kubernetes͕ඞཁͱͳΔഎܠ
    ▸ Kubernetesͱ͍͏”ΞΠσΞ” → πϥϛʹର͢ΔKubernetesͷར఺

    View Slide

  106. © ChatWork
    ࠓ೔ͷ໨ඪ
    ɾEnvoy ੌ͍ʂ͍ͬͯ͏ײಈͷڞ༗
    ɾDev / OpsΛ໰Θͣʹɺࣗ෼ͷ૊৫΍
    γεςϜͷڥքઢΛߟ͑Δ͖͔͚ͬʹ

    View Slide

  107. © ChatWork
    Feedback ͓ئ͍͠·͢ʂʂ
    from ωʔϜΧʔυͷQRίʔυ

    View Slide