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

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


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管理的项目。


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) 第三步、下载完成之后,进行解压可以看到如下 文件结构

image.png

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

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. 页面正常请求到。如下图:

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被启动,如下图:

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即可查看页面:

image.png

参考:
Nuxt服务端部署

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335