前端scp2自動打包部署

1. npm安裝 scp2, ora(建議此版本^5.1.0,版本過高會報錯), cross-env(已存在就不需要安裝)
2. package.json新增發(fā)布代碼命令
  "scripts": {
    "deploy": "vite build && cross-env NODE_ENV=production node ./deploy",
    // --mode test(為vue .env對用的環(huán)境)   cross-env NODE_ENV=test(打包部署時文件上傳的環(huán)境)
    "deploy:test": "vite build --mode test && cross-env NODE_ENV=test node ./deploy",
  },
3.新建根目錄新建deploy.js
const scpClient = require("scp2");
const ora = require("ora");
const chalk = require("chalk");
const spinner = ora("正在發(fā)布到服務器...");

const Client = require("ssh2").Client;
const conn = new Client();

// 默認測試環(huán)境代碼地址
let path = "";


if (process.env.NODE_ENV == "test") {
    path = "/mnt/www/ysss/ysss-merchant-admin-ui/test";
    console.log("測試環(huán)境打包完成");
}
// 上傳代碼到正式環(huán)境
if (process.env.NODE_ENV == "production") {
    path = "mnt/www/ysss/ysss-merchant-admin-ui/prod";
    console.log("正式環(huán)境打包完成");
}

const server = {
    host: "", // 服務器的IP地址
    port: "22", // 服務器端口
    username: "root", // 用戶名
    password: "", // 密碼
    path: path, // 項目部署的服務器目標位置
    command: "",
    // 若需要刪除服務器文件可使用下面代碼
    // command: 'rm -rf /mnt/www/ysss/ysss-merchant-admin-ui/test/*' // 刪除命令
};

if (path) {
    uploadFile();
}
function uploadFile() {
    conn.on("ready", () => {
        conn.exec(server.command, (err, stream) => {
            if (err) {
                throw err;
            }
            stream.on("close", () => {
                spinner.start();
                scpClient.scp(
                    "./dist/", // 本地項目打包文件的位置
                    {
                        host: server.host,
                        port: server.port,
                        username: server.username,
                        password: server.password,
                        path: server.path,
                    },
                    (err) => {
                        spinner.stop();
                        if (err) {
                            console.log(chalk.red("發(fā)布失敗!"));
                            throw err;
                        } else {
                            console.log(chalk.green("項目發(fā)布成功!"));
                        }
                    }
                );
                conn.end();
            }).on("data", (data) => {
                console.log("STDOUT: " + data);
            }).stderr.on("data", (data) => {
                console.log("STDERR: " + data);
            });
        });
    }).connect({
        host: server.host,
        port: server.port,
        username: server.username,
        password: server.password,
    });
}
4.終端執(zhí)行yarn deploy:test(或 node deploy:test)即可打包發(fā)布到服務器
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容