前提
nginx、unicorn、Ruby on Rails、RDS、Dockerを用いてwebアプリをデプロイしようとしています。Dockerなしの状態であればサイトの表示まで行えるのですが、Dockerを利用しようとすると、エラーが出てunicornの起動がうまくいかない状況です。
実現したいこと
- unicornのエラーを解決し、パブリックIPでアクセスできるようにしたい
- unicornが含まれるコンテナのステータスをExited(1)からUPにしたい
発生している問題・エラーメッセージ
FATAL -- : error adding listener addr=/var/www/rails/myapp/tmp/sockets/.unicorn.sock bundler: failed to load command: unicorn_rails (/usr/local/bundle/bin/unicorn_rails) ArgumentError: socket=/var/www/rails/myapp/tmp/sockets/.unicorn.sock specified but it is not a socket! /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/socket_helper.rb:132:in `bind_listen' /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/http_server.rb:242:in `listen' /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/http_server.rb:877:in `block in bind_new_listeners!' /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/http_server.rb:877:in `each' /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/http_server.rb:877:in `bind_new_listeners!' /usr/local/bundle/gems/unicorn-6.1.0/lib/unicorn/http_server.rb:141:in `start' /usr/local/bundle/gems/unicorn-6.1.0/bin/unicorn_rails:209:in `<top (required)>' /usr/local/bundle/bin/unicorn_rails:23:in `load' /usr/local/bundle/bin/unicorn_rails:23:in `<top (required)>'
関連していると思われるソースコード
1. Dockerfile
2. docker-compose.yml
3. unicorn.conf.rb
1. Dockerfile
FROM ruby:2.6.10 RUN apt-get update -qq && \ apt-get install -y build-essential \ libpq-dev \ nodejs \ vim RUN curl https://deb.nodesource.com/setup_12.x | bash RUN curl https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - RUN echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list RUN apt-get update && apt-get install -y nodejs yarn postgresql-client RUN mkdir -p /var/www/rails/myapp WORKDIR /var/www/rails/myapp ADD Gemfile ./Gemfile ADD Gemfile.lock ./Gemfile.lock RUN gem install bundler RUN bundle install ADD . ./ RUN mkdir -p ./tmp/sockets RUN mkdir -p ./tmp/pids RUN rm -f /var/www/rails/myapp/tmp/sockets/.unicorn.sock ENV RAILS_ENV production RUN rails assets:precompile
2. docker-compose.yml
docker-compose.yml version: '3' services: app: build: . command: bundle exec unicorn_rails -c /var/www/rails/myapp/config/unicorn.conf.rb -D -E production volumes: - .:/var/www/rails/myapp - public-data:/var/www/rails/myapp/public - tmp-data:/var/www/rails/myapp/tmp - log-data:/var/www/rails/myapp/log depends_on: - web web: build: context: containers/nginx volumes: - public-data:/var/www/rails/myapp/public - tmp-data:/var/www/rails/myapp/tmp ports: - 80:80 volumes: public-data: tmp-data: log-data:
3. unicorn.conf.rb
$worker = 2 $timeout = 30 $app_dir = "/var/www/rails/myapp” $listen = File.expand_path 'tmp/sockets/.unicorn.sock', $app_dir $pid = File.expand_path 'tmp/pids/unicorn.pid', $app_dir $std_log = File.expand_path 'log/unicorn.log', $app_dir # set config worker_processes $worker working_directory $app_dir stderr_path $std_log stdout_path $std_log timeout $timeout listen $listen pid $pid # loading booster preload_app true # before starting processes before_fork do |server, worker| defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect! old_pid = "#{server.config[:pid]}.oldbin" if old_pid != server.pid begin Process.kill "QUIT", File.read(old_pid).to_i rescue Errno::ENOENT, Errno::ESRCH end end end # after finishing processes after_fork do |server, worker| defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection end
試したこと
ArgumentError: socket=/var/www/rails/myapp/tmp/sockets/.unicorn.sock specified but it is not a socket!
上記のエラーを調べたところ、該当のsockファイルを一旦削除するといいということで、削除したうえでコンテナの中からbashでunicornを起動したところ、うまくいったようでした。
しかし、コンテナのステータスがExited(1)のままでしたので、Dockerfileにsockファイルの削除の記述を追加して再びコンテナを立ち上げ直しましたが、UPにならずunicornは起動していませんでした。
Dockerの設定にすべての要因があるのではないかと思いますが、なぜこのような問題が起きているのか、分かる方がいらっしゃいましたら、教えていただければ幸いです。
コメント
必要なコードや情報がありましたら適宜追加いたします。
質問に至らない点がありましたら、申し訳ございません。
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
下記のような回答は推奨されていません。
このような回答には修正を依頼しましょう。
また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。