2017-02-27 124 views
4

我遵循ruby on rails一个应用程序单击部署。数据库做得很好,即使我检查铁轨控制台一切工作正常连接()到unix:/var/run/unicorn.sock失败(111:连接被拒绝),同时连接到上游

017/02/26 15:34:17 [error] 18564#0: *31 connect() to unix:/var/run/unicorn.sock failed (111: Connection refused) while connecting to upstream, client: 121.52.156.57, server: _, request: "GET/HTTP/1.1", upstream: "http://unix:/var/run/unicorn.sock:/", host: "188.166.157.124" 
2017/02/26 15:35:42 [error] 32360#0: *1 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 119.155.34.115, server: _, request: "GET/HTTP/1.1", upstream: "http://unix:/var/run/unicorn.sock/", host: "188.166.157.124" 
2017/02/26 15:42:38 [error] 6296#0: *1 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 119.152.140.90, server: _, request: "GET/HTTP/1.1", upstream: "http://unix:/var/run/unicorn.sock/", host: "188.166.157.124" 

uncorn.conf是

listen "unix:/var/run/unicorn.sock" 
worker_processes 4 
user "rails" 
working_directory "/home/rails/company_startup" 
pid "/var/run/unicorn.pid" 
stderr_path "/var/log/unicorn/unicorn.log" 
stdout_path "/var/log/unicorn/unicorn.log" 

nginx的是

upstream app_server { 
server unix:/var/run/unicorn.sock fail_timeout=0; 

}

server { 
listen 80; 
root /home/rails/nehbor-webserver/public; 
server_name _; 
index index.htm index.html; 
client_max_body_size 1M; 
location/{ 
     try_files $uri/index.html $uri.html $uri @app; 
} 

location ~* ^.+\.(jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|mp3|flv|mpeg|avi)$ { 
       try_files $uri @app; 
     } 

location @app { 
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
     proxy_set_header Host $http_host; 
     proxy_redirect off; 
     proxy_pass http://app_server; 
} 
} 

回答

2

按照unicorn documentation ,我认为您应该从配置中的listen方法中删除unix部分,并将其更改为listen "/var/run/unicorn.sock"

listen 3000 # listen to port 3000 on all TCP interfaces 
listen "127.0.0.1:3000" # listen to port 3000 on the loopback interface 
listen "/path/to/.unicorn.sock" # listen on the given Unix domain socket 
listen "[::1]:3000" # listen to port 3000 on the IPv6 loopback interface 
0

总之,nginx试图重新指向你的应用程序,但它不能。基本配置的东西和结构之外,我认为最常见的问题是关系到:

  • 港口
  • 插座
  • 和我(使用AWS EC2),我用的是这是通过链接域我的DNS注册表中的一个cname记录。 ip改变了哪个改变了域名服务器名称,我的记录没有更新。我只是将它从cname记录名称更改为我的新弹性域名。
相关问题