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
PostgreSQL🐘と 比較しながら選ぶデータベース / select-database-u...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
soudai sone
PRO
July 25, 2020
Technology
3
1.6k
PostgreSQL🐘と 比較しながら選ぶデータベース / select-database-usecase
Open Source Conference 2020 Online/Niigataの登壇資料です。
https://ospn.connpass.com/event/181888/
soudai sone
PRO
July 25, 2020
Tweet
Share
More Decks by soudai sone
See All by soudai sone
外部キー制約の知っておいて欲しいこと - RDBMSを正しく使うために必要なこと / FOREIGN KEY Night
soudai
PRO
12
5.3k
手を動かしながら学ぶデータモデリング - 論理設計から物理設計まで / Data modeling
soudai
PRO
34
8.5k
これからアウトプットする人たちへ - アウトプットを支える技術 / that support output
soudai
PRO
20
8.2k
コミュニティと計画的偶発性理論 - 出会いが人生を変える / Life-Changing Encounters
soudai
PRO
8
3.6k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
62
49k
変化に強いテーブル設計の勘所 / Table design that is resistant to changes
soudai
PRO
68
20k
抽象化をするということ - 具体と抽象の往復を身につける / Abstraction and concretization
soudai
PRO
51
34k
目の前の仕事と向き合うことで成長できる - 仕事とスキルを広げる / Every little bit counts
soudai
PRO
41
56k
ソフトウェアエンジニアとしてキャリアの螺旋を駆け上がる方法 - 経験と出会いが人生を変える / Career-Anchor-Drive
soudai
PRO
20
7.1k
Other Decks in Technology
See All in Technology
顧客との商談議事録をみんなで読んで顧客解像度を上げよう
shibayu36
0
210
Ruby版 JSXのRuxが気になる
sansantech
PRO
0
150
Bill One 開発エンジニア 紹介資料
sansan33
PRO
4
17k
予期せぬコストの急増を障害のように扱う――「コスト版ポストモーテム」の導入とその後の改善
muziyoshiz
1
1.8k
生成AIを活用した音声文字起こしシステムの2つの構築パターンについて
miu_crescent
PRO
2
180
ClickHouseはどのように大規模データを活用したAIエージェントを全社展開しているのか
mikimatsumoto
0
220
CDK対応したAWS DevOps Agentを試そう_20260201
masakiokuda
1
240
Codex 5.3 と Opus 4.6 にコーポレートサイトを作らせてみた / Codex 5.3 vs Opus 4.6
ama_ch
0
130
StrandsとNeptuneを使ってナレッジグラフを構築する
yakumo
1
110
AI駆動PjMの理想像 と現在地 -実践例を添えて-
masahiro_okamura
1
110
生成AI時代にこそ求められるSRE / SRE for Gen AI era
ymotongpoo
5
3k
GitHub Issue Templates + Coding Agentで簡単みんなでIaC/Easy IaC for Everyone with GitHub Issue Templates + Coding Agent
aeonpeople
1
210
Featured
See All Featured
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
160
The Cost Of JavaScript in 2023
addyosmani
55
9.5k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
1.8k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
9.9k
A designer walks into a library…
pauljervisheath
210
24k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
1
1.4k
Ethics towards AI in product and experience design
skipperchong
2
190
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
270
Conquering PDFs: document understanding beyond plain text
inesmontani
PRO
4
2.3k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
0
320
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
730
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
240
Transcript
と 比較しながら選ぶデータベース ユースケース別に違いを見極め、RDBとNOSQLを使いける Open Source Conference 2020 Online/Niigata
と 比較しながら選ぶデータベース ユースケース別に違いを見極め、RDBとNOSQLを使いける Open Source Conference 2020 Online/Niigata RDBMS
データベースを正しく選択すること What is it?
データベースは 何を基準に選んでいますか? What is it?
データベースの選ぶには 特徴を掴むことが大切 What is it?
ユースケースに合わせて データベースの 種類と特徴を理解しよう! What is it?
https://speakerdeck.com/soudai/explanation-of-database-types アーキテクチャ別の違いの資料はこちら
1. 自己紹介 2. RDBとNOSQL 3. セッションを保存したい 4. まとめ あじぇんだ
1. 自己紹介 2. RDBとNOSQL 3. セッションを保存したい 4. まとめ あじぇんだ
自己紹介 曽根 壮大(35歳) Have Fun Tech LLC 代表社員 そ
ね たけ とも • 日本PostgreSQLユーザ会 勉強会分科会 担当 • 3人の子供がいます(長女、次女、長男) • 技術的にはWeb/LL言語/RDBMSが好きです • コミュニティが好き
1. 自己紹介 2. RDBとNOSQL 3. セッションを保存したい 4. まとめ あじぇんだ
RDBとNOSQL RDBとNOSQL
RDBとNOSQL ↓ なにが違うのか? RDBとNOSQL
RDBとNOSQL アーキテクチャ / データモデル マスタ型 P2P型 その他 リレーショナル MySQL PostgreSQL
ProxySQL pgpool-2 キーバリュー Redis Memcached Redis Cluster カラム指向 Redshift Cassandra ドキュメント指向 MongoDB グラフ指向 Neo4J InfiniteGraph ※代表的なデータベースのソフトウェアの抜粋
RDBとNOSQL アーキテクチャ / データモデル マスタ型 P2P型 その他 リレーショナル MySQL PostgreSQL
ProxySQL pgpool-2 キーバリュー Redis Memcached Redis Cluster カラム指向 Redshift Cassandra ドキュメント指向 MongoDB グラフ指向 Neo4J InfiniteGraph ※代表的なデータベースのソフトウェアの抜粋
リレーショナルデータモデルに 最適化されたデータベース 現在も多くのシステムで広く使われている RDBとNOSQL RDB
RDB以外のDBシステムの総称 (Not Only SQL) グラフデータモデルをはじめ、 RDBの不得意な分野に特化している RDBとNOSQL NOSQL
つまり、RDB以外はすべてNOSQL RDBとNOSQL
RDBと根本から違う RDBとNOSQL
• データモデルが違うのでデータ設計も違う • スケールアウトやスケールアップの有効性が違う • パフォーマンスチューニングの方法が違う • アプリケーションからの接続や扱い方が違う RDBとNOSQL RDBとNOSQLの違い
違いを捉えて特徴を掴む RDBとNOSQL
1. 自己紹介 2. RDBとNOSQL 3. セッションを保存したい 4. まとめ あじぇんだ
Webアプリケーションのセッション セッションを保存したい
Webアプリケーションのセッション ↓ どこに保存するか? セッションを保存したい
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
ApacheのWebサーバのローカルなどに セッションIDに紐づけて保存する。 シンプルな反面、複数のWebサーバ運用の時に セッション情報を共有するにはファイル共有が必要。
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
ブラウザのCookieの中にセッション情報も一緒に保存し、リク エストの際に一緒に送信する。 Webサーバが複数台でもセッションを共有できるので 負荷に対してはスケールするが、 Cookieをジャックされるなどの様々なリスクがある。 JSからCookieを触れる(HttpOnly=false)だと特に危険
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
RDBMSに保存したことありますか? セッションを保存したい
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
セッションをRDBMSに保存するとセキュリティ的にも安心。複数の Webサーバでセッション共有することができる。 しかし負荷が高くなるとRDBMSが問題になりやすい。 特にメインのデータと同じRDBMSで共有していると、 高負荷時にRDBMSにあわせ技で負担になる。
• ファイル • Cookie • RDBMS • NOSQL セッションを保存したい セッションの保存先
シンプルにWebサーバ間でセッションを共有できて、 セキュリティ的にも安心で、 スケールするデータストアが欲しい!!
どんなNOSQLがマッチするか? セッションを保存したい
どんなNOSQLがマッチするか? ↓ MemcachedとRedis セッションを保存したい
• 分散型インメモリKVS(キーバリューストア) ◦ マルチスレッドでMany CPUにも強い ◦ 簡単に分散することも出来る • しかし、AWSのElasticacheを使う場合は分散方法に注意が必要 ◦
同じセッションを取得するクライアント側の実装が必要 ◦ PHPはAWSが専用クライアントを提供してる。 • アトミックな処理は苦手なので、セッションのロックが使いたい場合の時は 注意が必要 ◦ 例えばSPAで非同期で同時にセッションを触るなど セッションを保存したい Memcached
• インメモリKVS(キーバリューストア) ◦ プライマリ、セカンダリ構成 ◦ クラスタ構成が作れるRedis Clusterもある • RDBMSと同じようにシンプルにセッションを扱える ◦
アトミックなロック処理が作れるので安心 • しかしRedis Clusterでない場合に書き込みはスケールしない ◦ そこでRedis Clusterなのだけど、お高くなりやすい • 多くのWebサービスなら1台でも対応可能 ◦ メンテナンス出来るなら、あとからCluster移行もできる範囲 セッションを保存したい Redis
RDBMSが問題になったら とりあえずRedisでも大丈夫 セッションを保存したい
1. 自己紹介 2. RDBとNOSQL 3. セッションを保存したい 4. キャッシュを使いこなしたい 5. まとめ
あじぇんだ
アーキテクチャ x データモデル ↓ データベースの種類と特徴を決める まとめ
保存したいデータモデル x 重視したいアーキテクチャ || 使うべきデータストア まとめ
正しく選べば RDBMSをもっと活かせる まとめ
長所と短所を知る まとめ
長所と短所を知る ↓ 要件に合わせる まとめ
“もし現在のアプリケーションがRDBで 上手く動いているのであれば、 それをNOSQLに置換する理由は無いし、 それを勧めたりはしない” Nate McCall (@zznate)
データベースの種類と特徴を捉えて 適切なデータベースを選ぶ まとめ
ご清聴ありがとうございました まとめ