我在我的nginx上运行一个Debian 8.5 64bit用作节点应用程序的反向代理。每个请求都会先经过我的反向代理,然后再路由到特殊应用。因此,我正在使用此配置:

upstream socket_nodes {
  server 127.0.0.1:3000;
  server myUrl.com:3000;
  server MY.ROOTSERVER.IP.ADDRESS:3000;
}
server {
  listen 80 default_server;
  listen [::]:80 default_server;
  server_name myUrl.com;
  return 301 https://$server_name$request_uri;
}

server {
  # SSL configuration
  #
  listen 443 ssl default_server;
  listen [::]:443 ssl default_server;
  include snippets/ssl-my-website.com.conf;
  include snippets/ssl-params.conf;

  # Self signed certs generated by the ssl-cert package
  # Don't use them in a production server!
  #
  # include snippets/snakeoil.conf;

  # Add index.php to the list if you are using PHP
  index index.html index.htm index.nginx-debian.html;

  server_name www.myWebsite.com;
  root /root/webserver/app/;
    location ~ /.well-known {
            allow all;
    }
  location / {
     proxy_pass http://localhost:8080;
         proxy_http_version 1.1;
         proxy_set_header Upgrade $http_upgrade;
         proxy_set_header Connection 'upgrade';
         proxy_set_header Host $host;
         proxy_cache_bypass $http_upgrade;
  }
    location /alexa-api/ {
     proxy_pass http://localhost:3000;
  }
  location /at_backend/ {
    proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_http_version 1.1;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $host;
        proxy_pass http://socket_nodes;
  }


  # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  #
  #location ~ \.php$ {
  # include snippets/fastcgi-php.conf;
  #
  # # With php5-cgi alone:
  # fastcgi_pass 127.0.0.1:9000;
  # # With php5-fpm:
  # fastcgi_pass unix:/var/run/php5-fpm.sock;
  #}

  # deny access to .htaccess files, if Apache's document root
  # concurs with nginx's one
  #
  #location ~ /\.ht {
  # deny all;
  #}
}


不幸的是,这不起作用。我可以通过https(https://www.myWebsite.com)访问我的网站,并且可以正常工作。

因此,我将Amazon Developer Console中的alexa技能的端点更改为:https://www.myWebsite.com/alexa-api(带有和不带有/的结尾),但是它不起作用。当我在本地使用技能服务器并通过ngrok使其可用时,技能服务器本身即可工作。我在这里做错了什么?

编辑:

在同一应用程序中还运行着一个socket.io服务器,可以从Internet上访问它(服务器loggs为“新客户端已连接”)-但我无法在它们之间发出任何事件。 socket.io连接的HTTP Status Code(正确)是101 Switching Protocols

问候

最佳答案

当您拥有HTTPS时,还应该通过https方案

proxy_pass https://socket_nodes;

10-08 01:13