资讯专栏INFORMATION COLUMN

nginx: [emerg] unknown "connection_upgrade&qu

gecko23 / 2421人阅读

摘要:什么是传统的通讯模式是客户端发起请求,服务端接收请求并作出响应。而协议复用了的握手通道,具体指的是,客户端通过请求与服务端协商升级协议。第二步,交换数据,客户端与服务端可以使用协议进行双向通讯。

问题


一天更新完主分支后启动nginx,结果报错:nginx: [emerg] unknown "connection_upgrade" variable

解决方法

网上查,发现是nginx配置文件出了问题,将下面map代码块补上即可。

   http {
    map $http_upgrade $connection_upgrade {
    default upgrade;
    ""      close;
   }

    server {
        location / {
                    #…
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection $connection_upgrade;
            }
        }
}
思考

虽然问题解决了,但后来我想知道为什么会出现这种情况,以及解决方法的真正原理。
在这篇博客可以知道问题出在了nginx代理websocket上。

什么是websocket

传统的http通讯模式是:客户端发起请求,服务端接收请求并作出响应。

而websocket协议复用了http的握手通道,具体指的是,客户端通过HTTP请求与WebSocket服务端协商升级协议。

第一步,建立连接,客户端使用http报文的格式发起协议升级的请求,服务端响应协议升级。

第二步,交换数据,客户端与服务端可以使用websocket协议进行双向通讯。

nginx反向代理websocket


首先,客户端发起协议升级的请求,而nginx在拦截时需要识别出这是一个协议升级(upgrade)的请求,所以必须显式设置升级(Upgrade head)和连接头(Connection head),如下:

    location /sockjs-node/ {
    proxy_pass http://127.0.0.1:4200/sockjs-node/;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection $connection_upgrade;
}

完成后,nginx将其作为WebSocket连接处理。

接着,服务器响应升级请求,由nginx做代理进行处理,这时,需要进行如下配置:

http {
    map $http_upgrade $connection_upgrade {
        default upgrade;
        "" close;
    }
    
    server {
        ...
    }
}

这时就出现了一开始我所修改的地方,结合上面那段的内容,我大概可以猜出来map 代码段该作用主要是根据客户端请求中 $http_upgrade 的值,来构造改变 $connection_upgrade 的值,即根据变量 $http_upgrade 的值创建新的变量 $connection_upgrade。
由于我没有进行map映射,它不知道connection_upgrade是什么,所以就会出现unknown "connection_upgrade" variable错误。

总结

即使是小小的一点改动,背后也会隐藏庞大的信息。如果止步于解决问题,而不是探索问题,就永远不会有进步。

本人水平有限,欢迎各位在评论区指出不足,你们的反馈就是我的进步动力!
参考文档:
https://www.nginx.com/blog/we...
https://www.cnblogs.com/chyin...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/40394.html

相关文章

  • Nginx 反向代理 websocket

    摘要:个人的理解参考资料的关于官方文档开发者的博客文档介绍的章节 最近有一个需求,就是需要使用 nginx 反向代理 websocket,经过查找一番资料,目前已经测试通过,本文只做一个记录 注: 看官方文档说 Nginx 在 1.3 以后的版本才支持 websocket 反向代理,所以要想使用支持 websocket 的功能,必须升级到 1.3 以后的版本,因此我这边是下载的 Te...

    aisuhua 评论0 收藏0
  • 不一样的nginx报错"Primary script unknown"

    摘要:昨天晚上忘记对开发环境做了什么改动,导致今天来了在进行接口调试的时候提示这个大多数情况下来说是一个很简单的问题配置里面的错误。然而我检查了我的配置,发现并没有什么问题。 昨天晚上忘记对开发环境做了什么改动,导致今天来了在进行接口调试的时候nginx提示Primary script unknown,这个大多数情况下来说是一个很简单的问题:nginx配置里面的script_filename...

    simpleapples 评论0 收藏0
  • [gist]<div id=&quot;gist6376327&quot; class=&qu

    from http://oyanglul.us 1 [x/2 for x in range(2,10,2)]

    vspiders 评论0 收藏0
  • MongoDB事务开发之写操作事务writeConcern

    一、什么是writeConcern?writeConcern 决定一个写操作落到多少个节点上才算成功。writeConcern 的取值包括:0:发起写操作,不关心是否成功;1~集群最大数据节点数:写操作需要被复制到指定节点数才算成功;majority:写操作需要被复制到大多数节点上才算成功。发起写操作的程序将阻塞到写操作到达指定的节点数为止。1.1 默认行为3 节点复制集不作任何特别设定(默认值)...

    社区管理员 评论0 收藏0
  • Nginx反向代理WebSocket响应403的解决办法

    摘要:在反向代理一个带有功能的程序源代码地址时,发现访问接口时总是出现响应,的配置参考的是官方文档相关配置唯一不同的是我们的配置了。 在Nginx反向代理一个带有WebSocket功能的Spring Web程序(源代码地址)时,发现访问WebSocket接口时总是出现403响应,Nginx的配置参考的是官方文档: http { // ssl 相关配置 ... map...

    王伟廷 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<