【发布时间】:2016-07-29 01:22:11
【问题描述】:
我按照tutorial 配置我的 Rails 应用程序以运行 Unicorn,并在我的 AWS ubuntu 实例上被 Nginx 反向代理。
我可以访问 nginx,“欢迎使用 nginx!”默认页面,从外部在站点上运行(安全配置正确)。但它不服务于 rails 应用程序。
我的独角兽在/home/ubuntu/appname/shared/sockets/unicorn.sock=下运行
为了以防万一,我跑了sudo service unicorn restart。
当我运行sudo service --status-all 它返回:
[ ? ] unicorn_gpei-tk
正如我提到的 nginx 肯定在运行,这里是位于 /etc/nginx/sites-available/default 的配置:
upstream app {
# Path to Unicorn SOCK file, as defined previously
server unix:/home/ubuntu/appname/shared/sockets/unicorn.sock fail_timeout=0;
}
server {
listen 80;
server_name localhost;
root /home/ubuntu/appname/public;
try_files $uri/index.html $uri @app;
location @app {
proxy_pass http://app;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
}
error_page 500 502 503 504 /500.html;
client_max_body_size 4G;
keepalive_timeout 10;
}
/etc/nginx/sites-enabled 中的符号链接是default -> /etc/nginx/sites-available/default——我想第二个问题是:启用站点是否必要?本教程没有提及/要求它,我在尝试破译这个问题的 1000 个其他资源之后遇到了这个。
其他信息:如果我以用户身份运行 Unicorn,我可以在端口 8080 上连接到它,因此 Unicorn 也可以自己运行并为网站提供服务。
我也重启了几次nginx服务,还是没有更新配置,可能是我哪里弄错了。
真的没有看到我错过了什么,有什么线索/想法吗?谢谢。
编辑:
我进入 /var/log/nginx/error.log (有一个 error.log.1,但它似乎没有更新),这显示:
2016/07/28 16:21:19 [error] 11763#11763: *2 open() "/usr/share/nginx/html/favicon.ico" failed (2: No such file or directory), client: XX.XXX.XXX.XX, server: localhost, request: "GET /favicon.ico HTTP/1.1", host: "my_public_address.com", referrer: "http://my_public_address.com/"
和 /var/log/nginx/access.log 是:
XX.XXX.XXX.XX - - [28/Jul/2016:16:24:58 +0000] "GET /favicon.ico HTTP/1.1" 404 571 "http://my_public_address.com/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36" "-"
【问题讨论】:
标签: ruby-on-rails ubuntu nginx reverse-proxy unicorn