欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue項目部署的實現(xiàn)(阿里云+Nginx代理+PM2)

 更新時間:2019年03月26日 14:51:39   作者:Clearlove  
這篇文章主要介紹了Vue項目部署的實現(xiàn)(阿里云+Nginx代理+PM2),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

最近部署一個Vue項目到阿里云ECS上,因為項目涉及一些跨域請求,所以采用了Nginx代理請求本地的node服務(wù)(利用pm2做進(jìn)程管理)。node服務(wù)借助axios設(shè)置headersreferer、host轉(zhuǎn)發(fā)請求,解決跨域請求問題。

先交代下在阿里云ECS里安裝的部署環(huán)境:phpstudy(php調(diào)試運行大禮包,里面包含nginx、mysql等,還能監(jiān)控端口占用情況)、pm2(node服務(wù)進(jìn)程管理工具)、node、git等等。

部署過程

  1. 拉去GitHub項目代碼至root目錄下(找到安裝phpstudy的WWW目錄),構(gòu)建項目
  2. 修改nginx-conf的代理配置、root項配置(指向項目項目的dist目錄下)
  3. 啟動pm2(項目中,事先已寫好服務(wù)端邏輯prod.server.js)
  4. 啟動phpstudy
  5. 訪問項目

構(gòu)建項目

構(gòu)建項目前,要修改項目confing目錄下的index.js,主要是build部分的端口、目錄,具體如下:

build: {
  port: 9001, // 因為我是用PHPStudy做web服務(wù)器的,此時php.cgi會占9000端口,所以改用9001
  // Template for index.html
  index: path.resolve(__dirname, '../dist/index.html'),

  // Paths
  assetsRoot: path.resolve(__dirname, '../dist'),
  assetsSubDirectory: 'static',
  assetsPublicPath: '',
  .......
}

主要有兩部分

修改端口,跟代理端口一致

port: 9001

修改assetsPublicPath

assetsPublicPath: ''

nginx-conf配置

利用phpstudy,可以很方便的進(jìn)行nginx相關(guān)設(shè)置、host修改、端口監(jiān)控等等。先來說說nginx-conf的配置。

先找到nginx-conf配置入口

修改ngin-conf

upstream my_project {
 server 127.0.0.1:9001;
 keepalive 64;
}

server {
 listen    80;
 server_name my_project;

 #charset koi8-r;

 #access_log logs/host.access.log main;
 root  "C:/phpStudy/PHPTutorial/WWW/project/dist";

 location / {
  index index.php index.html index.htm; 
  
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header Host $http_host;
  proxy_set_header X-NginX-Proxy true;
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection "upgrade";
  proxy_max_temp_file_size 0;
  proxy_pass http://my_project/;
  proxy_redirect off;
  proxy_read_timeout 240s; 
   
 }
}

注意事項

root配置,指向構(gòu)建后目錄

root "C:/phpStudy/PHPTutorial/WWW/project/dist";

設(shè)置代理端口時,避免端口占用??!

upstream my_project {
 server 127.0.0.1:9001;
 keepalive 64;
}

開始部署時,使用的是9000端口,一直運行不起來,后面發(fā)現(xiàn)phpstudy啟動是php-cgi.exe默認(rèn)就使用了9000端口。關(guān)于端口使用情況,phpstudy也提供了工具。

啟動pm2

關(guān)于pm2的介紹、常規(guī)使用自行了解。在項目目錄下事先已經(jīng)寫好了轉(zhuǎn)發(fā)請求的邏輯。

pro.server.js

var axios = require('axios')
const bodyParser = require('body-parser')
var config = require('./config/index')
var express = require('express')

var app = express()
var apiRoutes = express.Router()

apiRoutes.get('/api/getdata', function(req, res) {
 var url = 'https://a.com'
 axios.get(url, {
  headers: {
   referer: 'https://b.com',
   host: 'b.com'
  },
  params: req.query
 }).then((response) => {
  ....
 }).catch((e) => {
  console.log(e)
 })
})


app.use('/', apiRoutes)

app.use(express.static('./dist'))

var port = process.env.PORT || config.build.port

module.exports = app.listen(port, function (err) {
 if (err) {
  console.log(err)
  return
 }
 console.log('Listening at http://localhost:' + port + '\n')
})

這里只是簡單的借助axios可以設(shè)置refererhost,實現(xiàn)代理轉(zhuǎn)發(fā)的功能。

運行prod.server.js

prod.server.js是在根目錄下,所以運行命令如下:

pm2 start prod.server.js

進(jìn)程列表:

pm2 start list

查看進(jìn)程詳情

pm2 show 0

總結(jié)

整個部署過程涉及比較多的知識點,nginx代理node開發(fā)部署,端口管理等等。在端口占用這個點上卡了一段時間。不過目前只是實現(xiàn)構(gòu)建部署、訪問。但維護(hù)成本還是比較高,先得從GitHub拉取代碼,本地構(gòu)建。項目完成以后,研究下持續(xù)性集成流程。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3響應(yīng)式高階用法之shallowRef()的使用

    Vue3響應(yīng)式高階用法之shallowRef()的使用

    在Vue3框架中,shallowRef()為開發(fā)者提供了細(xì)粒度的響應(yīng)式控制能力,特別適用于處理深層嵌套對象或需要部分響應(yīng)式的場景,本文就來詳細(xì)的介紹一下,感興趣的可以了解一下
    2024-09-09
  • vue實現(xiàn)城市列表選擇功能

    vue實現(xiàn)城市列表選擇功能

    這篇文章主要介紹了vue實現(xiàn)城市列表選擇功能,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • Vue使得大屏自適應(yīng)的多種方法

    Vue使得大屏自適應(yīng)的多種方法

    這篇文章主要介紹了Vue使得大屏自適應(yīng)的多種方法,自適屏幕,始終保持16:9的比例,還一種是使用CSS scale屬性對大屏幕做自適應(yīng)處理,需要的朋友可以參考下
    2023-10-10
  • 基于vue+echarts 數(shù)據(jù)可視化大屏展示的方法示例

    基于vue+echarts 數(shù)據(jù)可視化大屏展示的方法示例

    這篇文章主要介紹了基于vue+echarts 數(shù)據(jù)可視化大屏展示的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2020-03-03
  • Vue配置文件vue.config.js配置前端代理方式

    Vue配置文件vue.config.js配置前端代理方式

    這篇文章主要介紹了Vue配置文件vue.config.js配置前端代理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue過濾器filters的用法及時間戳轉(zhuǎn)換問題

    Vue過濾器filters的用法及時間戳轉(zhuǎn)換問題

    Vue的filters過濾器是比較常見的一個知識點,下面我將結(jié)合時間戳轉(zhuǎn)換的例子帶你快速了解filters的用法,感興趣的朋友一起看看吧
    2021-09-09
  • Element-UI結(jié)合遞歸組件實現(xiàn)后臺管理系統(tǒng)左側(cè)菜單

    Element-UI結(jié)合遞歸組件實現(xiàn)后臺管理系統(tǒng)左側(cè)菜單

    在Vue.js中使用遞歸組件可以方便地構(gòu)建多層級的菜單結(jié)構(gòu),遞歸組件適用于處理具有嵌套關(guān)系的數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-09-09
  • vue3+ts項目搭建的實現(xiàn)示例

    vue3+ts項目搭建的實現(xiàn)示例

    這篇文章主要介紹了vue3+ts項目搭建的實現(xiàn)示例,本文目的在于記錄自己項目框架搭建的過程,通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • elementUI?el-table二次封裝的詳細(xì)實例

    elementUI?el-table二次封裝的詳細(xì)實例

    在項目中會多次使用表格展示數(shù)據(jù),不對這個table進(jìn)行二次封裝成我們自己想要的,重復(fù)的代碼量的工作會比較大,下面這篇文章主要給大家介紹了關(guān)于elementUI?el-table二次封裝的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • 詳解Vue3如何加載動態(tài)菜單

    詳解Vue3如何加載動態(tài)菜單

    這篇文章主要為大家詳細(xì)介紹了Vue3是如何實現(xiàn)加載動態(tài)菜單功能的,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Vue有一定幫助,需要的可以參考一下
    2022-07-07

最新評論