国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue-CLI 3.X 部署項目至生產服務器的方法

來源:懂視網 責編:小采 時間:2020-11-27 21:59:50
文檔

Vue-CLI 3.X 部署項目至生產服務器的方法

Vue-CLI 3.X 部署項目至生產服務器的方法:本教程主要講解的是 Vue-CLI 3.x 腳手架搭建的vue項目, 先構建生成dist文件(純靜態應用), 然后自動化部署到靜態文件服務器 Nginx。 一、Nginx服務器文件的配置 server { listen 80; server_name www.xxxxxx.com;#生產環境 loca
推薦度:
導讀Vue-CLI 3.X 部署項目至生產服務器的方法:本教程主要講解的是 Vue-CLI 3.x 腳手架搭建的vue項目, 先構建生成dist文件(純靜態應用), 然后自動化部署到靜態文件服務器 Nginx。 一、Nginx服務器文件的配置 server { listen 80; server_name www.xxxxxx.com;#生產環境 loca

本教程主要講解的是 Vue-CLI 3.x 腳手架搭建的vue項目, 先構建生成dist文件(純靜態應用), 然后自動化部署到靜態文件服務器 Nginx。

一、Nginx服務器文件的配置

server {
 listen 80;
 server_name www.xxxxxx.com;#生產環境
 location / {
 root /usr/local/www/xxx_program/;
 index index.html;
 try_files $uri $uri/ /index.html;
 }
 }
 server {
 listen 80;
 server_name test.xxxxxx.com; #測試環境
 location / {
 root /usr/local/www/xxx_program_test/;
 index index.html;
 try_files $uri $uri/ /index.html;
 }
 }

二、配置生產/測試環境 服務器SSH遠程登陸賬號

在項目根目錄下, 創建 .env 文件 (當前環境變量)

VUE_APP_SERVER_ID變量指代 當前需部署的服務器ID為0

VUE_APP_SERVER_ID=0

在項目根目錄下, 創建 deploy/products.js 文件

該文件功能如下:

(1) 讀取env環境變量

const fs = require('fs')
const path = require('path')
// env環境變量的路徑
const envPath = path.resolve(__dirname, '../.env')
// env對象
const envObj = parse(fs.readFileSync(envPath, 'utf8'))
const SERVER_ID = parseInt(envObj['VUE_APP_SERVER_ID'])

function parse (src) {
 // 解析KEY=VAL的文件
 const res = {}
 src.split('\n').forEach(line => {
 // matching "KEY' and 'VAL' in 'KEY=VAL'
 const keyValueArr = line.match(/^\s*([\w\.\-]+)\s*=\s*(.*)?\s*$/)
 // matched?
 if (keyValueArr != null) {
 const key = keyValueArr[1]
 let value = keyValueArr[2] || ''

 // expand newlines in quoted values
 const len = value ? value.length : 0
 if (len > 0 && value.charAt(0) === '"' && value.charAt(len - 1) === '"') {
 value = value.replace(/\\n/gm, '\n')
 }

 // remove any surrounding quotes and extra spaces
 value = value.replace(/(^['"]|['"]$)/g, '').trim()

 res[key] = value
 }
 })
 return res
}

(2) 定義多個服務器賬號 及 根據 SERVER_ID 導出當前環境服務器賬號

const SERVER_LIST = [
 {
 id: 0,
 name: 'A-生產環境',
 domain: 'www.xxx.com',
 host: 'XX.XX.XX.XX',
 port: 22,
 username: 'root',
 password: 'xxxxxxx',
 path: '/usr/local/www/xxx_program/'
 },
 {
 id: 1,
 name: 'B-測試環境',
 domain: 'test.xxx.com',
 host: 'XX.XX.XX.XX',
 port: 22,
 username: 'root',
 password: 'xxxxxxx',
 path: '/usr/local/www/xxx_program_test/'
 }, 
]

module.exports = SERVER_LIST[SERVER_ID]

三、創建自動化部署腳本 (使用scp2庫)

在項目根目錄下, 創建 deploy/index.js 文件

const scpClient = require('scp2')
const ora = require('ora')
const chalk = require('chalk')
const server = require('./products')
const spinner = ora('正在發布到生產服務器...')
spinner.start()
scpClient.scp('dist/', {
 host: server.host,
 port: server.port,
 username: server.username,
 password: server.password,
 path: server.path
}, function(err) {
 spinner.stop()
 if (err) {
 console.log(chalk.red(' 發布失敗.\n'))
 throw err
 } else {
 console.log(chalk.green(' Success! 成功發布到生產服務器! \n'))
 }
})

四、添加 package.json 中的 scripts 命令, 自定義名稱為 “deploy”

"scripts": {
 "serve": "vue-cli-service serve",
 "build": "vue-cli-service build",
 "lint": "vue-cli-service lint",
 "deploy": "npm run build && node ./deploy"
 }

五、執行部署任務

在項目根目錄下 執行 npm run deploy 命令, 或 使用 vue ui控制面板執行deploy任務, 即可自動打包并部署至線上服務器

備注: 要切換部署的服務器, 只需修改 .env文件中的服務器ID, 然后再執行deploy任務即可.

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue-CLI 3.X 部署項目至生產服務器的方法

Vue-CLI 3.X 部署項目至生產服務器的方法:本教程主要講解的是 Vue-CLI 3.x 腳手架搭建的vue項目, 先構建生成dist文件(純靜態應用), 然后自動化部署到靜態文件服務器 Nginx。 一、Nginx服務器文件的配置 server { listen 80; server_name www.xxxxxx.com;#生產環境 loca
推薦度:
標簽: 生產 服務器 項目
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美日本道免费二区三区 | 精品123区 | 亚洲国产精品嫩草影院久久 | 日本一区二区三区不卡在线视频 | 亚洲国产成人久久一区二区三区 | 亚洲第一区视频 | 国产在线观看第一页 | 欧美三级不卡 | 日韩精品 欧美 | 国产黄色视屏 | 欧美另类第一页 | 欧美1区2区3区 | 久色视频在线 | 91精品国产91久久久久久最新 | 一区二区三区在线视频播放 | 一级久久 | 国产精品久久一区二区三区 | 中文字字幕码一二三区 | 久久精品国产一区二区三区 | 国产成人精品三区 | 国产一区二区精品久久 | 国产片一区二区三区 | 麻豆国产成人精品午夜视频 | 国产视频播放 | 国产一区二区三区视频 | 亚洲激情在线观看 | 久久精品2 | 国产成人影院 | 激情一区二区三区成人 | 久久久国产99久久国产久 | 麻豆一区二区 | 一区二区三区网站 | 成人无码一区二区片 | 高清不卡一区 | 欧美黄站 | 亚洲精品高清国产一久久 | 精品欧美一区二区三区在线 | 亚洲五月婷婷 | 欧美曰韩| 九九久久久2 | 国产全黄a一级毛片视频 |