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

N+1はダメなのか? システムを落としたあの日より

Hayato Nakamura
May 10, 2024
21

N+1はダメなのか? システムを落としたあの日より

2024-04-11
Cake.jp LT会 登壇資料
https://cakejp.connpass.com/event/314516/

Hayato Nakamura

May 10, 2024
Tweet

Transcript

  1. 2 © Cake.jp Co.Ltd. All Right Reserved.|Confidential 自己紹介 • 名前

    ◦ 中村 隼人 • 業務 ◦ バックエンドエンジニア(PHP/Kotlin/TypeScript) • おすすめ🍰 ◦ 子どもが野菜を食べてくれる ◦ 大人が食べてもおいしい
  2. 5 © Cake.jp Co.Ltd. All Right Reserved.|Confidential N+1を許容する場合 ・・・ 0.03s +

    0.02s * 1000 = 20.03s N+1を許容しない場合・・・ 0.03s 実験
  3. 6 © Cake.jp Co.Ltd. All Right Reserved.|Confidential • Nの件数が少ない、Nの実行時間が短ければそれほど影響はない。 ◦

    Nが動的に変化する場合がある。 ◦ 実行時間は1クエリの実行時間のみに依存しない。 • ORMが意図しないN+1を引き起こす可能性がある。 まとめ
  4. 7 © Cake.jp Co.Ltd. All Right Reserved.|Confidential • 商品に複数の送料を設定できるようにした。 •

    API経由で送料を取得できるようにした。 • 送料は商品単位で取得できる。 Cake.jpで実際にあった事例 - 送料プロジェクト -
  5. 8 © Cake.jp Co.Ltd. All Right Reserved.|Confidential • 商品に複数の送料を設定できるようにした。 •

    API経由で送料を取得できるようにした。 • 送料は商品単位で取得できる。 Cake.jpで実際にあった事例 - 送料プロジェクト - ある商品一覧で システムアラートが発生!! 504エラーが多発!
  6. 9 © Cake.jp Co.Ltd. All Right Reserved.|Confidential • その商品一覧では、それぞれの商品に送料を表示するロジックがあった。 ◦

    もともとは商品テーブルに送料のカラムがあり、送料取得部分をAPI コールに単純に置き換えた。 → これがN+1になった。 ◦ メインの商品一覧では送料を表示するロジックがなかったため、一括で 複数商品の送料を取得するエンドポイントがなかった。 ◦ 商品の表示数が設定ファイルによって決定され、普段は表示する商品 数が少なく問題に気付けなかった。 Cake.jpで実際にあった事例 - 送料プロジェクト -
  7. 10 © Cake.jp Co.Ltd. All Right Reserved.|Confidential • N+1はシステムを落とす。 ◦

    運がよくアクセス数が少なかったり、Nが少ないと気づけない。 ◦ エンドポイント設計は適切に。(一括取得機能がなかった) • 実行されているクエリ数、API発行数は見る。 Cake.jpで実際にあった事例 - まとめ -