nginx: [emerg] unknown “connection_upgrade“ variable 解决与思考

 问题,如下图:

一天更新完主分支后启动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://segmentfault.com/a/1190000018712908

NGINX as a WebSocket Proxy

https://www.cnblogs.com/chyingp/p/websocket-deep-in.html

回答: 当出现"nginx: \[emerg\] unknown "clientrealip" variable"错误时,这意味着在nginx配置文件中使用了未知的"clientrealip"变量。要解决这个问题,你需要检查你的nginx配置文件并确保正确定义了这个变量。你可以在http标签下添加以下几行代码来定义这个变量: ``` map $http_x_real_ip $clientrealip { default $http_x_real_ip; '' $remote_addr; } ``` 这个代码块将根据请求头中的"X-Real-IP"字段来设置"clientrealip"变量的值。如果请求头中没有这个字段,它将使用客户端的真实IP地址作为默认值。请确保将这个代码块放在nginx配置文件的http块中。默认的nginx配置文件路径是/etc/nginx/nginx.conf。\[2\] #### 引用[.reference_title] - *1* [亲测:nginx: [emerg] unknownconnection_upgradevariable](https://blog.csdn.net/q906270629/article/details/130091625)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [nginx: [emerg] unknownconnection_upgradevariable](https://blog.csdn.net/ichen820/article/details/128119737)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值