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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

9358閲覧

unicornが実行出来ない。

jesushill

総合スコア37

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

1グッド

1クリップ

投稿2016/12/14 12:08

編集2016/12/14 12:10

初心者のものです。

現在、ruby on railsで開発したプログラムをデプロイしようとしているのですが、
その際に用いていたunicorn.rbが起動しません。

実行環境:centos7 unicorn (5.2.0) rails (4.2.7) ruby(2.2.5)

##実行コマンド

実行コマンド $ bundle exec unicorn -D -c unicorn.rb

最初は

ArgumentError: rackup file (config.ru) not readable

と言われたのでぐぐってみると、working_directoryを指定しないと
rackを読み込んでしまうとの記述をみつけました。
それに従い、以下のように実行ファイルを編集しました。

##ソースコード

パス
/var/www/app/my-app/current/config/unicorn.rb

ruby

1# -*- coding: utf-8 -*- 2worker_processes 2 3 4listen '/var/www/app/my-app/current/tmp/unicorn.sock' 5pid '/var/www/app/my-app/current/tmp/unicorn.pid' 6 7log = Dir.pwd + '/log/unicorn.log' 8stderr_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT']) 9stdout_path File.expand_path('log/unicorn.log', ENV['RAILS_ROOT']) 10 11#修正箇所 12working_directory '/var/www/app/current' 13 14preload_app true 15GC.respond_to?(:copy_on_write_friendly=) and GC.copy_on_write_friendly = true 16 17before_fork do |server, worker| 18defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect! 19 20old_pid = "#{ server.config[:pid] }.oldbin" 21unless old_pid == server.pid 22 begin 23 sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU 24 Process.kill :QUIT, File.read(old_pid).to_i 25 rescue Errno::ENOENT, Errno::ESRCH 26 end 27end 28end 29 30after_fork do |server, worker| 31 defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection 32end 33~

実行したところ、

ArgumentError: config_file=./unicorn.rb would not be accessible in working_directory=/var/www/app/current

と言われ、エラーとなります。
working_directoryの記述がおかしいのでしょうか。
お手数ですがどなたご教授いただきたくお願い致します。

kinounoko1👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

working_directoryの記述がおかしいのでしょうか。

多分ですが、その通りだと思います。

編集している資材の場所とかを見ると、普通に、
/var/www/app/my-app/current
ではないですか?
で、こういう記載ミスをしない為にも、以下のような書き方にした方が
良いと思います。

ruby

1# 実行したファイルの場所からrailsのrootパスを見つける 2RAILS_ROOT = File.expand_path('../../', __FILE__) 3ENV['BUNDLE_GEMFILE'] = RAILS_ROOT + "/Gemfile" 4# ここは、RIALS_ROOTが記載されていれば、明示的にかかなくても大丈夫です。 5# 自分が使っている環境でも、下の記載なしにちゃんと動いてますね。 6working_directory RAILS_ROOT

参考URLを貼っておきますので、詳しくは、こちらを読んでみてください。
Unicorn設定のまとめ

投稿2016/12/16 03:01

IPU

総合スコア283

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

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

jesushill

2016/12/16 16:20 編集

コメントいただきましてありがとうございます。 RAILS_ROOT = File.expand_path('../../', __FILE__) working_directory RAILS_ROOT 編集しなおして実行したところ、 ArgumentError: config_file=unicorn.rb would not be accessible in working_directory=/var/www/app/my-app/releases/20161210073023 というエラーが出てきました。releases/ をなぜ参照しているのかわかりません。。
IPU

2016/12/19 07:41

いくつか確認させてください。 1.以下は、記載しました?  ENV['BUNDLE_GEMFILE'] = RAILS_ROOT + "/Gemfile" 2.試しに以下の形で起動コマンドを実行してみてほしいです。  jesushillさんの環境だと、 cd /var/www/app/my-app bundle exec unicorn_rails -c config/unicorn.rb -D -E production 多分、上のコマンドなら起動しそうな気がしてます。
jesushill

2016/12/21 07:46

連絡いただきましてありがとうございます。 1を記載して、 2をcurrentフォルダで実行したところ、unicornが起動しました! 今はnginxを起動して、環境変数などに悪戦苦闘中です。 もしよろしければ、一つ質問させて下さい。一般のHTTPからアクセスするならどのように行えば良いのでしょうか http://{IPアドレス} といった形でしょうか? ほんっとうにありがとうございます!!
IPU

2016/12/21 08:04

あっ、ちゃんと動きました? 良かったです。 >一般のHTTPからアクセスするならどのように行えば良いのでしょうか http://{IPアドレス} といった形でしょうか? んー、一般と言われるとすごい広い意味なので、答えづらいですけど、 普通に身内で使うだけなら、nginxも使わないで、 http://{IPアドレス}:{ポート} で良いと思います。 外から使う人などに公開するなら、nginxを使って、 https://{FQDN} とかにして、セキュリティを高くするのが良いかと思いますよ。
jesushill

2016/12/21 08:26

ありがとうございます。 参考になりました。 nginxの設定がいまいちなのか見ても動かず・・・ 色々と調べてみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問