当前位置: 首页 > 编程笔记 >

详解nginx同一端口监听多个域名和同时监听http与https

沈枫涟
2023-03-14
本文向大家介绍详解nginx同一端口监听多个域名和同时监听http与https,包括了详解nginx同一端口监听多个域名和同时监听http与https的使用技巧和注意事项,需要的朋友参考一下

详解nginx同一端口监听多个域名和同时监听http与https

1、同一端口监听多个域名

如今公网ip资源越来越珍贵,多域名监听应用非常广泛,就是用一个端口,比如80或者443,监听多个入口域名。如下:

 server {
    listen 443 ssl;
    server_name xxx.xxx.cn;
    ssl_certificate     ssl/server.pem;
    ssl_certificate_key ssl/server.key;
    ......
  }

在启用新的域名的时候,只需要另启一个server配置文件,丢在vhosts目录下即可,不会报端口被占,这个维护nginx的大部分人都知道。但是,这里有个地方要注意:不能跨nginx实例。很多同事习惯在同一虚机或者云主机下安装多个nginx实例,如果你在实例1里面用了某个端口,再在实例2里面用这个端口绑不同域名,那对不起了,报错妥妥的出来:

nginx: [emerg] bind() to 0.0.0.0:xxxx failed (98: Address already in use)
nginx: [emerg] still could not bind()

个人建议:不在同一台虚机或者云主机下安装多个nginx实例,

2、http和https同时监听

这种需求还是挺多的,有时候我们的证书需要安装在A10或者F5这类硬负载均衡上,此时,DMZ区的服务器不需要安装证书,只需要监听http端口即可。但与此同时,内网dns直接将A地址指到了服务器,此时又需要在服务器上安装证书。这种场景,就需要服务器同时对http和https端口进行监听,监听https口是为了解析内网https域名,监听http口是为了反向代理从DMZ区过来的http请求。如此,可实现内外网https域名统一。

配置如下:   

server {
    listen    8080;
    listen    443 ssl;
    server_name xxx.xxx.cn;;
    ssl_certificate   ssl/server.pem;
    ssl_certificate_key ssl/server.key;
    ......
  }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

 类似资料:
  • 例如,我可以启动两个程序侦听端口371。第二个没有任何问题地启动并接收传入连接,而第一个没有。一旦最后开始的进程终止,第一个接收它们。 假设这是Windows(XP)行为,它怎么可能是安全的行为呢?这意味着人们可以“过载”任何已经侦听的端口,而不是获得通常的“地址已经在使用”错误消息,并简单地绕过防火墙,规则只是说“允许端口371上的任何传入TCP连接”。

  • Server可以监听多个端口,每个端口都可以设置不同的协议处理方式,例如80端口处理http协议,9507端口处理TCP协议。SSL/TLS传输加密也可以只对特定的端口启用。 !> 例如主服务器是WebSocket或Http协议,新监听的TCP端口(listen的返回值,即Swoole\Server\Port,以下简称port)默认会继承主Server的协议设置。必须单独调用port对象的set方

  • 本文向大家介绍详解Apache配置多个监听端口和不同的网站目录,包括了详解Apache配置多个监听端口和不同的网站目录的使用技巧和注意事项,需要的朋友参考一下 详解Apache配置多个监听端口和不同的网站目录 一 :添加多端口 Listen 80 Listen 81 Listen 82 二:设置虚拟主机目录 phpstudy  采用的配置信息为 : 可修改为红色字体配置 三:重启Apache 即可

  • 本文向大家介绍Oracle监听口令及监听器安全详解,包括了Oracle监听口令及监听器安全详解的使用技巧和注意事项,需要的朋友参考一下 很多Oracle用户都知道,Oracle的监听器一直存在着一个安全隐患,假如对此不设置安全措施,那么能够访问的用户就可以远程关闭监听器。 相关示例如下: 命令执行成功 大家可以发现,此时缺省的监听器的日志还无法记录操作地址: 有鉴于此,为了更好的保证监听器的安全,

  • 如何配置Spring云网关服务器以同时接受HTTP和HTTPS连接? 我已将SSL配置为网关服务器上的端口443。我还想在端口80上接受HTTP请求。我知道如何使用运行Tomcat的标准Spring Boot应用程序实现这一点,但我需要知道如何配置Gateway使用的Netty服务器。

  • 本文向大家介绍Javascript添加监听与删除监听用法详解,包括了Javascript添加监听与删除监听用法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Javascript添加监听与删除监听的用法。分享给大家供大家参考。具体分析如下: js中事件监听就是利用addEventListener来绑定一个事件,这个用法在jquery中非常常用并且简单,但在原生js中比较复杂,这里整理了