HerokuでRailsアプリケーションを公開した
data:image/s3,"s3://crabby-images/83bc0/83bc0baebb6c498ace03cd0e56ac79f3465e71cc" alt=""
はじめに
ポートフォリオとして作成中のRailsアプリ「Money App」をとりあえず公開する。
data:image/s3,"s3://crabby-images/6b557/6b557dcd3cc56b27c61e6ae42aa695a7da20b900" alt=""
gemfileを改修
data:image/s3,"s3://crabby-images/5838e/5838e099c71f0e415e7ddffb809415664ede3e28" alt=""
この記事の通りに改修を行ったら、「bundle install –without production」をターミナルに打ち込んだところでエラーが出た。
data:image/s3,"s3://crabby-images/34db7/34db70c0d62fa8a41f96c76153c812f206f2a96b" alt=""
出ていたエラーメッセージ。
Gem::Ext::BuildError: ERROR: Failed to build gem native extension.
An error occurred while installing sqlite3 (1.3.13), and Bundler cannot continue.
In Gemfile:
sqlite3
Gemfileの変更を元に戻した。
herokuでnew appを作成した
data:image/s3,"s3://crabby-images/aaff3/aaff39e99527b98efb7f980342db8f7911bdf70b" alt=""
以下のように、新しいアプリを作成した。地域はアメリカかヨーロッパしか選べなかった。
data:image/s3,"s3://crabby-images/0f1cf/0f1cfaf093758b043fb5f981a60deffb67130780" alt=""
支払い方法を追加する必要があるみたいなので、Add Payment Methodをクリックした。
We won’t charge you at this time. とのこと。
今回は課金されませんという意味である。
最初のアプリでは課金されないということだろう。
クレジットカードを登録する時に、1.00USDが課金されているのが気になった。
data:image/s3,"s3://crabby-images/7026e/7026ec74e4fb66479f7fab0de11edc7d324962a0" alt=""
ただ、アプリを見てみると、0になっていたので安心した。
data:image/s3,"s3://crabby-images/d0c45/d0c450bddfea9857da14960fcc4daa7510f3d46d" alt=""
もう一度アプリの作成の手続きを行うと完了することができた。
この画面になった。
data:image/s3,"s3://crabby-images/e4707/e4707abbd250cf7cd36d1a2adc5dc20485813b89" alt=""
GitHubと接続する
GitHubと繋げるという作業を行っていく。
data:image/s3,"s3://crabby-images/309a6/309a6b9225c718801ee3e0a22fb8ef0bfab88fc0" alt=""
GitHubのアイコンを選択した後に下のほうに出てきたボタンを押すと、GitHubにログインする画面が出てきた。
そこで、Herokuを認証していいですか?という確認画面が出てきて、「はい」を押すと、以下の画面になった。
data:image/s3,"s3://crabby-images/ffec1/ffec1a9ba0b50fd5ba43fad37c2368ddea9e3ee3" alt=""
ここで、公開したいリポジトリのリポジトリ名を入力するのがいいだろう。
data:image/s3,"s3://crabby-images/fdc00/fdc007a19041f60fc6dcb2af5ffaee6ca4a0c5ac" alt=""
money-appというレポジトリー名なので、こちらを入力していく。
data:image/s3,"s3://crabby-images/8d896/8d8960eb2d2f51bf44a83a21fb60133f4a1a2d48" alt=""
見つかったのでコネクトする。
無事、コネクトされたようだ。
data:image/s3,"s3://crabby-images/51def/51def521176c89270cd721c25210479aeba9e2a1" alt=""
GitHubから公開する
いよいよ最終段階に入っていく。
data:image/s3,"s3://crabby-images/ff0d2/ff0d28420aa944342befbfe9068e9a4d87e8e030" alt=""
下のほうにスクロールすると、Deploy Branchというボタンがあるので、公開したいブランチ名が選択されていることを確認してボタンをクリックする。
ビルドが上手く行かなかった
いろんな処理が走ってビルドが完成したようだ。いや、うまくいかなかったようだ。
data:image/s3,"s3://crabby-images/90dcf/90dcf272c57e61cd58b30e144a434b963b3a6b83" alt=""
ログメッセージはこちら。
-----> Building on the Heroku-22 stack
-----> Determining which buildpack to use for this app
-----> Ruby app detected
-----> Installing bundler 2.3.25
-----> Removing BUNDLED WITH version in the Gemfile.lock
-----> Compiling Ruby/Rails
-----> Using Ruby version: ruby-3.1.2
-----> Installing dependencies using bundler 2.3.25
Running: BUNDLE_WITHOUT='development:test' BUNDLE_PATH=vendor/bundle BUNDLE_BIN=vendor/bundle/bin BUNDLE_DEPLOYMENT=1 bundle install -j4
Your bundle only supports platforms ["x86_64-darwin-20", "x86_64-darwin-23"] but
your local platform is x86_64-linux. Add the current platform to the lockfile
with
`bundle lock --add-platform x86_64-linux` and try again.
Bundler Output: Your bundle only supports platforms ["x86_64-darwin-20", "x86_64-darwin-23"] but
your local platform is x86_64-linux. Add the current platform to the lockfile
with
`bundle lock --add-platform x86_64-linux` and try again.
!
! Failed to install gems via Bundler.
!
! Push rejected, failed to compile Ruby app.
! Push failed
上記の赤字部分、以下の部分が重要そうだった。重要なことだからなのか、2回繰り返していた。
Your bundle only supports platforms ["x86_64-darwin-20", "x86_64-darwin-23"] but your local platform is x86_64-linux.
Add the current platform to the lockfile with `bundle lock --add-platform x86_64-linux` and try again.
日本語にすると、以下のようになる。
あなたのバンドルは、["x86_64-darwin-20", "x86_64-darwin-23"]というプラットフォームのみをサポートしている。しかし、あなたのローカルプラットフォームは、x86_64-linuxである。
bundle lock --add-platform x86_64-linuxで、現在のプラットフォームに追加して、もう一度やり直してください。
言われた通りのコマンドを打ってみる
Gemfile.lockに「x86_64-linux」の記述が追加された。
data:image/s3,"s3://crabby-images/19a89/19a89181f2fce96ba3bfe6b664c350ce06974b05" alt=""
data:image/s3,"s3://crabby-images/a75d2/a75d2ecf3028d465bf3f2713a09c9135346bf650" alt=""
この変化点を反映させるために、GitHubにプッシュする一連の流れを行う。
data:image/s3,"s3://crabby-images/a5b7b/a5b7bf1949960878fa1d823a94c924d615855aa6" alt=""
もう一度トライ
先程のエラーが解決されてうまくいったようだ。
data:image/s3,"s3://crabby-images/947a6/947a6ea016940a148ad9a2c8e0cd20462bccaa27" alt=""
Viewボタンをクリックすると、公開されたページに飛ぶことができた。
data:image/s3,"s3://crabby-images/18c7f/18c7fb60ad2b3bf236937fb7629fb1a631fa4ec3" alt=""
コメントを残す