Я пытаюсь установить Redmine на свой компьютер с Ubuntu 14.04. У меня уже есть сервер nginx 1.8.1, поэтому мне нужно его использовать. Я следил за кучей руководств о том, как это сделать, поскольку у меня нет опыта работы в среде ruby. После того, как я установил и настроил все, я получаю сообщение об ошибке в nginx, когда пытаюсь получить доступ к экземпляру redmine:
2016/03/22 21:52:54 [crit] 6640#0: *253 connect() to unix:/var/sockets/thin.2.sock failed (2: No such file or directory) while connecting to upstream, client: <EDIT>, server: <EDIT>, request: "GET / HTTP/1.1", upstream: "http://unix:/var/sockets/thin.2.sock:/", host: "<EDIT>"
2016/03/22 21:52:54 [crit] 6640#0: *253 connect() to unix:/var/sockets/thin.1.sock failed (2: No such file or directory) while connecting to upstream, client: <EDIT>, server: <EDIT>, request: "GET / HTTP/1.1", upstream: "http://unix:/var/sockets/thin.1.sock:/", host: "<EDIT>"
2016/03/22 21:52:54 [crit] 6640#0: *253 connect() to unix:/var/sockets/thin.0.sock failed (2: No such file or directory) while connecting to upstream, client: <EDIT>, server: <EDIT>, request: "GET / HTTP/1.1", upstream: "http://unix:/var/sockets/thin.0.sock:/", host: "<EDIT>"
Итак, чем я сейчас занимаюсь:
1. Начните с трех серверов, как показано на примере. на этом сайте:
$ sudo thin start -s3 --socket /var/sockets/thin.sock
Starting server on /var/sockets/thin.0.sock ...
Starting server on /var/sockets/thin.1.sock ...
Starting server on /var/sockets/thin.2.sock ...
В /var/sockets/
каталог существует, и на данный момент я дал ему права доступа chmod 777. Несмотря на то, что thin не выдает ошибок, я не вижу никаких файлов .sock (может быть, они частные?).
Кроме того, вот мой файл хоста nginx:
upstream thin_cluster {
server unix:/var/sockets/thin.0.sock;
server unix:/var/sockets/thin.1.sock;
server unix:/var/sockets/thin.2.sock;
#server unix:/tmp/thin.3.sock;
#server unix:/tmp/thin.4.sock;
}
server {
listen 80;
server_name <EDIT>;
root /usr/share/redmine/public;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
if (-f $request_filename/index.html) {
rewrite (.*) $1/index.html break;
}
if (-f $request_filename.html) {
rewrite (.*) $1.html break;
}
if (!-f $request_filename) {
proxy_pass http://thin_cluster;
break;
}
}
#error_page 500 502 503 504 /50x.html;
#location = /50x.html {
# root html;
#}
}
Он пытается подключиться к http: // unix: сокет - это наверное проблема. Посмотрите на параметры конфигурации для nginx, чтобы исправить вашу конфигурацию. Наверное это
proxy_pass http://thin_cluster;
Я думаю, что proxy_pass может отправлять только на другой HTTP-сервер, но вы пытаетесь отправить его в сокет Unix. Это работает для PHP, но не для proxy_pass. Замените это на
proxy_pass http://your-server-url
Я не могу исключить другие неправильные конфигурации. Попробуйте и сообщите, что происходит.