97人参与 • 2024-11-20 • websocket
刚部署一个项目需要使用到webscoket实现。但通过域名指向ng做了反向代理,发现通过域名访问不了,通过查找资料后发现需要在nginx添加websocket的转发配置。
在网上找到大部分配置如下所示
location /websocket/ { proxy_pass http://myserver; proxy_http_version 1.1; proxy_read_timeout 360s; proxy_redirect off; proxy_set_header upgrade $http_upgrade; proxy_set_header connection "upgrade"; #配置连接为升级连接 proxy_set_header host $host:$server_port; proxy_set_header x-real-ip $remote_addr; proxy_set_header remote-host $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; }
使用如上连接,如果所有的连接仅仅为 "ws" 协议的请求是没有问题的
但是如果要及支持 http 请求又支持 ws 请求上述配置就不起作用了
通过nginx官方关于websocket的配置得知,可以自定义变量。
故配置如下,就可以做到既支持 ws 请求,又支持 http请求。
http { #自定义变量 $connection_upgrade map $http_upgrade $connection_upgrade { default keep-alive; #默认为keep-alive 可以支持 一般http请求 'websocket' upgrade; #如果为websocket 则为 upgrade 可升级的。 } server { ... location /chat/ { proxy_pass http://backend; proxy_http_version 1.1; proxy_set_header upgrade $http_upgrade; #此处配置 上面定义的变量 proxy_set_header connection $connection_upgrade; } } }
在这个配置中:
确保您的nginx版本是1.3或更高,以支持websocket。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论