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

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

ただいまの
回答率

88.13%

Rails | 個人開発サービスにおける今時のデプロイ方法

解決済

回答 3

投稿

  • 評価
  • クリップ 2
  • VIEW 915
退会済みユーザー

退会済みユーザー

前提・実現したいこと

個人開発における望ましいデプロイ方法を探りたい。

要件

  • 基本流行らないのでコストは低いほうがいい。
  • 流行ってしまった時にDBの移行が可能であること。
  • デプロイに割く時間や労力は低いほうがよい

都合がいい要件で大変恐縮なのですが、上記のような要件を満たす場合、
Heroku や Elastic Beanstalkなどのサーバレスがやはり望ましいでしょうか。

気になる点1( もしHerokuを選んだ場合 )

Herokuのデータベースはpostgresqlなので、
AWSに移行時も勿論postgresqlになりますよね。
この点はMySQLを普段使う人にとってデメリットになりうるでしょうか?

気になる点2( もしHerokuを選んだ場合 )

HerokuS3みたく永久的なストレージがないと伺いました。
初期段階でHerokuを用いる場合は、やはり、S3などを使うことになりますでしょうか。
(画像などの格納が必要だとします)

もしご教授頂ける方いらしたら、宜しくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

+2

Heroku や Elastic Beanstalkなどのサーバレスがやはり望ましいでしょうか。

一般的にHerokuやEBのようなPaaSをサーバーレスとは言わない気がします(確かに語義はあいまいですが)。
AWS LambdaやGoogle Cloud FunctionsなどのFaaSのことを指すと思います。

基本流行らないのでコストは低いほうがいい。

アクセスの少ないサービスでとにかく安く抑えたいならFaaSだと思いますね。

流行ってしまった時にDBの移行が可能であること。

流行ったら移行する理由がよくわからないですがMySQLやPostgreSQLなどのメジャー所なら移行に問題は出にくそうです。
サーバーレスでよく使われるAWS DynamoDBやFirestoreは独自仕様ロックインが強いので移行大変かもしれないですね。

デプロイに割く時間や労力は低いほうがよい

これはPaaSのメリットですね。

Herokuのデータベースはpostgresqlなので、
AWSに移行時も勿論postgresqlになりますよね。
この点はMySQLを普段使う人にとってデメリットになりうるでしょうか?

PostgreSQLはMySQLに並ぶメジャーRDBなので私は特に気にしません。
どうしてもHerokuでMySQLが使いたければClearDBアドオンの選択肢もあります。

初期段階でHerokuを用いる場合は、やはり、S3などを使うことになりますでしょうか。

はい、そうです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/03/01 20:40

    ありがとうございます。非常に勉強になりました。
    > サーバーレスでよく使われるAWS DynamoDBやFirestoreは独自仕様ロックインが強いので移行大変かもしれないですね。
    ベンダーロックインといわれるものですよね、やはり移行が大変なのですね、、、再確認できました。
    ありがとうございます!

    キャンセル

+2

気になる点1( もしHerokuを選んだ場合 )
Herokuのデータベースはpostgresqlなので、
AWSに移行時も勿論postgresqlになりますよね。
この点はMySQLを普段使う人にとってデメリットになりうるでしょうか?

HerokuでもMySQLを利用可能です。
一番はpostgresql/MySQL等、自由に選択できることです。
「普段MySQLを使う人」は「postgresqlのスキルがない人」と読み替えると、
postgresqlに限定する場合は利用・運用実績がないということになります。

一般向けであればさほど気にすることではないと考えます。

HerokuはS3みたく永久的なストレージがないと伺いました。
初期段階でHerokuを用いる場合は、やはり、S3などを使うことになりますでしょうか。
(画像などの格納が必要だとします)

Webベースのオブジェクトストレージを利用したい場合はS3などを選定する事になります。

1.基本流行らないのでコストは低いほうがいい。
2.流行ってしまった時にDBの移行が可能であること。
3.デプロイに割く時間や労力は低いほうがよい

1と3はコストに係る要件かと思います。
コストが低いほうがいいのは当然ですが、開発にかかる工数、運用にかかる工数の考え方ではないでしょうか。
開発はどれだけでもかけれるなら、運用にお金がかからないよう例えばS3のような機能も組み込んでしまいましょう。
S3 Compatibleなアプリも存在します。

2については工数をかければ移行は可能です。

個人開発における望ましいデプロイ方法を探りたい。

最後に、この件への回答ですが、「個人開発」なのであれば、
一つのバイナリを置いて、1コマンド叩けばデプロイが済めば望ましいと思います。
S3部分はローカルで、DBはsqliteで等。

どちらにせよ個人開発のものをそのまま商用で使うことはまずあり得ないので、
そんな部分で悩むより、作りたいものをサクッと動かせてすぐに試せるものを提供すべきです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/03/01 20:38

    HerokuでMySQLを使えることは初耳でしたので、ありがとうございます!
    またS3 Compatible なアプリという話も存じ上げていませんでした。
    https://qiita.com/kotauchisunsun/items/c870bb65cfa12edcce13
    この辺の資料を見て確認するとよいでしょうか。
    「S3部分をローカルに」という文言が自分にとって「新しい」です。

    キャンセル

checkベストアンサー

+1

Heroku や Elastic Beanstalkなどのサーバレスがやはり望ましいでしょうか。

Heroku や Elastic Beanstalk などの PaaS は有力な選択肢になると思います。
EC2 などの IaaS も構成によっては低価格に抑えることができますので、合わせて検討することが多いです。

Herokuのデータベースはpostgresqlなので、
AWSに移行時も勿論postgresqlになりますよね。
この点はMySQLを普段使う人にとってデメリットになりうるでしょうか?

ClearDB アドオンを使えば、Heroku でも MySQL を使うことができます。
異なる DB の移管は面倒なので、できれば避けたいところです。

HerokuはS3みたく永久的なストレージがないと伺いました。
初期段階でHerokuを用いる場合は、やはり、S3などを使うことになりますでしょうか。
(画像などの格納が必要だとします)

Heroku でもアドオンを使えば様々なデータストアが利用できます。
もちろん S3 を使ってもいいと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/03/01 20:32

    HerokuでMySQLを使えるのは初耳でした!
    https://elements.heroku.com/addons#data-stores を拝見したのですが、
    Redisなども使えるですね、知らなかったので大変為になりました。
    ありがとうございます。

    キャンセル

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

  • ただいまの回答率 88.13%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る