Vue项目在NodeJs服务端的部署
2020-03-19 本文已影响0人
西瓜鱼仔
项目打包
在Vue项目中执行npm run build
后会有一个dist目录,这个文件夹就是我们要部署上线的项目。
写一个NodeJs小脚本
如果你会点nodejs,脚本就很好理解了,下面是app.js启动脚本的内容:
const fs = require('fs');
const path = require('path');
const express = require('express');
const app = express();
// 模拟数据,api服务
var appData = require('./data.json');
var seller = appData.seller;
var goods = appData.goods;
var ratings = appData.ratings;
// api接口
var apiRoutes = express.Router();
apiRoutes.get('/seller', function(req, res) {
res.json({
erron: 0,
data: seller
})
});
apiRoutes.get('/goods', function(req, res) {
res.json({
erron: 0,
data: goods
})
});
apiRoutes.get('/ratings', function(req, res) {
res.json({
erron: 0,
data: ratings
})
});
app.use('/api', apiRoutes);
app.use(express.static(path.resolve(__dirname, './dist')))
app.get('*', function(req, res) {
const html = fs.readFileSync(path.resolve(__dirname, './dist/index.html'), 'utf-8')
res.send(html)
})
app.listen(8082);
简单解释一下上面的代码:由于项目需要些数据,我的模拟数据都在data.json这个文件里,所以简单写了三个路由,对应获取到模拟数据。
然后把dist目录静态出来,读取dist目录下的index.html(因为是单页应用,只有这一个html文件),监听8082端口。
我们先在本地把要上传的文件都准备好:
我们的这个脚本使用了express框架,所以我们创建了一个package.json,把依赖项添加进去:
{
"name": "vue-elm-dist",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"express": "^4.15.3"
}
}
完成以上操作,我们要上传的文件项目大概长这样:
![](https://img.haomeiwen.com/i19669663/549423276a129c7c.png)
新建一个文件夹如elm,把整个项目通过ftp上传到根目录www文件夹下
启动服务
登陆到你的服务端,cd到elm文件夹,执行npm install 安装依赖,然后pm2 start app.js
就成功启动服务了
![](https://img.haomeiwen.com/i19669663/65dcf4e114f436be.png)
现在通过ip加端口形式能正常访问,但是如果想通过域名访问就需要配置nginx映射。
关于pm2
PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单。
常用命令:
pm2 list
:查看所有运行的node服务进程状态
pm2 stop app_name | app_id
:停止某进程服务
pm2 start app.js --name my-project
:命名进程