前端工程部署实例

最近笔者负责的一个前端项目部署上线了,现将其分享出来,供各位大佬指点。

项目背景

前端项目需要集成兄弟部门开发的一个服务UserService,此服务在改造之前只能用在client端,即在node环境下通过shell指令打开,本质上是新的进程,使用electron开发。现需要对其改造,使其能支持web和client端。

部署思路

改造思路为:前端项目首先打包生成dist目录;然后使用nginx分别代理入口文件dist/index.html和静态资源路径dist/static/;最后直接将nginx代理的url作为使用iframe或者electron的入口。

在次改造过程中,提供api接口服务的后端程序会随着调用方一起启动,并且在前端项目中直接使用正确的接口地址而无需使用nginx做代理。

架构拓扑

使用mermaid标识此次部署的结构:

graph TB subgraph "Frontend Project: UserManager" A[React App] B[Webpack Bundling
dist/ ] end subgraph "Nginx Proxy" C[Nginx] D[Static Resource Proxy
dist/static] E[Page Proxy
dist/index.html] end subgraph "Service" F(Generate Access URL
http://localhost/User-Server) Z(Generate Resource API
http://localhost/User-Server/static) X[Request Service
UserService.exe] end subgraph "Invocation" G[electron Embed] --> F H[iframe Embed] --> F end subgraph "Frontend Projects: ECSNext" I[Project
Configuration] --> G I[Project
Configuration] --> H J[Project
Runtime] --> G J[Project
Runtime] --> H end A --> B B --> D B --> E D --> C E --> C C -- Generate Access URL --> F C -- Generate Resource API --> Z E --> X
相关推荐
Struggler281几秒前
SSE的使用
前端
用户5806139393007 分钟前
前端文件下载实现深度解析:Blob与ObjectURL的完美协作
前端
Lin866610 分钟前
Vue 3 + TypeScript 组件类型推断失败问题完整解决方案
前端
coding随想10 分钟前
从零开始:前端开发者的SEO优化入门与实战
前端
前端工作日常13 分钟前
我理解的JSBridge
前端
Au_ust13 分钟前
前端模块化
前端
顺丰同城前端技术团队13 分钟前
还不会用 Charles?最后一遍了啊!
前端
BUG收容所所长14 分钟前
二分查找的「左右为难」:如何优雅地找到数组中元素的首尾位置
前端·javascript·算法
彬师傅15 分钟前
geojson、csv、json 数据加载
前端
用户527096487449015 分钟前
🔥 我与 ESLint 的爱恨纠葛:从"这破玩意儿"到"真香警告"
前端