我已经对互联网进行了一些挖掘,但无法遇到类似的东西(至少在任何适合我的解决方案附近)。
从本质上讲,我在127.0.0.1:1337
本地运行Golang服务器,我希望它可以在全球范围内访问,因此我使用Nginx将流量从https://api.example.com/
转发到我的API以检索信息。
话虽如此,我只是简单地将我的 Golang 服务器设置为侦听并在端口 1337
上提供服务,并且我的 Nginx 配置设置为将所有 HTTP 流量(适用于所有域)重定向到 HTTPS:
server {
listen 80 default_server;
server_name _;
return 301 https://$host$request_uri;
}
然后我在此处将流量重定向到端口 1337:
server {
server_name api.example.com;
location / {
proxy_pass http://127.0.0.1:1337;
}
listen 443 ssl;
ssl_certificate_key /etc/nginx/ssl/private.key;
ssl_certificate /etc/nginx/ssl/cert.crt;
}
这样做的问题是我发现自己不断从HTTPS重定向到HTTP(根据wget),最终我得到了一个Too Many Redirects
错误。
如果有人可以提供一些指导,我将不胜感激!
server_name _;
匹配找不到匹配项的服务器名称。
我以前做过。
请参阅我的nginx配置以代理api后端:
# ssl
ssl_certificate /etc/nginx/cert/live/ybilly.com/fullchain.pem;
ssl_certificate_key /etc/nginx/cert/live/ybilly.com/privkey.pem;
# http to https
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name ybilly.com www.ybilly.com *.ybilly.com;
return 301 https://$host$request_uri;
}
# api backend
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name *.ybilly.com;
location / {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
proxy_set_header Host $host;
proxy_set_header X-Real-Ip $remote_addr;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass_header Set-Cookie;
proxy_read_timeout 900;
proxy_buffers 32 4k;
proxy_pass http://127.0.0.1:8080/;
}
}