0


Nginx服务、Vite项目如何设置ws(websocket)代理?

一、前言

最近干活中遇到请求访问地址代理的问题,http请求代理到是没啥问题,主要是WebSocket代理配置,今天折腾了一上午加下午一小时,才将其配置好,主要是部署服务器的时候nginx这一块不太清楚,作为一个初级前端,确实还有待提高。本文主要细致的讲解一下ws代理如何设置,在开发环境主要是vite代理设置方法,生产环境给Nginx设置代理。

请求地址及处理

在代码编写过程中,主要是url应该如何拼写,下面是项目中使用的请求地址:

//动态获取地址const wsUrl =`ws://${location.host}/wsUrl/test`;// 创建连接const socket =newWebSocket(wsUrl);

这里的地址需要注意

/wsUrl

,这个是拦截代理的标志(ps:这里也可以写别的路径替换

/wsUrl

,它不是必须的,但是后面配置需要注意这个标识),在前端用于标识ws请求,在设置代理的过程中主要用于请求拦截标识,实际请求会去掉它。

  • 实际访问后台的地址: ws://IP:Port/test
  • 前端访问的ws请求地址:ws://IP:Port/wsUrl/test

之所以加一层路径,主要还是为了拦截ws请求所用,具体理解可以看下面的配置方法。

Vite项目内配置ws代理设置

在vite的配置文件vite.config.ts/js文件中添加如下代理配置。

{
  base:"/",...
  server:{
    proxy:{"/wsUrl":{
        target:"ws://127.0.0.1:8080",//这里是后台ws访问地址
        changeOrigin:true,//允许跨域设置
        ws:true,//websocket代理设置rewrite:(path)=> path.replace(/~\/wsUrl/,""),//拦截路径去除},},},...}

以上就是vite项目内设置ws代理的配置方法,可以看到vite中使用路径重写(rewrite)去除了

/wsUrl

,经过代理后最终访问的是上述的实际地址,所以这个标识只是用于拦截对应的ws请求。

nginx项目中配置方法

nginx配置文件一般相对位置都在 ./nginx/conf文件夹中,打开nginx.conf文件即可修改代理配置内容。

我使用的是Linux服务,文件位置在/usr/local/nginx/connf/文件夹中,具体位置不同系统镜像文件位置可能略有差异,找到配置文件即可。

nginx设置代理稍有不同,在我配置代理过程中采坑也不少(主要还是菜了),反复测试才有了如下可行结果:

...
http:{...
  server{...
    # WebSocket代理
    location /wsUrl/ {
      rewrite ^/wsUrl/(.*)$ /$1break;#拦截标识去除
      proxy_pass http://192.168.100.20:8080;#这里是http不是ws,不用怀疑,代理的ip和port写ws访问的实际地址
      proxy_http_version 1.1;#这里必须使用http 1.1#下面两个必须设置,请求头设置为ws请求方式
      proxy_set_header Upgrade $http_upgrade;
      proxy_set_header Connection "upgrade";}...
  }...
}

rewrite这里正则写法不太清楚,但必须是上述格式,好像是匹配替换

/wsUrl

,不能去掉后面的斜杠(/),编写完成配置文件保存后,需要重启nginx服务,重启后使用上述前端访问地址发起ws请求即可成功连接到代理服务。

小结

设置代理还是需要理解其中运行的逻辑,不管是开发环境代理,还是生产环境代理,本质上都是一样的,通过正则匹配请求对应路径进行拦截,然后拦截后对请求进行处理,在本文演示示例中,主要是去除了

/wsUrl

路径再转发请求,如果请求后台的路径是

/wsUrl/test

,其实这里也不需要去除该地址,直接匹配转发请求即可。如果觉得本文对您有帮助烦请点个赞,鼓励一下作者,如果文章中有错误或不合理的地方,欢迎指正!

标签: nginx websocket 运维

本文转载自: https://blog.csdn.net/qq_42476927/article/details/128189169
版权归原作者 ZERO丶X 所有, 如有侵权,请联系我们删除。

“Nginx服务、Vite项目如何设置ws(websocket)代理?”的评论:

还没有评论