地雷の話
θϩ͔Β࢝ΊͨGunosyΞυαʔό։ൃӡ༻هגࣜձࣾGunosy҄൧ݪढ़հ
View Slide
ࣗݾհ• ҄൧ݪढ़հ (http://argmax.jp)• Gunosy։ൃຊ෦ Ϛωʔδϟʔ• ࠂ৴γεςϜͷ։ൃશମͱR&DܥΛ୲• ઐ: ܭࢉݴޠֶ• PythonͱඇಉظࢄγεςϜΛΉ• ը૾ॲཧɾԻ৴߸ॲཧͰ͍Ζ͍ΖϥΠϒϥϦ࡞ͬͯΔ• https://bitbucket.org/aihara
ɹɹGunosy Ads• χϡʔεΩϡϨʔγϣϯΞϓϦͷάϊγʔͷࠂ• ೖߘ͔Β৴·Ͱશࣗࣾ• ࠂೖߘγεςϜҎ֎΄΅Python• ࠷ۙscalaͱgo͕ೖ͖ͬͯͨ• End-to-EndͷRTBγεςϜ• ΞυωοτϫʔΫ࢝Ίͨ• iOS, Android, JS, Titanium͚SDKΛఏڙ
Ξυαʔό૯߹֨ಆٕ• ECPM(ऩӹੑ)Λ૿େͤ͞Δ༧ଌΞϧΰϦζϜͷߏங• CPA(ސ٬֫ಘ୯Ձ)Λ͑ͯ͘ࠂΛܧଓ• Ϣʔβʹͱͬͯ༗ӹͳࠂใΛ৴• େنσʔλΛ҆ఆ/ߴʹॲཧ͠ϩδοΫʹө• 50ms or Die
Gunosy Adsαʔόߏ 236019(!%-7 +#4/,:*'&5.8 MySQL+#$)"
Ξυαʔό։ൃͷجຊελϯε• ࠷ۙ·Ͱࠂ৴ΤϯδχΞ2໊• AWSͰ༗Δ͜ͱΛ࠷େݶ׆༻• TimeϕʔεͷϓϩϏδϣχϯά + େྔͷcold standby• ӡ༻ɾࢮ׆ࢹՄೳͳݶΓࣗಈԽ• αʔό૿͢ΑΓνϡʔχϯά(ශੑ)• ແବʹଟ͍KPI Tool
͜ͷҰΛৼΓฦΔ
1ͰGunosyϢʔβ10ഒࠂ৴ྔઍഒʹਓਓਓਓਓਓਓਓਓ݄ ݄ ݄ ݄ ݄ ࠓμϯϩʔυ ΞυΤϯδχΞਓ
͡Ίͷαʔόͩͬͨ• Python(Tornado)ͷ৴αʔό• ΦϯϥΠϯֶश/όϯσΟοτͰCTRਪఆ• Redisʹ৴σʔλΛͯ͢ೖ• RDBҰݟͳ͍• MongoDBʹtd-agentͰϩάΛೖ• Capped CollectionʹೖRedisMongoDB(Log Collector)Batch ServerMySQLMySQL৴αʔό
スパイキーなアクセスでサーバが死ぬϢʔβͷੵΈ͕ΓͰ λΠϚʔϕʔεͷఆ࣌1VTI͕ʹ
࠷ॳͷCPUόϯυ• ΞυαʔόΛTimeϕʔεͰϓϩϏδϣχϯά• ॏ͍ܭࢉΛAPIαʔόͰ͢Δͷ͕ؒҧ͍• ϦΞϧλΠϜͷ౷ܭΛଈ࣌ө͢ΔΑ͏ͳσʔλूܭܥͱόονܥΛߏங• ୯ҐͰ͘͘͞͞ճΔϨϕϧ!• ͜ͷλΠϛϯάͰϕʔε͕΄΅
·ͩ·ͩτϥϒϧָ͍࣌͠ظ• ΄΅ϓϩτλΠϓͷ͓ͪΌΈ͍ͨͳͩͬͨͷͰ৴ϩδοΫपΓͷνϡʔχϯάָ͕͍͠• αʔό૿͢ΑΓϒϥογϡΞοϓ• ΞΫηεച্·ͩ·ͩ
ウルトラマン来襲
CMͷ։࢝ʹΑΓDAU͕ര૿
ਓਓਓਓਓਓਓਓਓ݄ ݄ ݄ ݄ ݄ ࠓμϯϩʔυ ΞυΤϯδχΞਓ͜ͷ͋ͨΓ
Ϣʔβࠂ૿͍͑ͯ͘• ऩӹ૿͑ͯઈରʹࢭΊΒΕͳ͘ͳΔ…• ΦʔσΟΤϯεσʔλ͕RedisʹࡌΓΒͳ͍• Slave͕OOMͰࢮΜͩΓ• ΞΫηεͷεύΠΫΑΓܹ͘͠Redis͕٧·Γ࢝ΊΔ• MongoͷCapped Collectionʹ1͢ΒΒͳ͘ͳΔ
RedisͷߏΛมߋ• ͯ͢ͷΞΫηεʹڞ௨͢Δσʔλ(ࠂͷใ/୯Ձ)ΛS3ܦ༝ͰશαʔόʹΒ·͍ͯReadΛݮ• Redis͕མͪͯ࠷ݶͷ৴͕Ͱ͖ΔΑ͏ʹͳͬͨ!!!
RedisͷߏΛมߋ• σʔλछຖͷਨࢄ• twemproxyೖΕͯσʔλྔ૿Ճ࣌ͷϝϯςφϯεෛՙมΘΒͳ͍ͷͰਨࢄ / αΠζΞοϓͰରԠ• Riakݕ౼ɺ࣌ίετ໘Ͱબఆ͔Β֎Εͨ!!ϢʔβຖͷӾཡཤྺϢʔβͷηάϝϯτσʔλࠂຖͷ৴ύϥϝʔλΫϥΠΞϯτ͕σʔλछຖʹ3FEJTαʔόΓସ͑
ूܭDBΛRedshiftʹ• fluent-plugin-redshiftʹύονΛ͋ͯͯϩάΛϦΞϧλΠϜʹRedshiftʹೖ• ͱΓ͋͑ͣRedshiftʹೖΕΔͱָͰ͖Δと思っていた……
アドネットワーク開始で広告枠とログデータが爆発Redshiftは死ぬ
͕૿͑ͯόον૿͑ͨ• PythonͷࢄTask-Queue(Celery)ϥΠϒϥϦͰ΄΅ແվͰࢄॲཧԽ• ႈͰ૬ޓͷঢ়ଶʹґଘ͕ແ͍όονΛ࡞Δ• numpy, scipy, pandas, scikitsͷΤίγεςϜ͕ͦͷ··͑ΔAmazon SQSɾ ɾ ɾCelery WorkersDjango-Celery
Redshift͕٧·Γग़͢• Redshiftूܭରςʔϒϧ͕ϝϞϦʹΒͳ͘ͳΔͱ్ʹ͘ͳΔ• Ϋϥελ૿ / ΠϯελϯεมߋରԠग़དྷΔ͚Ͳߴ͗ͯ͢ROI͕߹Θͳ͘ͳͬͯ͘Δ• dw2.8xlargeߴ͗͢• ੴ༉ԦͳΒdw2.8xlargeΫϥελΛ͓͏
• Redshift͋͘·ͰσʔλϚʔτ• ఆৗूܭʹඞཁͳϝϞϦʹΓΔσʔλͷΈtemporalͳςʔϒϧʹͤΔ• ࣗಈͰఆظϩʔςʔγϣϯϝϞϦʹΒͳ͍Ϗοάσʔλ is ෆཁ
ϝϞϦʹΒͳ͍Ϗοάσʔλ is ෆཁ• ඇఆظతͳੳSparkʹ• ශऀͷຯํEMR on Spot Instance• ΞυϗοΫͳੳͱ͔ճؼϞσϧߏஙSparkΛར༻• શϩάूܭImpalaͰ(ΦϯϝϞϦ͡Όͳ͍͚Ͳ)
DAU積み上がりと記事タイトル付きPushでさらなるスパイクが…
ࣾͷผαʔϏεͷվળͷӨڹ͕…• PushͷهࣄબΞϧΰϦζϜͷվྑͰϢʔβͷ։෧͕େ෯্• Remote Pushܥஔ͖͑Ͱඦສ݅1ҎԼͰDelivery• APIαʔόͷεϧʔϓοτ͕վળ• ΞυαʔόͷϦΫΤετര૿• Too Slow To Die
͞Α͏ͳΒRedis͞Μ• Redisʹର͢ΔR/WΛͻͨ͢Βݮ• ΞΫςΟϒͳϢʔβ͚ͩϑΝΠϧDBʹͯ͠શʹ• temporalͳσʔλΛͳͯ͘͠Statelessͳ৴ϩδοΫʹมߋ• RedisͱͯͭΒ͍͚Ͳ·ࣺͩͯΒΕͯͳ͍• RiakͱMemcachedͷೋஈߏ͔Aerospikeͷٕज़ݕ౼• Ͳͬͪʹͯͭ͠Β͍
ݟ͑ͯΔཕΛશͯ౿Έൈ͍ͯࠓʹࢸΔ 236019(!%-7 +#4/,:*'&5.8 MySQL+#$)"
·ͱΊ• ҰؒͰ͍͖ͳΓαʔϏε͕େ͖͘ͳΔͱ• ເͷٕज़ແ͍ͱ͍͏͜ͱ͕ʹ͠ΈΔ• ച্ͷϓϨογϟʔ͕ͭΒ͘ͳͬͯ͘Δ• ͦͷී௨ग़དྷͳ͍ܦݧ͕ੵΊΔ• GunosyͰPython,Scala, Golang͕͖ͳΤϯδχΞ͕͖উखͬͯΔͷͰ༡ͼʹདྷ͍ͯͩ͘͞