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
大量物件データの差分反映をどう実現しているか
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Red Frasco
September 09, 2022
Technology
1
240
大量物件データの差分反映をどう実現しているか
2022.09.07「エンジニアが不動産業界の裏側について語る会」のLT資料です。
▼エンジニアが不動産業界の裏側について語る会
https://connpass.com/event/257082/
Red Frasco
September 09, 2022
Tweet
Share
More Decks by Red Frasco
See All by Red Frasco
これってSRE?いい部屋ネットを1,760%成長させた開発とインフラのコラボレーション
red_frasco
0
120
レガシーで硬直したテーブル設計から変更容易で柔軟なテーブル設計にする
red_frasco
9
1.9k
5年間のDB技術選定・運用を振り返る Aurora MySQL, RDS MySQL, RDS PostgreSQL が混在した理由と今後の展望
red_frasco
0
100
ゼロから構築!6年間で1,760%成長した「いい部屋ネット」を支えるデータ分析基盤
red_frasco
0
130
“後発優位”で挑んだ 「いい部屋ネット」再構築: 4年間のAWS移行で実現した成果とその舞台裏
red_frasco
0
3k
Datadog Synthetics 活用事例紹介
red_frasco
0
690
バッチ処理が終わらない!? -処理時間を90%削減した話-
red_frasco
1
410
不動産情報サイトにおけるデータ収集で頑張ったこと
red_frasco
0
360
コストに関するヒヤリハットのお話 ~コスト超過で手遅れにならないためにすべきこと~
red_frasco
0
530
Other Decks in Technology
See All in Technology
Sansan Engineering Unit 紹介資料
sansan33
PRO
1
4k
【SLO】"多様な期待値" と向き合ってみた
z63d
2
250
トラブルの大半は「言ってない」x「言ってない」じゃねーか!!
ichimichi
0
210
2026-02-24 月末 Tech Lunch Online #10 Cloud Runのデプロイの課題から考えるアプリとインフラの境界線
masasuzu
0
100
男(監査)はつらいよ - Policy as CodeからAIエージェントへ
ken5scal
4
630
OCI技術資料 : 外部接続 VPN接続 詳細
ocise
1
10k
Webアクセシビリティ技術と実装の実際
tomokusaba
0
140
Lookerの最新バージョンv26.2がやばい話
waiwai2111
1
140
What's new in Go 1.26?
ciarana
2
260
チームメンバー迷わないIaC設計
hayama17
5
3.1k
失敗できる意思決定とソフトウェアとの正しい歩き方_-_変化と向き合う選択肢/ Designing for Reversible Decisions
soudai
PRO
8
1.3k
1 年間の育休から時短勤務で復帰した私が、 AI を駆使して立ち上がりを早めた話
lycorptech_jp
PRO
0
190
Featured
See All Featured
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.4k
The Cult of Friendly URLs
andyhume
79
6.8k
Prompt Engineering for Job Search
mfonobong
0
180
The Mindset for Success: Future Career Progression
greggifford
PRO
0
260
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
210
Everyday Curiosity
cassininazir
0
150
Leading Effective Engineering Teams in the AI Era
addyosmani
9
1.7k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.2k
A Modern Web Designer's Workflow
chriscoyier
698
190k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
280
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
130
Transcript
大量物件データ 差分反映をどう 実現しているか 株式会社Red Frasco 照屋
物件管理システム ポータルサイトDB コンバーター 物件データ ここの話! なんの話? 物件画像 物件情報入力 ポータルサイトDB 物件データ変換
追加・更新・削除
どんな課題があったか システム構成 データ変換の実態 運用(おまけ) 目次
どんな課題があったか
1日2回、30万件のデータを 30分以内に処理する プロジェクト開始時の目標 物件は増える🦆 回数も増える🦆
分散処理と差分反映 工夫しているポイント
システム構成
他社物件管理システム S3 ダッシュボード(Redash) Slack BigQuery FTP Datadog TransferFamily DB 分散ポイント!
ポータルサイト コンバーターシステム(AWS) Step Functions 4.データ登録(Lambda) 3.データ変換(ECS) 5.結果通知(Lambda) 1.物件データ(CSV)のスキャン(Lambda) 2.排他処理(Lambda) Event Bridge システム構成 分散ポイント! 分散ポイント! 分散ポイント!
分散ポイント S3 システム単位でディレクトリを分割 店舗単位でディレクトリを分割 日付単位でディレクトリを分割 Step Functions システムごとにStep Functions自体も複数用意 データ変換
Step Functionsの並列実行でコンテナを40個同時起動 データ登録 Step Functionsの並列実行でLambdaを40個同時起動
データ変換の実態
Lambda 1.ファイルスキャン S3(内部用) ①スキャン ③ステータス保存 ②ファイル移動 連動元からアクセス可能 内部からのみアクセス可能 排他制御 べき等性
スキャンしたファイル をDBへ記録し、重複実 行されないよう制御した り実行状況を管理 こんば S3(外部用) 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録 DB /システムA /店舗A/yyyymmdd/*.csv /店舗B/yyyymmdd/*.csv /店舗C/yyyymmdd/*.csv /店舗D/yyyymmdd/*.csv ・ ・ ・ ・ /Work /システムA /店舗A/yyyymmdd/*.csv /店舗B/yyyymmdd/*.csv /店舗C/yyyymmdd/*.csv /店舗D/yyyymmdd/*.csv ・ ・ ・ ・
こんば 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録 2.データ変換
データ変換でしたいこと S3に配置されたファイルを読み解く 異常データの検知 差分反映(パフォーマンス向上) データ登録用のSTOREファイルとDELETEファイルを生成 新規物件と更新物件のみの 一覧をファイル出力 STOREファイル 削除物件の 一覧をファイル出力 DELETEファイル
ECS S3(内部用) コンテナの内部(Python) こんば 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談
4.結果通知 3.データ登録 並列実行 差分確認 トランザクション 40並列実行 2.データ変換 /Work /システムA /店舗A/yyyymmdd/*.csv /店舗B/yyyymmdd/*.csv /店舗C/yyyymmdd/*.csv ・ ・ ・ (スキャンした物件CSVファイル) 内部からのみアクセス可能 作業テーブル初期化 物件データダウンロード NGデータチェック データ変換 差分反映 ポータル登録用Tsvファイル作成 物件テーブルの更新 1. 2. 3. 4. 5. 6. 7. 取得 配置 RDS Proxy DB 物件テーブルと 作業テーブルにわけている
更新料が1円?! 交通情報がない?! 3階の建物なのに 部屋は5階?! 沿線情報はあるけど、距離 や徒歩時間情報がない?! 居住中なのに 即時入居可?! 住所が古い?! こんば
1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録 2-1.NGデータチェック
物件名や部屋番号などの少ない情報 を保持したテーブルを検索 まずは新規か既存かチェックする 物件名+部屋番号+賃料+敷金/礼金 +住所情報+沿線情報+構造+画像情報 +設備+建物情報+駐車場+フリーレン ト+入居可能日...etc あらゆる項目を文字列で結合 ハッシュ化 e56d5123807bdf4d166...(略)
既存なら更新か否かをチェックする テーブル2 テーブル1 2-2.差分反映 こんば 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録
例えば 入居可能日が2022/09/08の場合 ▼9/7に変換を実施 →まだ未来日なので「2022/09/08」と出力 ▼9/8以降に変換を実施 →入居可能なので「即時」のように出力 こんば 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック
2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録 なぜ変換後に差分チェックをするのか 変換前は同じでも変換後に変わることがある 2-2.差分反映
全物件 掲載中物件 物件テーブル 作業テーブル 変換開始時 最後に戻す 2-3.物件テーブル更新 こんば 1.ファイルスキャン 2.データ変換
2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 掲載中物件のみを扱うことで パフォーマンスを保つ 4.結果通知 3.データ登録
こんば ある程度実装した後の出来事 おや、、データ変換だけで数時間かかりそうだぞ。。 for文多いのか?並列処理必要か? プログラム各所で実行時間を計測してデバッグ ループ内でクラス生成しまくっている凡ミス 修正することで大幅に改善 結果、ストイックにしなくても変換は数分だった 2-4.データ変換の余談 1.ファイルスキャン
2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録
Lambda ポータルサイトDB S3(内部用) 差分反映で出たSTOREファイル 差分反映で出たDELETEファイル /TSV /システムA /店舗A/yyyymmdd/*_store.tsv /店舗B/yyyymmdd/*_store.tsv /店舗C/yyyymmdd/*_store.tsv
・ ・ /TSV /システムA /店舗A/yyyymmdd/*_delete.tsv /店舗B/yyyymmdd/*_delete.tsv /店舗C/yyyymmdd/*_delete.tsv ・ ・ 内部からのみアクセス可能 追加 更新 削除 参照 TSVファイルを読み取り BULK_INSERT BULK_UPDATE BULK_DELETE 実行 こんば 3.データ登録 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 4.結果通知 3.データ登録 並列実行 一括処理 40並列実行
Step Functions 4.データ登録(Lambda) 3.データ変換(ECS) 5.結果通知(Lambda) 1.物件データ(CSV)のスキャン 2.排他処理(Lambda) 実行対象件数 実行対象件数と 処理完了件数を
比較して Slackに通知 Slack 通知例 4.結果通知 こんば 1.ファイルスキャン 2.データ変換 2-1.NGデータチェック 2-2.差分反映 2-3.物件テーブル更新 2-4.データ変換の余談 [成功] 結果: 240/240 Aシステムが正常終了しました。 [失敗] 結果: 239/240 失敗店舗: B店舗 Aシステムが異常終了しました。 4.結果通知 3.データ登録 処理完了件数
運用(おまけ)
運用 - エラーログ Datadog Step Functions実行時に出力したログを連携 検索やフィルターなどエラーログの調査が容易 Slackへ通知
運用 - 物件調査 Big Query 連携直後の物件CSVを全て保持 変換後の登録用TSVを全て保持 過去にどんな物件があったかをSQLで検索 変換結果の履歴もSQLで検索
運用 - フィードバック ダッシュボード (Redash) 警告やエラー内容をダッシュボードに反映 物件の入稿担当の方へのフィードバックの仕組み
不動産のシステムを 1年やって思ったこと
fin