网站首页 > 博客文章 正文
前言
为什么要代理 WebSocket?
是这样的,因为我们有个基于 electron 的桌面应用,他在本地提供 http 和 websocket 两个服务,客户端(浏览器)可以使用这些服务来完成一些核心业务需要。
问题是,目前该应用只支持 windows 平台,虽然生产环境对环境有所要求,但部分开发却是 mac 电脑,无法安装该客户端,总不能要求开发者安装个虚拟机,或者尽快开发个 mac 版,无论硬件还是软件,搭建开发环境的成本都太高。
于是设想在一台 windows 电脑上共享桌面应用服务,在测试环境做请求代理,以便持有 mac 或者安装应用有问题的同学进行无障碍快速接入。
这篇就讲下如何配置 webpack 和 nginx 来完成这样的“小工程”。
架构设计
下图主要示意了如下几个方面:
- 桌面服务被安装在可用的 windows 机器上
- 开发环境通过配置 webpack 进行请求转发
- 对于 mac 平台及不适配的情况,统一通过 nginx 进行请求转发
跨平台 socket 代理策略
webpack-dev-server
项目基于 vue-cli,首先需要对 vue.config.js 中 webpack 的代理部分进行修改。
先设置 VUE_APP_PROXY_URL,定义目标转发环境的(IP)地址,再添加 VUE_APP_PROXY_PLATFORM 决定是否开启转发功能。
# env.local
VUE_APP_PROXY_PLATFORM = mac
VUE_APP_PROXY_URL = 192.168.1.x:81
// vue.config.js
var proxy = {
// 后端服务
['/api']: {
target: process.env.VUE_PROXY_API,
},
};
if (VUE_APP_PROXY_PLATFORM == 'mac') {
proxy = Object.assign(proxy, {
// 桌面应用 http 服务
['/app-api']: {
target: 'http://' + process.env.VUE_APP_PROXY_URL,
},
// 桌面应用 websocket 服务
['/app-ws']: {
target: 'ws://' + process.env.VUE_APP_PROXY_URL,
ws: true, //开启 websocket 支持
pathRewrite: {
'^/app-ws': '/',
},
},
});
}
module.exports = {
// ...
devServer: {
host: '0.0.0.0',
port: port,
open: true,
proxy: proxy,
},
};
接下来只要在业务代码中,添加对应 /app** 前缀来匹配代理规则即可。
nginx
nginx 端配置简单,只需要对协议进行升级即可:
server {
listen 81;
# http 代理
location /app-api/ {
proxy_pass http://192.168.1.y:18455/;
}
# websocket 代理
location / {
proxy_pass http://192.168.1.y:18455/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
}
}
最后
本文主要记录我在遇到这个问题时,实施的解决方案,但不具备通用性。不过也希望为有遇到类似场景问题的同学提供一个方向的解决思路。
猜你喜欢
- 2025-04-09 Springboot下的WebSocket开发(springboot整合websocket)
- 2025-04-09 Java实现即时通讯的优雅之选——Websocket
- 2025-04-09 Spring Boot整合WebSocket:开启实时通信之旅
- 2025-04-09 Flutter UI自动化测试技术方案选型与探索
- 2025-04-09 Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
- 2025-04-09 揭秘利用python+unittest实现Webscoket协议接口测试
- 2025-04-09 【Spring Boot】WebSocket 的 6 种集成方式
- 2025-04-09 Session与WebSocket,在线统计误导了多少人
- 2025-04-09 Spring Boot3 中 WebSocket 实现数据实时通信全解析
- 2025-04-09 fastapi调试websocket报错404的处理方案
你 发表评论:
欢迎- 372℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 369℃用AI Agent治理微服务的复杂性问题|QCon
- 360℃初次使用IntelliJ IDEA新建Maven项目
- 352℃Maven技术方案最全手册(mavena)
- 349℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 348℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 346℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 344℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)