我在我的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;