[英]Nginx, Passenger, Ruby on Rails 4.1.6 Ubuntu 14 - 403 forbidden error
[英]Forbidden - Ruby 2.0.0 Rails 4.0.0 Nginx Passenger on Ubuntu 12.04
這個問題被問了太多遍了。 我花了數小時來瀏覽關於stackoverflow的所有帖子,到目前為止還算不上運氣。 嘗試訪問我的rails應用程序時始終顯示403 Forbidden。 使用一個空的新生成的應用程序進行測試。
/ var / www中的所有文件均由www-data擁有。 我在代碼的完整路徑上將權限設置為755。 當我將index.html添加到公共目錄時,它會顯示出來,但是我無法運行該應用程序。
這是啟用站點中的配置
server {
listen 80;
root /var/www/default/public;
server_name s.dev
passenger_enabled on;
rails_env development;
}
nginx.conf
user www-data;
worker_processes 2;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
access_log /var/log/nginx/access.log;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
gzip on;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_proxied any;
gzip_vary off;
gzip_types text/plain text/css application/x-javascript text/xml application/xml application/rss+xml application/atom+xml text/javascript application/javascript application/json text/mathml;
gzip_min_length 1000;
gzip_disable "MSIE [1-6]\.";
server_names_hash_bucket_size 64;
types_hash_max_size 2048;
types_hash_bucket_size 64;
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
passenger.conf
passenger_root /usr/local/rvm/gems/ruby-2.0.0-p247/gems/passenger-4.0.17;
passenger_ruby /usr/local/rvm/rubies/ruby-2.0.0-p247/bin/ruby;
passenger_max_pool_size 6;
passenger_spawn_method smart-lv2;
passenger_use_global_queue on;
passenger_buffer_response on;
passenger_min_instances 1;
passenger_max_instances_per_app 0;
passenger_pool_idle_time 300;
passenger_max_requests 0;
關於我可以嘗試的任何建議將不勝感激!
謝謝
更多信息:
passenger-config --root
/usr/local/rvm/gems/ruby-2.0.0-p247/gems/passenger-4.0.17
哪個紅寶石
/usr/local/rvm/rubies/ruby-2.0.0-p247/bin/ruby
這是錯誤
2013/09/11 16:03:00 [錯誤] 30400#0:* 3目錄索引“ / var / www / default / public /”被禁止,客戶端:145.33.44.33,服務器:s.dev,請求: “ GET / HTTP / 1.1”,主機:“ s.dev”
乘客內存統計
Version: 4.0.17
Date : 2013-09-11 16:24:16 -0400
------- Apache processes --------
### Processes: 0
### Total private dirty RSS: 0.00 MB
---------- Nginx processes ----------
PID PPID VMSize Private Name
-------------------------------------
32226 1 38.8 MB 0.2 MB nginx: master process /opt/nginx-1.5.4/sbin/nginx
32227 32226 39.2 MB 0.6 MB nginx: worker process
32228 32226 39.2 MB 0.5 MB nginx: worker process
### Processes: 3
### Total private dirty RSS: 1.25 MB
----- Passenger processes -----
PID VMSize Private Name
-------------------------------
32200 216.2 MB 0.3 MB PassengerWatchdog
32205 489.6 MB 0.3 MB PassengerHelperAgent
32220 223.6 MB 0.8 MB PassengerLoggingAgent
### Processes: 3
### Total private dirty RSS: 1.40 MB
我也可以在運行“乘客啟動”時成功運行應用
因此它開始工作。 奇怪的是,我無法真正說出是什么導致它開始工作。 在修正過程中,我犯了一些錯誤。 一種是將基本身份驗證錯誤地添加到站點配置中:
server {
listen 80;
root /var/www/default/public;
server_name s.dev;
location / {
auth_basic "Restricted";
auth_basic_user_file /var/www/default/.htpasswd;
passenger_enabled on; <------ did not remember to add this
}
passenger_enabled on;
rails_env development;
}
另一件事是將一個用戶添加到nginx.conf中,並使該用戶成為/ var / www / default的所有者-盡管我很確定這是我無法解決的事情之一
謝謝大家的幫助
也許是因為passenger_spawn_method smart-lv2
嗎? 根據http://www.modrails.com/documentation/Users%20guide%20Nginx.html#_passenger_max_instances_per_app_lt_integer_gt的說明 :
自Phusion Passenger 4.0起,保守的生成已重命名為Direct,smart-lv2重命名為smart。 舊的智能生成已被刪除,以支持新版本。
並作為:
默認值為智能。
嘗試將其刪除。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.