wss连接错误:Error in connection establishment: net::ERR_SSL_PROTOCOL_ERROR

今天项目上线 用到wss协议,然后连接websocket的时候报错了 如下

Error in connection establishment: net::ERR_SSL_PROTOCOL_ERROR

这是因为我们websocket 连接的域名不支持wss协议

 

项目里我用的是swoole,监听端口是9501,因为9501的端口不支持ssl,所以我们利用nginx代理来解决这个问题:

 

原理:

wss协议 相当于 https 协议,都在443端口需要ssl证书,我们在nginx配置一个域名提供给websocket专用,

然后监听该域名的80端口和443端口,做一个反向代理,指导9501端口,这样就可以实现完整的流程了。

server {
	listen       80;
	server_name  xxx;
	location / {
            proxy_pass http://127.0.0.1:9501;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "Upgrade";
    }
}
server {
    listen 443;
    server_name   xxx;
    ssl on;
    ssl_certificate xxx.pem;
    ssl_certificate_key xxx.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    location / {
        proxy_connect_timeout 60;
        proxy_send_timeout 60;
        proxy_read_timeout 60;
        proxy_buffer_size 256k;
        proxy_buffers 4 256k;
        proxy_busy_buffers_size 256k;
        proxy_temp_file_write_size 256k;
        proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_404;
        proxy_max_temp_file_size 128m;
        proxy_pass http://127.0.0.1:9501;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
    }

}

  以上都是自己的见解,有问题可以指出

posted @ 2019-10-14 15:44  KenChung  阅读(13449)  评论(2编辑  收藏  举报