LoginSignup
5
3

Renderの無料プランでDBを使う方法

Last updated at Posted at 2024-05-30

Renderとは

Renderは簡単にアプリなどのサービスを公開できるホスティングサービスです。
利用できる言語や機能も豊富でありながら、価格も抑えられた良いサービスです。

スクリーンショット 2024-05-24 20.52.56.png
参考:https://render.com

無料プランについて

Renderには複数のプランが存在していますが、無料プランでも豊富な機能が利用できます。
詳細は公式サイトのhttps://render.com/pricing をご覧いただければと思いますが、簡単なサイトの公開であれば、無料プランでも十分対応できます。

少し難点なのは無料プランの場合、DBが3ヶ月でリセットされてしまうという点です。DBを利用しないサービスであったり、とりあえずプロトタイプを作ってみるという場合には問題ないのですが、サービスを長期間維持し続けるためには結構痛手です。

DBを無料プランで使い続ける方法

有料プランに変更するという手もあるかと思いますが、ここでは無料プランを利用したまた、DBも維持し続ける方法について記載しようと思います。

私たちのプロジェクトではDBeaverというツールを利用しているため、そちらをもとに解説していきます。他のDBツールを利用していてもあまり差はないと思います。

大まかな流れはこんな感じです。

  1. DBのダンプファイルを作る
  2. RenderでDBを削除する
  3. Renderで新しいDBを作成する
  4. ダンプファイルを使用し、新しいDBでデータを復元する

DBのダンプファイルを作る

  1. DBeaverでRenderのDBに接続
     a. Host:Renderの管理画面 > Connections > Hostnameに.singapore-postgres.render.comを付加したもの(DBのゾーンが異なる場合はそこだけ変更)
     b. Database:Renderの管理画面 > Connections > Database
     c. ユーザー名:Renderの管理画面 > Connections > Username
     d. パスワード:Renderの管理画面 > Connections > Password
  2. DBeaverで(追加したデータベース) > データベース > (追加したデータベース)を右クリックし、ツール > バックアップを選択
  3. publicを選択
  4. Output folder patternに任意のフォルダを設定し、開始を押下
  5. ファイルが出力されたことを確認する

DBに外部から接続する場合には、Hostnameの後ろに{リージョン}-postgres.render.comをつける必要があるので、お忘れなく

RenderでDBを削除する

これはRenderの管理画面から簡単にできるで割愛。

Renderで新しいDBを作成する

こちらもRenderの管理画面から簡単にできるので割愛。
RegionやSQLのバージョンなどは元のものと揃えてください。

ダンプファイルを使用し、新しいDBでデータを復元する

  1. DBeaverでRenderの新しいDBに接続します
     a. ホスト名やDB名が変わっていますので、そこだけ変更をお忘れなく
  2. その後DBeaverで(追加したデータベース) > データベース > (追加したデータベース)を右クリックし、ツール > リストアを選択
  3. バックアップしたファイルを選択し、リストアを開始する
  4. モーダルが出た場合はOKを押す

その他

  • SQLのバージョンはRenderとローカルで同じものを利用した方が良いです
  • RenderにデプロイするアプリのDB接続に必要な情報はenvファイルなどの環境変数で保持しておき、DBの更新時に環境変数を更新する形にすると楽です(環境変数の更新はRenderの管理画面から行えます)
    • ソースコードを変更してデプロイすることもできますが、少し面倒なので
  • 正式にリリースしているサービスの場合は、作業開始前にメンテナンスモードへの切り替えを行なってください
5
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
3