<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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文件(純靜態(tài)應用), 然后自動化部署到靜態(tài)文件服務器 Nginx。 一、Nginx服務器文件的配置 server { listen 80; server_name www.xxxxxx.com;#生產環(huán)境 loca
        推薦度:
        導讀Vue-CLI 3.X 部署項目至生產服務器的方法:本教程主要講解的是 Vue-CLI 3.x 腳手架搭建的vue項目, 先構建生成dist文件(純靜態(tài)應用), 然后自動化部署到靜態(tài)文件服務器 Nginx。 一、Nginx服務器文件的配置 server { listen 80; server_name www.xxxxxx.com;#生產環(huán)境 loca

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

        一、Nginx服務器文件的配置

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

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

        在項目根目錄下, 創(chuàng)建 .env 文件 (當前環(huán)境變量)

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

        VUE_APP_SERVER_ID=0

        在項目根目錄下, 創(chuàng)建 deploy/products.js 文件

        該文件功能如下:

        (1) 讀取env環(huán)境變量

        const fs = require('fs')
        const path = require('path')
        // env環(huán)境變量的路徑
        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 導出當前環(huán)境服務器賬號

        const SERVER_LIST = [
         {
         id: 0,
         name: 'A-生產環(huán)境',
         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-測試環(huán)境',
         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]
        

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

        在項目根目錄下, 創(chuàng)建 deploy/index.js 文件

        const scpClient = require('scp2')
        const ora = require('ora')
        const chalk = require('chalk')
        const server = require('./products')
        const spinner = ora('正在發(fā)布到生產服務器...')
        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(' 發(fā)布失敗.\n'))
         throw err
         } else {
         console.log(chalk.green(' Success! 成功發(fā)布到生產服務器! \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"
         }
        

        五、執(zhí)行部署任務

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

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

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

        文檔

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

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久亚洲精品成人AV| 国产精品自拍亚洲| 亚洲av无码国产综合专区 | 亚洲国产一区二区三区青草影视| 亚洲fuli在线观看| 亚洲免费福利视频| 国产成人毛片亚洲精品| 亚洲中文字幕一区精品自拍| 怡红院免费的全部视频| 日本视频免费在线| 亚洲人妖女同在线播放| a级午夜毛片免费一区二区| 中文字幕在线亚洲精品| 美女被免费网站在线视频免费| AV大片在线无码永久免费| 国产亚洲3p无码一区二区| 老牛精品亚洲成av人片| 免费无码黄十八禁网站在线观看| 婷婷久久久亚洲欧洲日产国码AV| 一区二区三区免费在线视频 | 亚洲精品福利网站| 中国在线观看免费的www| 四虎影视永久免费观看网址| 亚洲色丰满少妇高潮18p| www.亚洲色图.com| 色窝窝亚洲av网| 亚洲AV永久纯肉无码精品动漫| 精品人妻系列无码人妻免费视频| 国产色爽免费视频| 亚洲av无码成人精品国产| 100000免费啪啪18免进| 亚洲youwu永久无码精品| 午夜精品在线免费观看| 亚洲女女女同性video| 成全视频免费高清 | 亚洲资源在线观看| 韩国二级毛片免费播放| 亚洲综合在线一区二区三区| 亚洲午夜精品一级在线播放放| 99re6在线精品视频免费播放| 亚洲人成在线播放网站岛国|