質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

Amazon DynamoDB

Amazon DynamoDBは、 AWS上のNoSQLデータベースサービスです。フルマネージド型のサービスで、スキーマレス、高速且つ安定性のある動作、自動的に容量を変更する自動スケーリングなどの特徴を持ちます。

NoSQL

NoSQL(not only SQL)は、リレーショナルデータベース管理システムとは異なるデータベースシステムを指す言葉です。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

2回答

5148閲覧

RDS vs NoSQL どう使い分ければ良いのでしょうか?

ucndev

総合スコア14

Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

Amazon DynamoDB

Amazon DynamoDBは、 AWS上のNoSQLデータベースサービスです。フルマネージド型のサービスで、スキーマレス、高速且つ安定性のある動作、自動的に容量を変更する自動スケーリングなどの特徴を持ちます。

NoSQL

NoSQL(not only SQL)は、リレーショナルデータベース管理システムとは異なるデータベースシステムを指す言葉です。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

3クリップ

投稿2020/10/30 04:20

個人開発・スタートアップで採用すべき最強のアーキテクチャを考えた

上記記事で

RDS vs DynamoDB

結論から言うと問答無用でDynamoDBを選択することを推奨します。
正確にいうとDynamoDBでは表現しきれないデータ構造や複雑すぎるアクセスパターンの場合はRDSにせざるをえないのですが、初期のフェーズではDynamoDBで作って無理が出てきたらRDSとの併用を考えるという形が良いと思います。

との記載がありました。

この記事への人気コメントとして、

この理由でNoSQL採用すると後で死なない?NoSQLをRDBの代わりとして使わないほうがいいよ

これ、スタートアップではものすごい技術的負債になるので、普通に RDS にしたほうがいいよ。 “初期のフェーズではDynamoDBで作って無理が出てきたらRDSとの併用を考える”

という反応がありました。

もちろんどのようなデータがどんな要件で使われるかで適する構造は変わると思いますが、一般論として、どのような要件であればRDSが適していて、どのような要件ならNoSQLが適しているのでしょうか?

また、コメントではなぜこの文脈においてNoSQLに否定的な見解が支持を集めているのでしょうか?

これから作るシステムでNoSQL採用を少し検討していたタイミングでしたので、経験のある方の率直な感触を伺えたらと思いました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

RDBMSの重要な特性として、ACIDと言われるものがあります。

  • A…Atomicity(不可分性)1つのトランザクションが「完全に実行される」か「全く実行されない」かのどちらかになる
  • C…Consistency(一貫性)データベースレベルで、データに制約条件をかけて、それは必ず守られる
  • I…Isolation(独立性)トランザクションの途中経過は、他のトランザクションからは見えない
  • D…Durability(永続性)トランザクションの結果が確定すれば、そのデータが失われることはない

NoSQLは、これらの特徴を持たない、あるいは独自の形で実装しています。たとえば、DynamoDBでは自由な構造のデータを作成できますので、明らかにCと合致しません。

NoSQLを使う場合、その製品が担保していないデータ整合性は、別な方法で担保する必要が出てきます。

なお、Amazon自身がDynamoDBに合うかどうかのチェックリストを公開しています。

投稿2020/10/30 08:38

maisumakun

総合スコア145941

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ucndev

2020/10/31 01:35

ありがとうございます! RDBMSとNoSQLの構造的な違いがわかりました。 Amazonのチェックリストも拝見しました。 広く浅くというより狭く深いシーンに適合する印象で、プログラム側でケアすべき事項も多く、少なくとも盲目的に採用すべきものでないとの印象を受けました。
guest

0

ベストアンサー

SQL使いたければRDBMS(以降RDS)
RDSで困らなければRDS
よく分からなければRDS

勝手に引用された記事に対して意見言うのは悪い気がしますが、

初期のフェーズではDynamoDBで作って無理が出てきたらRDSとの併用を考えるという形が良いと思います。

かなり控えめに言ってありえないです
そんなシステムの面倒見てくれって言われたら相場より高くします。

これから作るシステムでNoSQL採用を少し検討していたタイミングでしたので、経験のある方の率直な感触を伺えたらと思いました。

それはそれで良いんじゃないでしょうか。何事も経験です。両方使ってそれぞれの特徴を知るのが良いでしょう。

投稿2020/10/30 05:25

hentaiman

総合スコア6426

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ucndev

2020/10/30 05:43

ありがとうございます! NoSQLの方がしっかりと目的とビジョンを持って設計・導入しないとデメリットが大きくなるのかな、と捉えました。 「よく分からなければRDS」←すごく心に響きました笑 でもNoSQLを触らずにいても仰られた言葉の意味を理解できないと思いましたので、まずは使ってみようと思います。 (勝手に引用した記事に言及させてしまい、申し訳ありませんでした。。。)
hentaiman

2020/10/30 07:34 編集

mysqlやpostgres等のRDBMS利用したシステム構築・設計の経験が無ければそちらを優先して作る事をおすすめします。 それをNoSQLに置き換えて作るとしたらどうするかで考えた方が良いです。 ※特徴が違うので置き換えるという考え方も不適切ですが
ucndev

2020/10/31 01:27

なるほどです。 以前RubyOnRails x PostgresでWEBアプリを作った時に、データが増えてきたらクエリ実行がレスポンスのボトルネックになってしまい、redisを導入してクエリ結果をキャッシュした時がありました。 レスポンスがかなり早かったので、もしかしたらもっとredisにデータを持たせても良いのかな、と感じました。 その際にredis documentsの日本語訳(http://redis.shibu.jp/tutorial/index.html)を見たのですが、ケーススタディに衝撃を受けました。 SET uid:1000:username antirez SET uid:1000:password p1pp0 SET username:antirez:uid 1000 uidとusernameとpasswordを別のkeyで保存している! postgresなら一発なのに、欲しいデータを取るためにプログラム側で担う事がとても多いなと感じました。 ソートも検索も別テーブルの連携も事前に予定していないと厳しそうだなと。 でもユースケースでtwitterライクなアプリを作れるなら、もしかしたら一般的にこうしたアプローチが初手で採用される世の中なのかな、、、と感じ、先のQiita記事と併せて不安になり質問させていただいた次第です。 誰にも気軽に聞けず不安でしたが、お答えを伺えて少し安心しました!ありがとうございました。
hentaiman

2020/10/31 01:36

質問とは関係無いけど回答したついでに、 そういう時はredisを検討する前にSQLチューニング、DBチューニングをするものです。 > postgresなら一発なのに、欲しいデータを取るためにプログラム側で担う事がとても多いなと感じました。 利用箇所が適していないだけか、他に適した手段があるのでは?と思います。 > でtwitterライクなアプリを作れるなら、もしかしたら一般的にこうしたアプローチが初手 twitterでこそNoSQLが最初の選択に来るなんてありえないです。 という事で、質問者の今の習熟度ならSQL・DBのチューニングを学習するのが一番良いんじゃないかと思います。次点でネットワーク。
ucndev

2020/10/31 01:40

ついでのご回答、誠にありがたいです・・・ キャッシュよりSQL・DBチューニングの方が先立つべしとの事ですね。 ありがとうございます!精進いたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問