RubyonRails应用程序在Nginx上使用Vagrant和Chef,并带有HTPS——该站点没有';t载荷

RubyonRails应用程序在Nginx上使用Vagrant和Chef,并带有HTPS——该站点没有';t载荷,nginx,vagrant,chef-infra,chef-solo,puma,Nginx,Vagrant,Chef Infra,Chef Solo,Puma,我正在开发RubyonRails应用程序。我用的是流浪汉和厨师。我正在尝试将Nginx配置为我的web服务器,以便在HTTPS上工作 我非常确定我的Nginx配置文件中缺少了一些东西。以下是我的Nginx配置文件: /etc/nginx/nginx.conf: user www-data; worker_processes 1; daemon off; error_log /var/log/nginx/error.log; pid /var/run/nginx.pid; e

我正在开发RubyonRails应用程序。我用的是流浪汉和厨师。我正在尝试将Nginx配置为我的web服务器,以便在HTTPS上工作

我非常确定我的Nginx配置文件中缺少了一些东西。以下是我的Nginx配置文件:

/etc/nginx/nginx.conf:

user www-data;
worker_processes  1;
daemon off;

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/*;
}
upstream olympus {
    server unix:///tmp/olympus.sock;
}

server {
    listen 4430 default deferred;
    listen [::]:4430;
    listen 8080;
    listen [::]:8080;

    server_name: *.olympus.dev;

    add_header   Strict-Transport-Security max-age=31104000;

    ssl                  on;
    ssl_certificate      /vagrant/.ssl/olympus.crt;
    ssl_certificate_key  /vagrant/.ssl/olympus.key;

    root /vagrant/public;

    location / {
        proxy_redirect     off;

        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

        #all requests are sent to the UNIX socket
        proxy_pass  http://olympus;
    }
}
/etc/nginx/sites enabled/olympus:

user www-data;
worker_processes  1;
daemon off;

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/*;
}
upstream olympus {
    server unix:///tmp/olympus.sock;
}

server {
    listen 4430 default deferred;
    listen [::]:4430;
    listen 8080;
    listen [::]:8080;

    server_name: *.olympus.dev;

    add_header   Strict-Transport-Security max-age=31104000;

    ssl                  on;
    ssl_certificate      /vagrant/.ssl/olympus.crt;
    ssl_certificate_key  /vagrant/.ssl/olympus.key;

    root /vagrant/public;

    location / {
        proxy_redirect     off;

        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

        #all requests are sent to the UNIX socket
        proxy_pass  http://olympus;
    }
}
来自Vagrant文件的端口转发配置:

user www-data;
worker_processes  1;
daemon off;

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/*;
}
upstream olympus {
    server unix:///tmp/olympus.sock;
}

server {
    listen 4430 default deferred;
    listen [::]:4430;
    listen 8080;
    listen [::]:8080;

    server_name: *.olympus.dev;

    add_header   Strict-Transport-Security max-age=31104000;

    ssl                  on;
    ssl_certificate      /vagrant/.ssl/olympus.crt;
    ssl_certificate_key  /vagrant/.ssl/olympus.key;

    root /vagrant/public;

    location / {
        proxy_redirect     off;

        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

        #all requests are sent to the UNIX socket
        proxy_pass  http://olympus;
    }
}
config.vm.network:forwarded_端口,来宾:8080,主机:80
config.vm.network:forwarded_端口,来宾:4430,主机:443
下面是我如何运行Puma的

bundle exec puma -b unix:///tmp/olympus.sock
Puma starting in single mode...
* Version 2.9.0 (ruby 2.1.2-p95), codename: Team High Five
* Min threads: 0, max threads: 16
* Environment: development
* Listening on unix:///tmp/olympus.sock
Use Ctrl-C to stop
这是我尝试
curl时遇到的错误https://olympus.dev/

curl: (7) Failed connect to olympus.dev:443; Connection refused

您的rails应用服务器是什么?独角兽?你犯了什么错误?Stacktrace?@sethvargo,补充了更多细节。我认为pow不够聪明,无法完成你认为的布线-我建议尽可能多地移除碎片。如果你的
curl
服务器上的URL怎么办?它有用吗?您的服务器日志中有哪些内容?@sethvargo:我没有使用
pow
,有趣的是,nginx
error
access
日志中没有任何内容