nginx 在 http 配置中,http、https只能开两个独立的端口访问。如果对外服务只能开一个端口,这时候访问以http 访问 https 服务就会报错。
在网上搜索了一下,在 stream 配置里可以识别流量是否是TLS,以此将不同的流量转发到 http、https 对应的端口上,实现共用端口。
参考配置:
# http https proxy
stream {
upstream http {
server 127.0.0.1:80;
}
upstream https {
server 127.0.0.1:443;
}
map $ssl_preread_protocol $upstream {
default http;
"TLSv1.2" https;
"TLSv1.3" https;
}
server {
# Port for accessing the service
listen 8000;
proxy_pass $upstream;
ssl_preread on;
}
}
http 规则做重定向处理,强制使用 https 访问。端口需要与stream配置中的一致。
重定向语句:
return 301 https://$host:8000$request_uri;
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。