纯前端低代码平台demo,vue框架,nodejs,简单的pm2纯前端部署实践

文章目录

      • 目录结构说明
      • 本地运行
      • 项目启动后的页面demo
      • 前端部署
        • 打包
        • pm2
        • nginx
      • 后话

前段时间开发了一个纯前端的低代码平台demo,vue框架,nodejs,pm2纯前端部署实践。为此记录一下开发过程以及各方面遇到的问题,并作说明。

表单用了若依的开源代码https://gitee.com/y_project/RuoYi-Vue,由于这个没有表格等组件,所以在此基础上又开发了一些表格、分页等相关组件,并实现了代码导出的功能)。支持保存当前设计的配置代码,支持读取该配置重新渲染成预览表单。

目录结构说明

low_code_plantform
├─ .env
├─ babel.config.js
├─ jsconfig.json
├─ package.json
├─ README.md
├─ service   // node相关的文件夹,为了方便演示将node文件放在vue项目中了
│  ├─ ecosystem.config.js   // pm2管理文件
│  ├─ gulpfile.js
│  ├─ package.json
│  ├─ server.bundle.js
│  ├─ server.js   // node启动文件
│  └─ webpack.config.js
├─ service-files   // service-files文件夹是模拟服务器文件用来存放要保存的模板配置的文件
│  └─ templates.json
├─ src
│  ├─ api
│  │  └─ index.js
│  ├─ App.vue
│  ├─ assets
│  │  ├─ demo_edit.png
│  │  └─ demo_preview.png
│  ├─ components
│  │  ├─ build
│  │  └─ Index.vue
│  ├─ main.js
│  ├─ router
│  │  └─ index.js
│  └─ utils
└─ vue.config.js

本地运行

根目录下启动vue:

$ npm run serve

service文件下启动node:

$ node server.js

项目启动后的页面demo

在这里插入图片描述
在这里插入图片描述

前端部署

打包

根目录下vue打包,将生成的 dist 文件夹

$ npm run build

service文件下node打包,将生成的 server.bundle.js 文件

$ npm run build
pm2

pm2是用来管理服务器上的多个node进程,这里如果没有配置过需要生成一个pm2配置文件ecosystem.config.js:

$ pm2 init simple

然后根据PM2官网说明进行配置就好了。

module.exports = {apps : [{name   : "form-design",  // 设置启动项目名称port: '9001', // 启动端口instances: 'max', // 集群实例数autorestart: true, // 程序崩溃后自动重启script : "./service.js" // 这里写好服务器文件夹要启动的相对路径就行,比如这个项目就是要写当前文件相对service.js文件的路径}]
}

如果本来就存在pm2的配置文件,只需要在后面添加一个当前要启动的node配置对象就好了。

配置好后,就可以启动pm2尝试是否配置正确。常用命令有:

$ pm2 list  // 查看所有node状态

在这里插入图片描述

$ pm2 start id号   // 启动
$ pm2 stop id号   // 暂停 (服务器如果要替换新的文件,需要先stop,替换文件后,再start。否则会报无法删除/被占用等)

前端通过pm2启动:

$ pm2 serve D:\xxxx\low_code_plantform\dist 9003 --spa     // 9003是指定端口,为了之后配nginx

至此,前端在9003端口,node在9001端口

nginx

nginx配置如下:
首先nginx启动在9004端口,配置正确的话,此时打开localhost:9004会显示Welcome To Nginx!
然后先将所有的请求转发到9003端口下,即前端项目所在端口;在前端项目运行时,请求/form-design/api/的接口转发到node启动的端口9001。
此时访问localhost:9004/ 就能访问到前端页面了。至此配置完成。

#user  nobody;
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;#pid        logs/nginx.pid;events {worker_connections  1024;
}http {include mime.types;default_type application/octet-stream;server {listen 9004;       # nginx启动端口server_name localhost;location / {#root   html;#index  index.html index.htm;proxy_pass http://localhost:9003; # 前端项目端口}location /form-design/api/ {proxy_pass http://localhost:9001; # node启动端口}}
}

后话

因为在服务器部署好之后,在终端访问不到。这里有个配置的地方:
win开放可访问端口的方法
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
然后一路确定就可以了。

然后再添加出站规则,填写的内容跟入站规则一致,这样就可以从终端访问了。


github传送门

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/474935.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaweb学习day03(JS+DOM)

一、javascript入门 1 官方文档 地址: https://www.w3school.com.cn/js/index.asp离线文档: W3School 离线手册(2017.03.11 版).chm 2 基本说明 JavaScript 能改变 HTML 内容,能改变 HTML 属性,能改变 HTML 样式 (CSS),能完成 页面的数据…

Python中 ‘==‘ 与‘is‘的区别

嗨喽,大家好呀~这里是爱看美女的茜茜呐 比较判断逻辑是在代码中经常使用的,在Python中常用 ‘’ 和 is 来做比较判断。 : 双等号是用来比较变量所指向内存单元中的值是否相等,它只关心值,并不在意值的内存地址,也就是说…

剖析中青年专家英年早逝现象

剖析中青年专家英年早逝现象 近年来,一个令人痛心的现象频繁触动公众的心弦——不少处于事业巅峰期的中青年专家、教授不幸英年早逝。他们的去世不仅是个人和家庭的悲剧,也是国家和社会的巨大损失。这一现象背后的原因错综复杂,涉及工作压力、…

《辽宁春晚》开场动画惊艳亮相,蓝海创意云渲染服务再显神通

随着2024年甲辰龙年的脚步日益临近,备受瞩目的《辽宁春晚》于除夕夜为全国观众带来了一场精彩绝伦的视听盛宴。作为整场晚会的亮点之一,开场动画以其独特的创意和精美的画面效果,为观众带来了一个难忘的视觉体验。而这一精彩的呈现&#xff0…

无人机技术,无人机动力系统知识,电机、电调、桨叶技术详解

无人机动力系统中的电机、电调和桨叶技术都是非常重要的部分,以下是对这些技术的详解: 无人机电机 在无人机动力系统中,电机是将电能转化为机械能的关键部件。其主要作用是产生旋转力矩,驱动螺旋桨的旋转,从而实现无…

UnityShader——07数学知识:向量

数学知识:向量 二维(笛卡尔)坐标系 二维向量(矢量) 具有方向的线段叫做有向线段,以A为起点、B为终点的有向线段作为向量,可以记作 v B - A。区别于有向线段,在一般的数学研究中&a…

Shell脚本条件语句

1.条件测试 文件测试与整数测试 test命令 测试表达式是否成立,若成立返回0,不成立返回其他数值 格式1:test 条件表达式 格式2:[ 条件表达式 ] 测试 是否成功使用 $? 操作符: -d:测试是否为目…

【Java程序员面试专栏 Java领域】Java虚拟机 核心面试指引

关于Java 虚拟机部分的核心知识进行一网打尽,主要包括Java虚拟机的内存分区,执行流程等,通过一篇文章串联面试重点,并且帮助加强日常基础知识的理解,全局思维导图如下所示 JVM 程序执行流程 包括Java程序的完整执行流程,以及Javac编译,JIT即时编译 Java程序的完整执…

九宫格锁屏模块,九宫格设置密码

要使用九宫格设置密码,先用自定义一个九宫格样式,使用的自定义的view画出九个点,然后重写onMeasure和onDraw,这两个方法,并处理onTouchEvent,这个事件 在Android视图的绘制和布局过程中,onMeasure和onDraw这两个方法的调用顺序是固定的。以下是它们通常的调用顺序&…

成都力寰璨泓科技有限公司抖音小店购物新体验

在数字化时代,网购已成为人们生活中不可或缺的一部分。随着抖音等短视频平台的兴起,越来越多的消费者选择在抖音小店购物。成都力寰璨泓科技有限公司抖音小店,作为新兴的电商力量,凭借其可靠的品质和服务,正逐渐成为消…

去测试化真的可行吗?

当前业界对于软件测试和质量相关的讨论非常广泛,各种不同的声音此起彼伏。其中包括质疑测试人员的必要性、去测试人员化、强调测试技术化和工程化、探讨测试与质量的协同作用、讨论敏捷测试、持续测试以及全程自动化测试等等。 这些讨论表明,测试工作和…

23年秋招结束,同学们陆陆续续拿到心仪的offer!24年秋招出发!

续接上次上岸同学的分享:还在担心秋招吗?看看24届已上岸同学的经验分享! 秋招的时间过程相同,但经历却各不相同。学历、专业似乎都影响着同学们的面试经历和感受。校招的面试毫无疑问学历的加持是巨大的优势,学历好会…