質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

1回答

1273閲覧

Dockerでunicornが起動しない

jack20xx

総合スコア45

unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2022/06/22 09:04

前提

 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の設定にすべての要因があるのではないかと思いますが、なぜこのような問題が起きているのか、分かる方がいらっしゃいましたら、教えていただければ幸いです。

コメント

必要なコードや情報がありましたら適宜追加いたします。
質問に至らない点がありましたら、申し訳ございません。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決しました。
unicornを起動する際にはsockファイルが自動的に生成されますが
何らかの問題で過去のsockファイルが残ったままになっており
新たにunicornを起動する際に妨げとなっていました。
また、pidファイルも起動に関連していることが分かったため
その両方を削除するコマンドの後にunicornを立ち上げることで、無事に成功しました。

閲覧いただきありがとうございました。

rm ./tmp/pids/unicorn.pid && rm -f ./tmp/sockets/.unicorn.sock && bundle exec unicorn_rails -c ./config/unicorn.conf.rb -D -E

投稿2022/07/14 11:30

jack20xx

総合スコア45

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問