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

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

新規登録して質問してみよう
ただいま回答率
85.49%
Ruby on Rails

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

Q&A

解決済

3回答

10941閲覧

unicorn のlogsがない

esakyohum

総合スコア12

Ruby on Rails

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

0グッド

0クリップ

投稿2015/08/11 12:18

raspberry pi2でunicornを入れたのですが、(bundle install で)
bundle exec unicorn -E production -c config/unicorn.rb -D でunicornを起動した際、
master failed to start, check stderr log for details
と、出てきたのですが、どこにもunicornのlogがなく、そもそもlogsディレクトリ自体がないのです。
teratailで、unicornに関する質問を見てきたのですが、
rails new で作ったファイルの logs/unicorn.log
または、config/logs/unicorn.log
らしいのですが見当たりません。
どう、対処すればいいでしょうか? それとraspberry piといってもubuntuとほとんど変わらないので、ubuntuなら分かるという方でも書いてもらえると助かります。
よろしくお願いします。

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

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

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

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

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

rifuch

2015/08/11 13:15

config/unicorn.rbの内容を見せてもらえますか?
esakyohum

2015/08/12 06:39

以下です # -*- coding: utf-8 -*- worker_processes Integer(ENV["WEB_CONCURRENCY"] || 3) timeout 15 preload_app true # 更新時ダウンタイム無し listen "/tmp/unicorn.sock" pid "/tmp/unicorn.pid" before_fork do |server, worker| Signal.trap 'TERM' do puts 'Unicorn master intercepting TERM and sending myself QUIT instead' Process.kill 'QUIT', Process.pid end defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect! end after_fork do |server, worker| Signal.trap 'TERM' do puts 'Unicorn worker intercepting TERM and doing nothing. Wait for master to send QUIT' end defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection end # ログの出力 stderr_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT']) stdout_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT'])
esakyohum

2015/08/12 14:40

unicorn.rbの中身が間違っていたようなので、調べて書き直したら出来ました。 ありがとうございました。
guest

回答3

0

見せていただいたconfig/unicorn.rbには、以下の様に記述されています

Ruby

1stderr_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT']) 2stdout_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT'])

OSに関係なく、Unicornはこの設定ファイルにあるとおりにログを書き出そうとします。
ここで言うENV['RAILS_ROOT']は、Railsプロジェクトを展開したパスのなので、
そこからの相対パスにあるはずです。

無ければディレクトリを作成し、
Unicorn実行ユーザー権限で書き込みが可能なように権限設定してみてください。

投稿2015/08/12 07:11

rifuch

総合スコア1901

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

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

0

ありがとうございました

投稿2015/08/12 14:41

esakyohum

総合スコア12

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

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

0

ベストアンサー

config/unicorn.rbには下記のように書かれているはずです。

ruby

1worker_processes 2 2 3stderr_path File.expand_path('../../log/unicorn/stderr.log', __FILE__) 4stdout_path File.expand_path('../../log/unicorn/stdout.log', __FILE__) 5 6pid File.expand_path('../../log/unicorn/unicorn.pid', __FILE__) 7 8preload_app false

このstderr_pathが標準エラーに出力された内容を保持するパスなので、ここに書かれたパスにログを出力するようにするでしょう。そのため、このパスを見て適宜フォルダがないようであれば作成してあげましょう。

投稿2015/08/11 13:31

編集2015/08/11 13:31
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問