docker初心者です。
AWSのEC2でRailsアプリをデプロイしようとしています。
使用しているものはDocker,nginx,puma,mysqlです。
docker-compose buildまでは正常にできたのですが、
docker-compose upを実行するとappコンテナが起動できません。
pumaが起動するとpuma.sockファイルができるみたいなのですが、作成されません。
どこを直せばいいのかわからず行き詰ってしまったのでどなたか教えてください。
エラー内容
エラーログ
app_1 | Puma starting in single mode... app_1 | * Puma version: 5.4.0 (ruby 2.6.7-p197) ("Super Flight") app_1 | * Min threads: 5 app_1 | * Max threads: 5 app_1 | * Environment: production app_1 | * PID: 1 app_1 | * Listening on http://0.0.0.0:3000 app_1 | * Listening on unix:///rastlia_youtube/tmp/sockets/puma.sock app_1 | bundler: failed to load command: puma (/usr/local/bundle/bin/puma) app_1 | Errno::ENOENT: No such file or directory @ rb_sysopen - tmp/pids/server.pid
解決したいこと
コンテナを起動し、Railsアプリのページを表示したい。
試したこと
- nginxとpumaのpuma.sockパスの設定・確認
- フォルダの作成
tmp/sockets/
tmp/pids/
###フォルダ構成
/var/www/rastlia_youtube
├── containers
│ └── nginx
│ ├── Dockerfile
│ └── nginx.conf
├── docker-compose.yml
├── Dockerfile
├── environments
│ └── db.env
├── Gemfile
└── Gemfile.lock
【docker-compose.yml】 version: '3' services: app: build: context: . env_file: - ./environments/db.env # =========ローカルと本番切り替え=========== #本番 command: bundle exec puma -C config/puma.rb -e production #ローカル # command: # bundle exec puma -C config/puma.rb # ====================================== volumes: - .:/rastlia_youtube - public-data:/rastlia_youtube/public - tmp-data:/rastlia_youtube/tmp - log-data:/rastlia_youtube/log depends_on: - db db: image: mysql:5.7 environment: MYSQL_USER: name MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: rastlia_youtube env_file: - ./environments/db.env volumes: - db-data:/var/lib/mysql web: build: context: containers/nginx volumes: - public-data:/rastlia_youtube/public - tmp-data:/rastlia_youtube/tmp ports: - 80:80 links: - app depends_on: - app volumes: public-data: tmp-data: log-data: db-data:
【Dockerfile】 FROM ruby:2.6.7 # リポジトリを更新し依存モジュールをインストール RUN apt-get update -qq && \ apt-get install -y build-essential \ nodejs # yarnパッケージ管理ツールインストール RUN apt-get update && apt-get install -y curl apt-transport-https wget && \ curl -sS 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 && apt-get install -y yarn # Node.jsをインストール RUN curl -sL https://deb.nodesource.com/setup_14.x | bash - && \ apt-get install -y nodejs # ルート直下にrastlia_youtubeという名前で作業ディレクトリを作成(コンテナ内のアプリケーションディレクトリ) RUN mkdir /rastlia_youtube WORKDIR /rastlia_youtube # ホストのGemfileとGemfile.lockをコンテナにコピー ADD Gemfile /rastlia_youtube/Gemfile ADD Gemfile.lock /rastlia_youtube/Gemfile.lock # bundle installの実行 RUN bundle install # ホストのアプリケーションディレクトリ内をすべてコンテナにコピー ADD . /rastlia_youtube # puma.sockを配置するディレクトリを作成 RUN mkdir -p tmp/sockets
【nginx.conf】 # プロキシ先の指定 # Nginxが受け取ったリクエストをバックエンドのpumaに送信 upstream rastlia_youtube { # ソケット通信したいのでpuma.sockを指定 server unix:///rastlia_youtube/tmp/sockets/puma.sock; } server { listen 80; # =========ローカルと本番切り替え=========== #本番 server_name ec2-DNS名 #ローカル # server_name localhost; # ====================================== access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; # ドキュメントルートの指定 root /rastlia_youtube/public; client_max_body_size 100m; error_page 404 /404.html; error_page 505 502 503 504 /500.html; try_files $uri/index.html $uri @rastlia_youtube; keepalive_timeout 5; # リバースプロキシ関連の設定 location @rastlia_youtube { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_pass http://rastlia_youtube; } }
【Dockerfile(nginx)】 FROM nginx:1.15.8 # インクルード用のディレクトリ内を削除 RUN rm -f /etc/nginx/conf.d/* # Nginxの設定ファイルをコンテナにコピー ADD nginx.conf /etc/nginx/conf.d/rastlia_youtube.conf # ビルド完了後にNginxを起動 CMD /usr/sbin/nginx -g 'daemon off;' -c /etc/nginx/nginx.conf
【puma.rb】 threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }.to_i threads threads_count, threads_count max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 } min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count } threads min_threads_count, max_threads_count worker_timeout 3600 if ENV.fetch("RAILS_ENV", "development") == "development" port ENV.fetch("PORT") { 3000 } environment ENV.fetch("RAILS_ENV") { "development" } pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" } plugin :tmp_restart app_root = File.expand_path("../..", __FILE__) bind "unix://#{app_root}/tmp/sockets/puma.sock" stdout_redirect "#{app_root}/log/puma.stdout.log", "#{app_root}/log/puma.stderr.log", true
あなたの回答
tips
プレビュー