websocket php workerman 服务器nginx配置wss协议

avatar
作者
猴君
阅读量:1

首先 Nginx的版本要高,尽量用当前最新稳定版本。

其次 WSS协议,是在HTTPS协议的基础上,进行协议升级,进行通讯的,所以先要保证你有一个
HTTPS正常的WEB站点。

所以,通过Nginx -V 请保证 一定有 --with-http_ssl_module --with-stream --with-stream_ssl_module 这三个模块。

好了,关键点:nginx.conf 配置修改

在 http{} 节点中,增加以下配置:

map $http_upgrade $connection_upgrade { 	default upgrade; 	'' close; }  upstream websocket {     ip_hash;                 server 127.0.0.1:2000;#换成具体的服务器对应的IP与端口 } 

在这里插入图片描述

然后在具体的 监听有 443 ssl 的server{}节点中,增加以下配置 或者单独增加一个443 的Server{}节点也行

location /socket.io {    proxy_pass http://websocket;#前面的upstream websocket对应    proxy_http_version 1.1;    proxy_set_header Upgrade $http_upgrade;    proxy_set_header Connection "upgrade";    proxy_read_timeout 60s;#默认为60s     proxy_send_timeout 60s;#默认为60s    break; } 

在这里插入图片描述

假设当前域名为 https 😕/www.domain.com 则配置好后的wss地址为 wss://www.domain.com/socket.io

另外,如果是ajax请求wss,可能会有跨域问题,解决方案就是:
在配置有wss的Server{}节点中增加以下内容:

add_header ‘Access-Control-Allow-Origin’ ‘*’;
add_header ‘Access-Control-Allow-Headers’ ‘X-Requested-With’;
add_header ‘Access-Control-Allow-Methods’ ‘GET,POST’;

配置OK后,重启nginx 即可测试。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!