nginx反向代理webSocket配置

发布时间 - 2019-05-13 00:00:00    点击率:

最近在做项目的时候用到了websocket协议,而且是在微信小程序中用到了websocket,微信小程序中使用wss协议的时候不能设置端口,只能使用默认的443端口。我的https已经监听了443端口,websocket再去监听443,肯定不行啊。要想办法解决。于是想到了两种办法解决。一种解决办法是把websocket部署到另一台服务器上,这样成本也太高了。另一种办法,就是使用nginx反向代理。

因为webSocket协议是基于http协议升级的(见下图),所以可以使用nginx反向代理webSocket.

从这张图片上可以看出,webSocket连接的建立是在http协议的基础上。

GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw==
Sec-WebSocket-Protocol: chat, superchat
Sec-WebSocket-Version: 13
Origin: http://example.com

熟悉HTTP的童鞋可能发现了,这段类似HTTP协议的握手请求中,只是多了几个东西。

Upgrade: websocket
Connection: Upgrade

这个就是Websocket的核心了,告诉Apache、Nginx等服务器:我发起的是Websocket协议。

Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw==
Sec-WebSocket-Protocol: chat, superchat
Sec-WebSocket-Version: 13

首先,Sec-WebSocket-Key 是一个Base64 encode的值,这个是浏览器随机生成的,告诉服务器:泥煤,不要忽悠窝,我要验证尼是不是真的是Websocket助理。

最后,Sec-WebSocket-Version 是告诉服务器所使用的Websocket Draft(协议版本),在最初的时候,Websocket协议还在 Draft 阶段,各种奇奇怪怪的协议都有,而且还有很多期奇奇怪怪不同的东西,什么Firefox和Chrome用的不是一个版本之类的,当初Websocket协议太多可是一个大难题。。不过现在还好,已经定下来啦大家都使用的一个东西

然后服务器会返回下列东西,表示已经接受到请求, 成功建立Websocket啦!

HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: HSmrc0sMlYUkAGmm5OPpG2HaGWk=
Sec-WebSocket-Protocol: chat

这里开始就是HTTP最后负责的区域了,告诉客户,我已经成功切换协议啦~

Upgrade: websocket
Connection: Upgrade

依然是固定的,告诉客户端即将升级的是Websocket协议。至此,HTTP已经完成它所有工作了,接下来就是完全按照Websocket协议进行了。

明白协议的原理了就可以下一步了

首先nginx先配置好https的证书

服务器的证书是老大配置好的,我就直接用了。需要的自己查一下吧0.0

在nginx配置文件的service节点中添加如下配置

location /wss
        {
                 proxy_pass http://127.0.0.1:8888;
                 proxy_http_version 1.1;
                 proxy_set_header Upgrade $http_upgrade;
                 proxy_set_header Connection "Upgrade";
                proxy_set_header X-Real-IP $remote_addr;
         }

解释一下参数

/wss这个是随便起的,告诉Nginx要代理的url,现在我的设置为wss,当我访问的我的服务器https://abc.com/wss时,Nginx会把我的请求映射到本机的8888端口。

proxy_pass 要代理到的url,我的代理到本机的8888端口。

proxy_http_version 代理时使用的 http版本。

重点来了:

代理webSocket的关键参数

proxy_set_header Upgrade 把代理时http请求头的Upgrade 设置为原来http请求的请求头,wss协议的请求头为websocket

proxy_set_header Connection 因为代理的wss协议,所以http请求头的Connection设置为Upgrade

proxy_set_header X-Real-IP 给代理设置原http请求的ip,填写$remote_addr 即可

至于websocket协议的response的参数,在反向代理的时候不用管。

到这里,Nginx反向代理webSocket的配置就完成了,重启Nginx,用websocket连接试试,在原来wss地址的地方填写wss://abc.com/wss。如果websocket成功连接,说明Nginx反向代理websocket已经成功了。

总结

现在的配置只是反向代理到本机时的配置,如果要反向代理到别的主机,在代理时可能会跨域问题,需要在Nginx的反向代理中做跨域的配置。

思考

在Nginx的配置文件中能看到这一段

location ~ .php$ {
      root html;
      fastcgi_pass 127.0.0.1:9000;
      fastcgi_index index.php;
      fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
      include fastcgi_params;
}

这是Nginx中php的配置文件,我擦,怎么这么眼熟,这个配置清单跟刚才的websocket的反向代理这么像。通过上网查资料才知道,原来Nginx在处理php类型的请求时,把请求发fastcgi管理进程处理,fascgi管理进程选择cgi子进程处理结果并返回被nginx,而php-fpm是一个PHP FastCGI管理器,nginx本身不能处理PHP,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端。所以说Nginx在处理php类型的请求时,本质上也是通过反向代理功能实现的。

我们可以把思维展开,用Nginx反向代理可以实现更多的功能,比如代理Tomcat

location /Tomcat
        {
                 proxy_pass http://127.0.0.1:8080;
                 proxy_http_version 1.1;
                proxy_set_header X-Real-IP $remote_addr;
         }

当然,也可以用Nginx反向代理实现负载均衡,这个我还没有试过,等以后用到了,再来补充。


# nginx  # websocket  # php  # tomcat  # firefox  # chrome  # CGI  # apache  # 微信小程序  # http  # https  # 负载均衡  # 的是  # 是一个  # 是在  # 配置文件  # 设置为  # 本机  # 怪怪  # 奇奇  # 客户端  # 这是 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  如何快速搭建安全的FTP站点?  打造顶配客厅影院,这份100寸电视推荐名单请查收  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Linux系统命令中tree命令详解  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  Laravel如何实现用户注册和登录?(Auth脚手架指南)  如何在宝塔面板中创建新站点?  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  如何正确下载安装西数主机建站助手?  如何快速生成专业多端适配建站电话?  如何在IIS中新建站点并配置端口与IP地址?  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  高端企业智能建站程序:SEO优化与响应式模板定制开发  Laravel如何处理文件下载请求?(Response示例)  千库网官网入口推荐 千库网设计创意平台入口  如何在IIS7上新建站点并设置安全权限?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  微信推文制作网站有哪些,怎么做微信推文,急?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何在腾讯云服务器快速搭建个人网站?  如何用搬瓦工VPS快速搭建个人网站?  Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程  如何获取上海专业网站定制建站电话?  网站制作企业,网站的banner和导航栏是指什么?  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  如何在阿里云购买域名并搭建网站?  微信小程序 input输入框控件详解及实例(多种示例)  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  如何有效防御Web建站篡改攻击?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  ,南京靠谱的征婚网站?  如何快速建站并高效导出源代码?  java获取注册ip实例  js实现点击每个li节点,都弹出其文本值及修改  googleplay官方入口在哪里_Google Play官方商店快速入口指南  如何在建站之星网店版论坛获取技术支持?  如何续费美橙建站之星域名及服务?  如何彻底卸载建站之星软件?  实例解析angularjs的filter过滤器  如何基于云服务器快速搭建个人网站?  JavaScript模板引擎Template.js使用详解  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  如何在阿里云完成域名注册与建站?  如何实现javascript表单验证_正则表达式有哪些实用技巧  中山网站制作网页,中山新生登记系统登记流程?