使用nginx,pm2,node部署vue,nuxt项目

最近学习vue和nuxt,于是部署Vue和Nuxt项目到腾讯云上,因为项目涉及一些跨域请求,所以采用了Nginx代理请求本地的node服务(利用pm2做进程管理)。node服务借助axios设置headers的referer、host转发请求,解决跨域请求问题。


使用nginx,pm2,node部署vue,nuxt项目_第1张图片
timg (1).gif

nuxt架子git地址

vue架子git地址

一、部署过步骤


1.首先购买服务器,域名等。获得公共ip地址,下载远程桌面链接软件;
2.服务器新建root文件夹。拉去GitHub项目代码至root目录下,npm install安装依赖的包;
3.项目构建,无错误后,下载nginx,并修改nginx-conf的代理配置;
4.用nod给项目起一个服务,并使用pm2对node的进程进行管理和保护;
5.本地浏览器输入域名和相应的端口号,页面正常显示,部署完成。

3,4,5接下来会详细讲到

二、vue项目的部署

1.vue项目构建

(1)首先需要安装express起动服务

$ npm install express --save

(2)因为pm2是基于服务来管理的,所以我们需要一个在webpack构建好的静态文件夹上(一般是dist/)搭建一个node服务,这里我们用express来搭建node服务。在项目的跟目录创建app.js

// app.js
const fs = require('fs');
const path = require('path');
const express = require('express');
const chalk = require('chalk')
const app = express();
app.use(express.static(path.resolve(__dirname, './dist')))

app.get('/', function(req, res) {
    const html = fs.readFileSync(path.resolve(__dirname, './dist/home.html'), 'utf-8')
    res.send(html)
})

app.get('/home', function(req, res) {
    const html = fs.readFileSync(path.resolve(__dirname, './dist/home.html'), 'utf-8')
    res.send(html)
})

app.get('/about', function(req, res) {
    const html = fs.readFileSync(path.resolve(__dirname, './dist/about.html'), 'utf-8')
    res.send(html)
})
app.listen(8082, res => {
    console.log(chalk.yellow('Start Service On 8082'));
});

(3)修改vue.config.ts 的publicPath和port

修改端口,跟代理端口一致,修改publicPath为空

port: 8082
publicPath: ''

(4) 打包项目

npm run build

这样在根目录终端下运行使用pm2运行node app.js就可以搭建一个以dist为根路径的node服务了(这里要确保安装了代码中的依赖插件)。
(5)在服务器全局安装pm2

// 安装pm2
npm i pm2 -g

(6)pm2在项目根目录下运行

pm2 start node_modules/nuxt/bin/nuxt-start --name ts-vue-test

这样node服务就可以用pm2进行操作了,查看pm2管理的项目。


使用nginx,pm2,node部署vue,nuxt项目_第2张图片
image.png

可以运行pm2 list查看当前管理的项目
常用的pm2命令总结

pm2 show 0                         # 查看进程详情
pm2 list                                #查看当前的进程列表
pm2 stop all                         #停止PM2列表中所有的进程
pm2 stop 0                           #停止PM2列表中进程为0的进程
pm2 reload all                       #重载PM2列表中所有的进程
pm2 reload 0                         #重载PM2列表中进程为0的进程
pm2 delete 0                         #删除PM2列表中进程为0的进程
pm2 delete all                       #删除PM2列表中所有的进程

2、Nginx的配置

项目进行到现在,在服务器上的项目正常没有问题,但是当我们在浏览器中输入http://zhoupengfei1996.com:8082/,额,震惊,你并没有看到自己想要的结果,(;′⌒`)

这时候就改Nginx出场时候啦,当当当当~~~

(1)、Nginx安装

(1)第一步、Nginx 的安装步骤比较简单,安装在windows上推荐使用压缩包的安装方式,下载地址;

(2) 第二步、有稳定版本和最新版本及以前版本,推荐使用稳定版本开发

(3) 第三步、下载完成之后,进行解压可以看到如下 文件结构

使用nginx,pm2,node部署vue,nuxt项目_第3张图片
image.png

(4)第四步、双击nginx,exe 就启动了。在页面输入localhost。出现如下界面则表示安装成功。默认监听80端口号

使用nginx,pm2,node部署vue,nuxt项目_第4张图片
image.png

(5)第五步、nginx的配置,打开下载的nginx文件夹,选择conf/nginx.conf,修改配置如下:

#user  nginx;
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    gzip  on;
    server {
        listen       80;
        server_name  www.zhoupengfei1996.com:8082;
        location / {
            proxy_pass  http://127.0.0.1:8082/;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

(6)第六步、nginx根目录下打开命令窗口,nginx -s reload 重新载入nginx(当配置信息发生修改时),重新在浏览器中打开www.zhoupengfei1996.com. 页面正常请求到。如下图:

使用nginx,pm2,node部署vue,nuxt项目_第5张图片
image.png

nginx其他命令

start nginx             # windows下的启动命令
nginx -s quit           # 停止ngix
nginx -s reload      # 重新载入nginx(当配置信息发生修改时)
nginx -h                # 查看帮助信息

至此,vue项目部署完毕。
参考文章:
Vue项目部署(阿里云+Nginx代理+PM2)
nginx+pm2+vue+webpack发布项目


三、nuxt项目的部署

1.为什么要用Nuxt.js
原因其实不用多说,就是利用Nuxt.js的服务端渲染能力来解决Vue项目的SEO问题。

二、Nuxt.js和纯Vue项目的简单对比

  1. build后目标产物不同
    vue: dist
    nuxt: .nuxt

  2. 网页渲染流程
    vue: 客户端渲染,先下载js后,通过ajax来渲染页面;
    nuxt: 服务端渲染,可以做到服务端拼接好html后直接返回,首屏可以做到无需发起ajax请求;

  3. 部署流程
    vue: 只需部署dist目录到服务器,没有服务端,需要用nginx等做Web服务器;
    nuxt: 需要部署几乎所有文件到服务器(除node_modules,.git),自带服务端,需要pm2管理(部署时需要reload pm2),若要求用域名,则需要nginx做代理。

  4. 项目入口
    vue: /src/main.js,在main.js可以做一些全局注册的初始化工作;
    nuxt: 没有main.js入口文件,项目初始化的操作需要通过nuxt.config.js进行配置指定。

1.nuxt项目构建

1.在本地开发的项目中配置及打包

npm run build

2.打包后,将以下文件上传至服务器,接下来的操作都在服务器上进行操作

.nuxt
static
nuxt.config.js
package.json

我使用的是直接把整个项目上传到git上,服务器这边拉取代码

3.进入到项目的根目录下,依次执行

npm install
npm run dev
npm run build
npm run start

4.进入项目根目录下,pm2启动nuxt项目服务

pm2 start npm --name "my-nuxt-app" -- run start

nuxt被启动,如下图:

使用nginx,pm2,node部署vue,nuxt项目_第6张图片
image.png

5.Nginx配置代理服务
nginx可以开启多个代理,在代理vue项目的nginx配置文件中,新增一个服务,如下:

# 新建一个nuxtserver服务
upstream nuxtserver{
        server 127.0.0.1:3000;
        keepalive 64;
 }
 server {
        listen  8080;
        server_name     www.zhoupengfei1996.com;  #这里对应你服务器的域名
        location / {
                proxy_pass      http://nuxtserver;  #这里对应上面upstream中新建的服务名
                index       index.html  index.htm;
        }
               location /home {
                proxy_pass  http://nuxtserver;
                index       home.html   home.htm;
        }
 }

重新载入nginx即可

nginx -s reload      # 重新载入nginx(当配置信息发生修改时)

至此,nuxt部署完毕,本地浏览器输入www.zhoupengfei1996.com:8080即可查看页面:

使用nginx,pm2,node部署vue,nuxt项目_第7张图片
image.png

参考:
Nuxt服务端部署

你可能感兴趣的:(使用nginx,pm2,node部署vue,nuxt项目)