Mesos Meetup Tokyo #3 https://mesos.connpass.com/event/67877/
ref1. Apache Mesos with Amazon EC2 SpotFleet https://speakerdeck.com/kotatsu360/apache-mesos-with-amazon-ec2-spotfleet
© 2017 VASILY,Inc.શͯͷ“Waiting”Λੜ·ΕΔલʹফ͠ڈΓ͍ͨɻMesos Meetup Tokyo #3 2017/11/01 Wed. Tatsuro MITSUNO
View Slide
© 2017 VASILY,Inc.ࣗݾհ▸ Tatsuro Mitsuno / ޫ ୡ࿕▸ 2012/04 Yahoo Japan Corporation▸ 2016/04 VASILY, Inc.▸ Infrastructure Engineer▸ Twitter GitHub Qiita: @kotatsu360Icon illustrated by YOSHI https://ja-jp.facebook.com/yoshi.yone.7Yukihiro "Matz" Matsumoto (VASILY technical advisor )
© 2017 VASILY,Inc.Mesos Meetup Tokyo #2 ʹͯhttps://speakerdeck.com/kotatsu360/apache-mesos-with-amazon-ec2-spotfleetApache Mesos ͱ Amazon EC2 SpotFleetͰߏங͞Εͨ ฐࣾͷΫϩʔϥʔج൫ʹ͍ͭͯ͝հ͠·ͨ͠ɻ
© 2017 VASILY,Inc.VASILYͷΫϩʔϥʔج൫scaling requestcontrolSpotFleet InstancescalingrequestLambdaCloudWatch /CloudWatch Eventupdate request
© 2017 VASILY,Inc.ຊͷςʔϚMarathonͷ“Waiting”Λղܾ͢Δ͜Ε
© 2017 VASILY,Inc.Waitingͱ▸ Marathon͕λεΫʹඞཁͳϦιʔεΛ֬อͰ͖ͳ͍ঢ়ଶ▸ ެࣜυΩϡϝϯτͷτϥϒϧγϡʔςΟϯάͷୈҰ߲ An app stays in “Waiting” forever▸ ୭͕ૺ۰͢Δ▸ ࣌ؒܦաͰղܾ͠ͳ͍▸ ղܾํ๏ɿෆ͍ͯ͠ΔϦιʔεΛಛఆͯ͠ɺՃɾ։์
© 2017 VASILY,Inc.Waitingͷ▸ ͲͷϦιʔε͕ෆ͍ͯ͠Δ͔Θ͔Βͳ͍ɾɾɾ▸ ϝϞϦɾCPUɾϙʔτɾetc,,,▸ Mesos͕֬อՄೳͳϦιʔεશ͕ͯݪҼʹͳΓ͏Δ▸ ͔͠͠ɺز͔ͭͷ͋Γ͕ͪͳύλʔϯʹྨՄೳ▸ ຊ͝հ͢Δͷ࣮ࡍʹࢲ͕ૺ۰ͨ͠Waitingͱͦͷରࡦ
© 2017 VASILY,Inc.Waitingͦͷ1ɿΫϥελϦιʔεΓͯ·͔͢ʁ
© 2017 VASILY,Inc. Waitingͦͷ1ɿΫϥελϦιʔεΓͯ·͔͢ʁݪҼɿλεΫ͕͏Ϧιʔε > MesosΫϥελͷۭ͖Ϧιʔε֬ೝɿλεΫ͕ඞཁͱ͢ΔϝϞϦCPUΛܭࢉͯ͠ɺMesos UIͰۭ͖Λ֬ೝରࡦɿMesosΫϥελΛ૿͢ɾλεΫͷׂྔΛݮΒ͢λεΫAϝϞϦ512MϝϞϦ 2048Mʮ2560M֬อʯʮϝϞϦΒͳ͍ʯλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAΛ5ݸϝϞϦ512MWaiting
© 2017 VASILY,Inc.Waitingͦͷ2ɿλεΫͷ੍ຬͨͯ͠·͔͢ʁ
© 2017 VASILY,Inc. Waitingͦͷ2ɿλεΫͷ੍ຬͨͯ͠·͔͢ʁݪҼɿ੍͖ͭλεΫͷ੍͕ຬͨͤͳ͍֬ೝɿλεΫͷ੍͕ຬͨ͞Ε͍ͯΔ͔ݟ͢ʢಛʹϢχʔΫ੍ʣରࡦɿϊʔυΛ૿͢λεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫBΛ5ݸConstraints =hostname, uniqueWaitingΤʔδΣϯτʮ1λεΫ/1ϗετʯʮϗετΓͳ͍ʯΤʔδΣϯτΤʔδΣϯτ ΤʔδΣϯτ
© 2017 VASILY,Inc. Waitingͦͷ2ѥछɿϦιʔεยدͬͯແ͍Ͱ͔͢ʁݪҼɿ੍͖ͭλεΫ͕͏Ϧιʔε>ಛఆϗετͷۭ͖Ϧιʔε֬ೝɿλεΫ͕ಛఆͷϗετʹยدͬͯͳ͍͔ʢكͳঢ়گʣ ରࡦɿఆظతʹλεΫΛϦελʔτ͢Δɾ੍͖ͭλεΫΛेʹখ͘͢͞ΔλεΫAϝϞϦ512MλεΫAϝϞϦ512MλεΫBΛ2ݸConstraints =hostname, uniqueWaitingʮ1λεΫ/1ϗετʯʮ1ͰϝϞϦΓͳ͍ʯΤʔδΣϯτϝϞϦ༻90%ΤʔδΣϯτϝϞϦ༻20%
© 2017 VASILY,Inc.Waitingͦͷ3ɿϦιʔεͷ༻ڐՄ͋Γ·͔͢ʁ
© 2017 VASILY,Inc. Waitingͦͷ3ɿϦιʔεͷ༻ڐՄ͋Γ·͔͢ʁݪҼɿλεΫ͕͏ϙʔτͷ༻ڐՄ͕ͳ͍֬ೝɿλεΫ͕ಛผͳϦιʔεΛΘͳ͍͔֬ೝରࡦɿλεΫʹrequirePortsɺagentϓϩηεʹresourcesΦϓγϣϯΛՃ https://mesosphere.github.io/marathon/docs/troubleshooting.html#requiring-a-specific-host-portWaitingλεΫCΛ1ͭϗετϙʔτ80Λ༻ʮ80ϙʔτʯʮڐՄແ͠ʯσϑΥϧτઃఆͷ mesos-agentϓϩηε
© 2017 VASILY,Inc. Waitingͦͷ3ѥछɿطଘλεΫ͕ར༻͍ͯ͠·ͤΜ͔ʁݪҼɿ৽نλεΫ͕͍͍ͨϙʔτΛطଘλεΫ͕όΠϯυࡁΈ֬ೝɿൃੜλΠϛϯάɻσϓϩΠ࣌ͳΒϙʔτ͕͔ͪ߹͍ͬͯΔՄೳੑ ରࡦɿupgradeStrategyͰɺminimumHealthCapacityͱmaximumOverCapacityʹ0Λࢦఆ ʢ৽نλεΫͷσϓϩΠલʹطଘλεΫ͕kill͞ΕΔʣWaitingλεΫCΛ1ͭϗετϙʔτ80Λ༻ʮ80ϙʔτʯʮ༻தʯλεΫCʢrunningʣ
© 2017 VASILY,Inc.·ͱΊ▸ λεΫ͕ඞཁͱ͢Δ֤छϦιʔε͕֬อͰ͖ͳ͍߹ɺWaitingʹͳΔ▸ දతͳWaitingύλʔϯ▸ ϝϞϦɾCPU͕Γͳ͍▸ ੍͕ຬͨͤͳ͍▸ ಛఆͷϦιʔεΛ͏ݖݶ͕ͳ͍▸ దͳϦιʔεͱಉ࣌ʹɺλεΫࣗମͷݟ͠▸ ੍ϗετϙʔτ͕ඞཁͳ͍λεΫͰ͋Εࣗવʹ͑Δ
© 2017 VASILY,Inc.We are Hiringhttps://www.wantedly.com/companies/vasily