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
Qiita Career Meetup for Server Side Engineers
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
tosametal
July 20, 2018
Technology
4
4.2k
Qiita Career Meetup for Server Side Engineers
2017/7/20開催のSever Side Engineer向け採用イベント
https://connpass.com/event/92668/
tosametal
July 20, 2018
Tweet
Share
More Decks by tosametal
See All by tosametal
マイクロアドのアドテクを支える技術
tosametal
1
200
DigdagでETL処理をする
tosametal
0
4.2k
Other Decks in Technology
See All in Technology
名刺メーカーDevグループ 紹介資料
sansan33
PRO
0
1k
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
920
SREが向き合う大規模リアーキテクチャ 〜信頼性とアジリティの両立〜
zepprix
0
440
ClickHouseはどのように大規模データを活用したAIエージェントを全社展開しているのか
mikimatsumoto
0
220
GSIが複数キー対応したことで、俺達はいったい何が嬉しいのか?
smt7174
3
150
インフラエンジニア必見!Kubernetesを用いたクラウドネイティブ設計ポイント大全
daitak
1
350
AI駆動開発を事業のコアに置く
tasukuonizawa
1
160
モダンUIでフルサーバーレスなAIエージェントをAmplifyとCDKでサクッとデプロイしよう
minorun365
4
180
CDK対応したAWS DevOps Agentを試そう_20260201
masakiokuda
1
250
Amazon S3 Vectorsを使って資格勉強用AIエージェントを構築してみた
usanchuu
3
450
Introduction to Bill One Development Engineer
sansan33
PRO
0
360
顧客の言葉を、そのまま信じない勇気
yamatai1212
1
350
Featured
See All Featured
How STYLIGHT went responsive
nonsquared
100
6k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
53
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
A Soul's Torment
seathinner
5
2.2k
Rails Girls Zürich Keynote
gr2m
96
14k
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
240
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.3k
Digital Ethics as a Driver of Design Innovation
axbom
PRO
1
180
RailsConf 2023
tenderlove
30
1.3k
Paper Plane (Part 1)
katiecoart
PRO
0
4.1k
The Cult of Friendly URLs
andyhume
79
6.8k
Transcript
Qiita Career Meetup for Server Side Engineer 株式会社MicroAd テックリード 中野翔太
2018/7/20(金)
会社概要 事業内容 本社 設立 社員数 開発拠点 Data Platform/Ad Platform 渋谷
2007年7月 200人 東京/京都
発表内容 1. MicroAdの事業,技術 2. 開発案件紹介
1. MicroAdの事業,技術
アドプラットフォーム その他広告サービス Ad Platform
1回目のアクセス 転職広告 サイトA 同じサイトを訪れても、違う広告が表示される 車広告 サイトA 2回目のアクセス
SSP DSP1 DSP3 DSP2 30円 50円 10円 転職広告 RTB(Real Time
Bidding) 健康食品 広告 車広告 ※実際の入札金額はもっと少ないです。説明を分かりやすくするためこの金額にしています 転職広告 サイトA 最も高い金額の50円を出した DSP2の広告が落札され表示
• SSP • メディアの広告管理を自動化し、収益の最大 化を実現 • DSP • WEB上の行動・属性データや購買データ、位 置情報など多彩なターゲティングが可能
• アカウント開設約18000社 • 国内の代表的なAdExchangeやSSPと連携 MicroAdのSSP,DSP製品
システム紹介(BLADE) • Bid Request 150億/day, Impression 30億/month • ピーク時20万QPS •
レスポンス5~10ms(ネットワークのレイテンシは除く) • Scala, Java, Python • 他社データ(CCC, SoftBank, Geo, EC, Credit etc...) • 約1500台のサーバ(全てオンプレミス)
Data Platform
WEB上の行動履歴 世田谷在住 30代男性 旅行サイトで申し込みあり ポルシェに興味あり
• 毎朝野菜ジュース購入 • ユニクロでTシャツ購入 • 渋谷のコンビ二利用 • 世田谷在住30代男性 • 旅行サイトで申し込み
• ポルシェに興味あり • • 平日は渋谷、休日は市川 • 月に1回は大阪 • 平日も夜は新宿が多い • ニンテンドーSwitch購入 • サイクロン掃除機 • トーマスのおもちゃ WEB上の行動履歴 位置情報データ EC購買データ リアル購買データ データを繋げてわかる 真のユーザ像
UNIVERSE FFM FFM(Full Funnel Management) 多様なデータからユーザ毎のオンラインKPI の到達可能性をAIでスコアリングし広告配 信を最適化 潜在層 見込層
直近層
None
オンライン上のデータだけでなく オフラインの行動データをマネジメント対象に加える UNIVERSE FFM
UNIVERSE Bidder(仮) DDD 広告配信プラットフォーム絶賛新規開発中!
まとめ
2. 開発案件紹介
案件1. サイトアクセスログ
サイトにアクセスしたログをリアルタイムに処理 要件 • 2~5万QPS • 整形・加工 • ログの順序は保持 トップ ページ
商品 ページ 購入 ページ 12:00:00 12:00:05 12:00:10 購入でCV(コンバージョン) 達成
Spark Streamingによるストリーム処理 アクセスログの重複排除・整形・加工 ※詳細は弊社エンジニアブログ(https://developers.microad.co.jp/entry/2018/04/03/121012)で確認出来ます ※Qiita記事もあります
パーティション1 パーティション2 パーティション3 エグゼキュータ1 エグゼキュータ3 エグゼキュータ2 • KafkaとSpark間の並列処理を容易に実装できる • at
least onceを保証できる Direct Stream
高速化 MySQL Scheduler 更新 Actor ActorSystem ドライバ エグゼキュータ エグゼキュータ エグゼキュータ
定期的に メッセージ送信 →2~5万QPSのパフォーマンス要件を満たす DBから取得し たデータは メモリに保持
リアルタイムにスコアを算出 →その瞬間にCV確率の高いユーザに対しての配信が可能
案件2. 入札額算出フロー刷新
入札額 SSP DSP1 DSP3 DSP2 30円 50円 10円 転職広告 健康食品
広告 車広告 転職広告
既存の入札額算出フロー DWH 分析 ツール crontab データソース ジョブ管理 • 複数のデータソース •
ブラックボックス化した分析基盤 • スケールしづらいDWH • 複雑なジョブ管理 • 実行環境依存のバッチ処理 など問題は山積み・・・ DWHにデータを転送 DWHで入札額計算処理を実行 Hadoop Hadoop Hadoop Hadoop
新データ基盤アーキテクチャ • ログのJson化 • DWHをhadoopに変更 • digdagを用いたworkflow管理 • バッチのコンテナ実行 ※詳細は弊社エンジニアブログ(https://developers.microad.co.jp/entry/2018/05/24/131136)で確認出来ます
※Qiita記事もあります 広告配信 サーバなど 各種サーバ バッチ処理 リアルタイム処理
digdagによるworkflow管理 TreasureData社製workflow管理ツール • yamlに似たDSLでworkflowを記述 • Dockerコンテナでの実行を標準サポート • session_timeにより実行予定時間を保持 • UIからリカバリ可能
• その他workflow管理に必要な要件を満たす
MicroAd BLADEにおける入札額算出処理 3. 入札額算出 2. 広告効果予測 1. 入力データ 生成 機械学習用
サーバ tsv形式でdownload それぞれの処理の スケジュールや依存関係を digdagで管理
digdagのコード digdagのUI
MicroAd BLADEにおける入札額算出から適用まで RTB サーバ 機械学習 サーバ KVS
- 2つの開発事例の紹介 - 技術選定の裁量権は案件担当エンジニアにある まとめ
WE ARE HIRING! https://recruit.microad.co.jp/