現在、railsアプリケーションをdockerを用いて開発しようと思っています。
既にアプリケーションは途中まで開発していて、途中からのdocker導入となります。
一通りセットアップは済ませ、既存のアプリケーションをdocker上で動かすことは可能になりました。
しかし、色々なサイトを見ていてbundleに関するいくつかの疑問が浮上しました。
現在のDockerfileはこのようになっています。
FROM ruby:2.5.0 RUN apt-get update -qq && apt-get install -y nodejs postgresql-client RUN mkdir /myapp WORKDIR /myapp COPY Gemfile /myapp/Gemfile COPY Gemfile.lock /myapp/Gemfile.lock RUN bundle install COPY . /myapp COPY entrypoint.sh /usr/bin/ RUN chmod +x /usr/bin/entrypoint.sh ENTRYPOINT ["entrypoint.sh"] EXPOSE 3000 CMD ["rails", "server", "-b", "0.0.0.0"]
また、docker-copmose.yml
version: "3" services: backend: build: context: ./backend command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" volumes: - ./backend:/myapp ports: - "3000:3000" links: - db db: image: postgres:12 ports: - "5432:5433" volumes: - postgresql-data:/var/lib/postgresql/data volumes: postgresql-data: driver: local
まず、新たにgemを追加しようとします。
ホスト側のGemfileに
gem hogehoge
を追加し、
docker-compose build
を実行したとします。
この場合、Dockerfile内の
COPY Gemfile /myapp/Gemfile COPY Gemfile.lock /myapp/Gemfile.lock
が変更を検知して、その次のRUN bundle install
を実行すると思います。
この時、Dockerイメージ内にはCOPYされてきたGemfile内のパッケージはインストールされていない状態だと思うので、1から全てのgemをinstallすることになると思います。
その結果、Gemfile.lockがbundle install
が実行された後の依存関係を新たに記載した状態になると思います。
しかし、この後の
COPY . /myapp
によって、ホスト側のbundle install
していない状態のGemfile.lockがCOPYされ、bundle install
後のGemfil.lcokの内容が上書きされると思うのですが、どうなんでしょうか?
また、docker-compsoe.ymlのvolumes: ./backedn:/myapp
の記載によって上記と同じようにbundle install
が済んでいない状態のホスト側のGemfile.lockがコンテナ内にマウントされて古いGemfile.lockが上書きされ、Gemfile.lock以外にもbundleディレクトリ
がまだホスト側では更新されていないので古いbundleディレクトリがコンテナ内にコピーされると思うのですが、このような考え方があっているのでしょうか?
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/09/30 04:48
2019/09/30 06:23
2019/09/30 07:16