Upgrade to Pro — share decks privately, control downloads, hide ads and more …

【GAE、CloudSQL】Elixir/Phoenixで開発したDBアプリをGAEにデプロイ

0807d008e670d7eb0b674e0cfd104e22?s=47 KrainNeun
February 14, 2019

 【GAE、CloudSQL】Elixir/Phoenixで開発したDBアプリをGAEにデプロイ

0807d008e670d7eb0b674e0cfd104e22?s=128

KrainNeun

February 14, 2019
Tweet

Transcript

  1. 【GAE 、CloudSQL 】 Elixir /Phoenix で開発したDB アプリをGAE にデプロイ Hiroshi Kodama

    mike.kodama@karabiner.tech
  2. 自己紹介 名前: 児玉 寛 所属: カラビナテクノロジー株式会社 呼称: マイク GCP 歴:

    名前だけ知ってた Twitter など: @NeunKrain
  3. ここに来るまでの私 GCP ってなんか難しいと思ってた。 というか、クラウドという段階で躊躇していた。 弊社の開発合宿で、初めて顔見知りになった。 Elixir/Phoenix を最近利用してます。

  4. そうだ! GAE にデプロイしてみよう! と、いうことで実践しました。

  5. はじめに 詳細はQiita 記事あります。今回は抜粋してお話。 ※ Qiita 記事: GAE(+CloudSQL) 環境に Elixir+Phoenix をデプロイして動かしてみるまで。

    環境構築等がとっても簡単で、身近になれるんだ! が伝わればと思います。
  6. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  7. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  8. GCP の新規プロジェクトを作成 ダッシュボードから「新しいプロジェクト」を押 します。 プロジェクト名を決めて、作成ボタンを押します。 これだけです。簡単ですね!!

  9. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  10. CloudSQL のインスタンス作成 メニューからSQL を選びます インスタンス作成を押します。

  11. CloudSQL のインスタンス作成 データベースを選びます。 インスタンスID を決めて、作成ボタンを押します。 これだけです。簡単ですね!!

  12. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  13. GoogleCloudSDK のインストール・初期化 公式サイト を参考に導入します ローカルからCloudSQL に接続 ※CloudSQLProxy 公式サイト を参考にCloudSQLProxy を導入します

    これだけです。権限設定が少し大変です!! # UNIX ソケットの場合のプロキシ開始 sudo mkdir /cloudsql; sudo chmod 777 /cloudsql ./cloud_sql_proxy -dir=/cloudsql -instances=<INSTANCE_CONNECTION # プロキシへの接続 psql "sslmode=disable host=/cloudsql/<INSTANCE_CONNECTION_NAME>
  14. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  15. Elixir プロジェクト作成 Elixir プロジェクトを作成します。 mix phx.new gae_cloudsql_ex_phx --no-brunch DB 接続情報を修正します。※password

    とsocket_dir config :gae_cloudsql_ex_phx, GaeCloudsqlExPhx.Repo, adapter: Ecto.Adapters.Postgres, username: "postgres", password: ※CloudSQL のユーザパスワード, # ここ database: "gae_cloudsql_ex_phx_dev", socket_dir: "/cloudsql/<INSTANCE_CONNECTION_NAME>", # ここ pool_size: 10
  16. Elixir プロジェクト作成 簡単なAPI を作成し、Migrate 実行します。 mix phx.gen.json Api Test tests

    subject:text ~ 略~ mix ecto.migrate Migrate を実行後、CloudSQL を確認します。 DataBase が作成されていますね!
  17. やっていくこと GCP の新規プロジェクトを作成 CloudSQL のインスタンス作成 GoogleCloudSDK のインストール・初期化 ローカルからCloudSQL に接続 ※CloudSQLProxy

    Elixir プロジェクト作成 デプロイ・確認
  18. デプロイ・確認 コミュニティチュートリアル を参考にします。 ※ デプロイ準備のファイル修正箇所は割愛します。 デプロイコマンド実行 gcloud app deploy ※

    デプロイ対象プロジェクトを選ぶ場合は以下のようです。 gcloud app deploy --project=<PROJECT>
  19. デプロイ・確認 URL に接続します。 適当にポストしてみます。 無事、GAE での確認ができました!!

  20. まとめ

  21. まとめ 環境周りって難しいって思ってたんですが・・・ → GAE+CloudSQL の環境構築が簡単! → CloudSQLProxy での接続が簡単!! → デプロイもコマンド実行で簡単!!!

    GCP を利用することで・・・ → 環境周りがとても身近になった気がしました!!
  22. おわり