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
比較サイトの検索改善(SPA から SSR に変換)
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
gree_tech
PRO
November 11, 2021
Technology
620
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
比較サイトの検索改善(SPA から SSR に変換)
GREE Tech Conference 2021 で発表された資料です。
https://techcon.gree.jp/2021/session/Session-3
gree_tech
PRO
November 11, 2021
More Decks by gree_tech
See All by gree_tech
変わるもの、変わらないもの :OSSアーキテクチャで実現する持続可能なシステム
gree_tech
PRO
0
4.6k
マネジメントに役立つ Google Cloud
gree_tech
PRO
0
60
今この時代に技術とどう向き合うべきか
gree_tech
PRO
3
2.7k
生成AIを開発組織にインストールするために: REALITYにおけるガバナンス・技術・文化へのアプローチ
gree_tech
PRO
0
410
安く・手軽に・現場発 既存資産を生かすSlack×AI検索Botの作り方
gree_tech
PRO
0
410
生成AIを安心して活用するために──「情報セキュリティガイドライン」策定とポイント
gree_tech
PRO
1
2.2k
あうもんと学ぶGenAIOps
gree_tech
PRO
0
530
MVP開発における生成AIの活用と導入事例
gree_tech
PRO
0
560
機械学習・生成AIが拓く事業価値創出の最前線
gree_tech
PRO
0
430
Other Decks in Technology
See All in Technology
Mastering Ruby Box
tagomoris
3
150
トークン数だけでは測れない — Claude Code 組織展開の効果検証から学んだこと
makikub
0
140
EventBridge Connection
_kensh
5
660
Djangoユーザが知っ得なPostgreSQL機能 - 設計の選択肢を増やす / Djang-use-PostgreSQL
soudai
PRO
0
210
非定型業務をAI slackbotで自動化する ~ 社内要望を自動壁打ちするbotを作った ~/automating-ad-hoc-work-with-ai-slackbot
shibayu36
0
400
AIの性能が向上しても未解決な組織の重大問題は何か?/An Unsolved Organizational Problem in the Age of AI
moriyuya
2
390
GoとSIMDとWasmの今。
askua
3
520
Databricks における 生成AIガバナンスの実践
taka_aki
1
350
ブロックチェーン / Blockchain
ks91
PRO
0
110
データ基盤をDataformで整えた話 〜 開発環境を添えて 〜
takapy
0
130
「速く作る」から「正しく作る」へ ─ 生成AI時代の開発フロー改革の ロードマップと実行 ─
starfish719
0
8.9k
新規事業を牽引する技術選定 〜フルスタックTypeScript開発の実践事例〜
nullnull
3
370
Featured
See All Featured
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Raft: Consensus for Rubyists
vanstee
141
7.5k
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
A Modern Web Designer's Workflow
chriscoyier
698
190k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
Odyssey Design
rkendrick25
PRO
2
690
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Unsuck your backbone
ammeep
672
58k
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.3k
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.9k
Transcript
比較サイトの検索改善 (SPAからSSRに変換) アウモ株式会社 サーバーサイドエンジニア 天野桂輔
• 名前 • 天野 桂輔 • 担当 • サーバーサイドエンジニア •
Ruby on Rails、Nuxt.js • 経歴 • 2013- グリー株式会社 • GREE Platform 部に所属 • 2020- アウモ株式会社 • 比較サイト、aRM※の開発担当 ※CRMツール 自己紹介 2
aumoはご存知ですか? ⓘ Start presenting to display the poll results on
this slide.
4 aumoってどんなサービス? 国内最大級のおでかけ情報サービス 1300万 500万 月間ユーザー数 アプリDL数 50万 掲載記事数 総口コミ数
50万 掲載メディア数 500
5 aumoってどんなサービス? Web記事 SEOに最適化された コンテンツ制作 Web記事 Web記事 Web記事 位置情報、閲覧傾向を利用 レコメンドシステム
App ユーザーの口コミを活用 おでかけCGM Web施設
6 Web記事 カテゴリ 技術スタック プログラム言語 / FW Ruby / Ruby
on Rails インフラ AWS データベース MySQL, Redis, Memcached, DynamoDB 監視 Datadog, Papertrail, PagerDuty 分析 Bigquery, PoT ※社内分析ツール 検索エンジン ElasticSearch コード管理 GitHub Web記事 SEOに最適化された コンテンツ制作 Web記事
7 App Web記事 カテゴリ 技術スタック プログラム言語 / FW Ruby /
Ruby on Rails, Swift, Kotlin, Python インフラ AWS データベース MySQL, Redis, Memcached, DynamoDB, FireStore Database 監視 Datadog, Papertrail, PagerDuty, Firebase 分析 Bigquery, PoT ※社内分析ツール 検索エンジン ElasticSearch 機械学習 SageMaker, fastText コード管理 GitHub 位置情報、閲覧傾向を利用 レコメンドシステム App
8 Web施設 Web記事 カテゴリ 技術スタック プログラム言語 / FW Ruby /
Ruby on Rails, Vue.js, Nuxt.js インフラ AWS データベース MySQL, Redis, Memcached, DynamoDB 監視 Datadog, Papertrail, PagerDuty, Sentry 分析 Bigquery, PoT ※社内分析ツール 検索エンジン ElasticSearch コード管理 GitHub Web施設 ユーザーの口コミを活用 おでかけCGM
9 比較サイトとは? Web記事 Web記事 位置情報、閲覧傾向を利用 レコメンドシステム App ユーザーの口コミを活用 おでかけCGM Web施設
Web記事 SEOに最適化された コンテンツ制作 Web記事
10 施設情報を提供するサービス 比較サイトとは? • 施設 • 基本情報、写真、口コミ • 検索 •
ジャンル×エリア×カテゴリで施設を検索 ホテル グルメ レジャー・観光 チラシ・ショッピング
11 構成 フロントエンド バックエンド ELB 同一インスタンスに搭載 サブドメイン
12 当初のフロントエンド設計 UXを優先したSPAという方法を採用
13 Single Page Application SPA ページ遷移することなく同一のページ内でコンテンツのみ切り替 え サーバー ELB クライアント
①リクエスト ③レスポンス ②コンテンツ生 成 ④JSをブラウザで実行 ※2回目以降は差分のみリクエスト するため処理が早い
14 SPA • メリット • 2回目以降は差分のデータのみを要求するため早い • デメリット • 初回のページ読み込みが遅い
Single Page Application
15 比較サイトの成長に伴い、初回読み込みの遅延が顕著に。。。
16 特に、施設の検索が遅い
17 検索の課題 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策
18 検索の課題 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策
19 コンテンツ表示までの速度 検索の課題 • コンテンツ生成が非同期 • レンダリングに時間がかかる
20 検索の課題 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策
21 検索エンジン最適化(SEO)対策 検索の課題 • コンテンツ生成が非同期で評価できない • Web記事はSEOに強い • ノウハウを共有したい Web記事
SEOに最適化された コンテンツ制作 Web記事
22 検索の課題 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策 解決策:SPAからSSR(同期生成)に仕様変更
23 Server Side Rendering SSR Webページのレンダリングをブラウザの代わりにサーバ上で行う サーバー ELB クライアント ①リクエスト
③レスポンス ②コンテンツ生 成 ・HTML生成 ・JS実行 ※ Node.js必要 ④コンテンツ表 示 ※画面の表示において有用な アプリケーションの機能
24 SSR • メリット • 画面の表示が早い • デメリット • サーバー側の負荷が高い
• Node.js サーバー環境が必要 Server Side Rendering
25 つまり
26 SPAからSSR(同期生成)に仕様を変更することで • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策 を改善できる
27 仕様変更 • 検索処理 • Vue components 内 mounted 時に実行
• しかも、ジャンル毎に似たような処理がある... mounted () { return this.search() }, search () { const page = this.$route.query.page || 1 : 検索パラメータ設定 : this.searchGourmetAction({ searchQuery, page }) // store経由でAPIリクエスト } 変更前
28 Life Cycle NuxtJS nuxt ServerInit Route Middleware fetch() asyncData()
created() fetch() mounted() validate() ・初回アクセス時に実行される ・ストアに事前にデータを格納する ☆ page components のみ利用可能 ★ 全ての Vue components で利用可能 ・条件の設定やチェックを行う ・page リダイレクトに利用 ☆ 動的ルーティングのパラメータを検証 Vuex store component data ☆ page レンダリング前にデータを取得 ★ Vue インスタンスが生成されたときに呼び出される ★ Vue インスタンスが生成された後に呼び出される ★ DOM がレンダリングされたときに呼び出される
29 Life Cycle NuxtJS nuxt ServerInit Route Middleware fetch() asyncData()
created() fetch() mounted() validate() DOM がレンダリングされた後に検索
30 Life Cycle NuxtJS nuxt ServerInit Route Middleware fetch() asyncData()
created() fetch() mounted() validate() page レンダリング前に検 索
31 ① 検索処理の移行 仕様変更 • 検索処理 • page components 内
fetch 時に実行 • page 全てに同様の処理を置くのは微妙なので... async fetch ({ app, route }) { return await Promise.all([ app.$categorySearch({ route }) ]) },
32 ② 検索処理の共通化 仕様変更 • plugin 利用 • ジャンル毎の検索処理を共通化 export
default ({ store, req }, inject) => { inject('categorySearch', async ({ route }) => { const page = route.query.page || 1 switch (process.host) { case process.env.GOURMET_DOMAIN: : 検索パラメータ設置 : await store.dispatch('gourmetSearch/searchGourmetAction', { searchQuery, page }) break : } }) } ※ ブラウザ環境に帰属するオブジェクト(window, document)にはアクセス不可
33 ③ 検索ページ導線を変更 仕様変更 • 検索ページへの遷移処理を修正 • <NuxtLink>によるページ遷移はクライアント側で実行 • ブラウザをハード再読み込みしてサーバーへリクエスト
34 まとめ
35 改善項目 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策
36 改善項目 • コンテンツ表示までの速度 • リクエストからコンテンツ表示までの速度:55~62%⬇ • 検索エンジン最適化(SEO)対策
37 改善項目 • コンテンツ表示までの速度 • 検索エンジン最適化(SEO)対策 • 初回読み込み時に全てのコンテンツを生成
38 改善項目 • コンテンツ表示までの速度 • リクエストからコンテンツ表示までの速度:55~62%⬇ • 検索エンジン最適化(SEO)対策 • 初回読み込み時に全てのコンテンツを生成
39 学び
40 NuxtJS • SSR導入は困難ではない • Node.js サーバー環境を準備 • Nuxt Life
Cycle 理解 ※クライアント、サーバーの処理 • 同様の課題があるサービスに有用 • ページ単位で導入も可能
41 引き続きより良いサービス作りを心掛けていきます これからもaumoを宜しくお願いしますmm
42