Docker・Rails7・TailwindCSS・DaisyUIでFly.ioにデプロイできる環境構築
自己紹介
はじめまして、はると申します。
駆け出しエンジニアとして働き始めて約4ヶ月弱が経過しました🐣
概要
下記環境で、Fly.ioにデプロイまでできる環境構築についてまとめました。
環境
- Mac OS(Apple Silicon)
- Docker
- Ruby on Rails (Ruby 3.2.3、Rails 7.1.3)
- Tailwind
- DaisyUI
- PostgreSQL(Fly Postgres)
- Fly.ioにデプロイ
環境構築手順
Docker環境構築
-
touch Dockerfileを実行します。
Dockerfileの中身は以下のとおりです。DockerfileARG RUBY_VERSION=ruby:3.2.3 ARG NODE_VERSION=20 FROM $RUBY_VERSION ARG RUBY_VERSION ARG NODE_VERSION ENV LANG C.UTF-8 ENV TZ Asia/Tokyo RUN curl -sL https://deb.nodesource.com/setup_${NODE_VERSION}.x | bash - \ && wget --quiet -O - /tmp/pubkey.gpg https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \ && echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \ && apt-get update -qq \ && apt-get install -y build-essential nodejs yarn RUN mkdir /app WORKDIR /app RUN gem install bundler COPY Gemfile /app/Gemfile COPY Gemfile.lock /app/Gemfile.lock COPY yarn.lock /app/yarn.lock RUN bundle install RUN yarn install COPY . /app COPY entrypoint.sh /usr/bin/ RUN chmod +x /usr/bin/entrypoint.sh RUN bundle exec rails assets:precompile ENTRYPOINT ["entrypoint.sh"] CMD ["rails", "server", "-b", "0.0.0.0"] -
touch docker-compose.ymlを実行します。
docker-compose.ymlの中身は以下のとおりです。docker-compose.ymlservices: db: image: postgres:latest platform: linux/amd64 environment: TZ: Asia/Tokyo POSTGRES_PASSWORD: password volumes: - postgres_data:/var/lib/postgresql/data ports: - 5432:5432 web: build: . command: bash -c "bundle && yarn && bundle exec rails db:prepare && yarn build && yarn build:css && rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" tty: true stdin_open: true volumes: - .:/app - bundle_data:/usr/local/bundle:cached - node_modules:/app/node_modules environment: TZ: Asia/Tokyo ports: - "3000:3000" depends_on: - db volumes: postgres_data: bundle_data: node_modules: -
touch entrypoint.shを実行します。
entrypoint.shの中身は以下のとおりです。entrypoint.sh#!/bin/bash set -e rm -f /app/tmp/pids/server.pid if [ "$RAILS_ENV" = "production" ]; then bundle exec rails assets:clobber bundle exec rails assets:precompile bundle exec rails db:migrate fi exec "$@" -
touch Gemfile Gemfile.lock yarn.lockを実行します。
Gemfileの中身は以下のとおりです。
Gemfile.lockとyarn.lockは編集しません。Gemfile# frozen_string_literal: true source "https://rubygems.org" gem "rails", "~> 7.1.3"
Rails newとDBセットアップ・Railsサーバー立ち上げ
-
下記コマンドでRails newします。
Overwrite /app/Gemfile? (enter "h" for help) [Ynaqdhm]と出てきた際にはyにします。bash(local)$ docker compose run --rm web rails new . --database=postgresql --css=tailwind --javascript=esbuild --skip-action-mailbox --skip-action-mailer --skip-test --skip-active-storage --skip-action-text -
docker compose buildを実行して再ビルドします。 -
config/database.ymlに以下を追加します。
database.ymldevelopment: <<: *default database: app_development + username: postgres + password: password + host: db + port: 5432 test: <<: *default database: app_test + username: postgres + password: password + host: db + port: 5432 -
下記コマンドでDBのセットアップをします。
bash(local)$ docker compose run --rm web rails db:create (local)$ docker compose run --rm web rails db:migrate -
サーバーを立ち上げて確認します。
localhost:3000/にアクセスし、画像のような画面が表示されればOKです。bash(local)$ docker compose up -d
DaisyUIのインストール
- 下記コマンドを実行します。bash
(local)$ docker compose exec web yarn add daisyui - tailwind.config.jsに以下を追加します。tailwind.config.js
module.exports = { content: [ './app/views/**/*.html.erb', './app/helpers/**/*.rb', './app/assets/stylesheets/**/*.css', './app/javascript/**/*.js' ], + plugins: [require("daisyui")], }
デプロイ準備・デプロイ
-
本番環境で
Blocked hosts: 〜〜.onrender.comのようなエラーが出るのを防ぐため、
config/environments/development.rb内に下記を追加します。development.rbRails.application.configure do # 〜省略〜 config.hosts.clear end -
あらかじめFly.ioのアカウントを作っておくとスムーズです。(GitHubログインが楽です)
クレジットカードの登録は必須です。(現在、従量課金で5$以下は無料ですが、詳しくは公式でご確認ください。)
また、Fly.ioを初めて使うorコマンドをインストールしてない場合は、flyのためのコマンドのインストールをします。bash(local)$ brew install flyctl -
アプリのフォルダ内にいる状態で下記コマンドを実行します。
bash(local)$ fly auth loginすると、ブラウザが自動で開くため、画面内の「Continue as 〇〇〜」をクリックします。
その後、ターミナルに戻り、successfully logged in as 〇〇と表示されていればOKです。 -
次に下記コマンドを実行します。
bash(local)$ fly launchターミナルで、
? Do you want to tweak these settings before proceeding? (y/N)と出てくるので、yを選択します。
すると、ブラウザ上の設定ページに自動で飛ばされます。このような画面です。
-
設定後、
Confirm Settingをクリックします。
すると、ターミナルが動き出し、デプロイの準備が行われます。
Once ready: run 'fly deploy' to deploy your Rails app.が表示されれば完了し、デプロイの準備OKです。 -
次に下記コマンドを実行してデプロイします。
bash(local)$ fly deployVisit your newly deployed app at https://アプリ名.fly.dev/と表示されるためURLにアクセスしRailsの初期画面が表示されていればデプロイ完了です🎉
まとめ
以前Fly.ioでDockerを使ったデプロイをするのに苦戦したことがあったのですが、この環境であれば無事にデプロイまで行うことができました!
読んでいただきありがとうございました😊
Discussion