nginx配置http与https共用端口
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;
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » nginx配置http与https共用端口
码云笔记 » nginx配置http与https共用端口