前端工程部署实例

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

项目背景

前端项目需要集成兄弟部门开发的一个服务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
相关推荐
Hexene...2 分钟前
【前端Vue】npm install时根据新的状态重新引入实际用到的包,不引入未使用到的
前端·vue.js·npm
2301_780669868 分钟前
Vue(入门配置、常用指令)、Ajax、Axios
前端·vue.js·ajax·javaweb
码农幻想梦9 分钟前
Vue3入门到实战【尚硅谷】
前端·vue
hudou_k10 分钟前
利用WebNaket实现Web应用直接访问硬件设备
前端
吃茄子的猫10 分钟前
若依框架根据当前登录人信息,显示不同的静态公司logo
前端·vue
LZQ <=小氣鬼=>20 分钟前
React + Ant Design (antd) 国际化完整实战教程
前端·react.js·前端框架·antd·moment
星海拾遗23 分钟前
react源码从入门到入定
前端·javascript·react.js
Charlie_lll26 分钟前
学习Three.js–星环粒子(ShaderMaterial)
前端·three.js
wuhen_n30 分钟前
JavaScript事件循环(下) - requestAnimationFrame与Web Workers
开发语言·前端·javascript
我是ed.32 分钟前
Vue3 音频标注插件 wavesurfer
前端·vue.js·音视频