写一个node批量打包业务代码的脚本插件

概述

由于公司内部使用微前端技术,将各个子项目拆分成独立的项目分发到不同项目组进行开发,我自己的小组涉及到每次线上升级项目的时候,需要手动打包的项目达到了10个以上,每个项目手动拉取远程代码,然后安装依赖和执行打包命令的方式实在太慢太痛苦,而且很折磨人,这里根据现在的痛点,自己写了写一个node脚本可以根据配置拉取,合并,打包git项目代码等。

仓库地址

github.com/Dreamy-deng...

支持功能

  • 动态 node 版本
  • 打包输入到本机任意目录
  • 动态根据分支或者 tag 打包
  • 支持合并分支、tag
  • 可配置并发执行或者链式执行
  • 拉取远程代码在打包后不占用本地磁盘空间,打包完成后自动清空工作空间
  • 支持串行或者并发打包

安装

js 复制代码
yarn add gnip-bundle-tool

使用

php 复制代码
//导入包
const { start } = require("gnip-bundle-tool");
const path = require("path");

// 需要打包项目的git分支,git地址,node版本映射信息
/**
 * @Description
 * @Author dengping
 * @Date 2023/12/22 13:48:36
 * @param { string }  gitUrl git项目克隆地址
 * @param { string }  branchOrTag 需要拉取的分支或者tag
 * @param { string }  nodeVersion node版本,默认14.21.3
 * @param { string }  mergeBranch 拉取后需要合并的远程分支名注意(带origin/xxx)
 * @param { string }  mergeTag 拉取后需要合并的远程tag
 **/
// 资产项目(必改)
const gitProjectMap = {
  "dsep-web-home-page": {
    gitUrl:
      "https://git.cisdigital.cn/gzjg/dsep/frontend/desp-web-plus/dsep-web-home-page.git",
    branchOrTag: "master",
    nodeVersion: "",
  },
  "fe-cisdigital-data-standard": {
    gitUrl:
      "https:git.cisdigital.cn/qt/qbee/fe/fe-qbee/fe-cisdigital-data-standard.git",
    branchOrTag: "release-3.7.0-11_30-20231218",
    nodeVersion: "",
  },
  "fe-cisdigital-assets-config-management": {
    gitUrl:
      "https:git.cisdigital.cn/qt/qbee/fe/fe-qbee/fe-cisdigital-assets-config-management.git",
    branchOrTag: "release-3.7.0-11_30-20231218",
    nodeVersion: "16.14.0",
  },
  "fe-qbee-layout": {
    gitUrl: "https:git.cisdigital.cn/qt/qbee/fe/fe-qbee/fe-qbee-layout.git",
    branchOrTag: "private/merge-test",
    nodeVersion: "",
    mergeBranch: "",
    //mergeTag: "release_3.1.8.0-2_20231218",
  },
};
// 默认node版本(必改)
const defaultNodeVersion = "14.21.3";
// 输入的项目目录,自行复制文件目录输出位置(必改)
const outputPutDir = path.resolve("C:\Users\Y00043\Desktop");
/* 
--------以下配置可根据自身项目条件更改
 */
//最后项目打包后需要归并的文件后缀(公司项目为.tar.gz的压缩包)
const suffixReg = /.tar.gz/;
// 输入的文件名称
const outputFileName = "dsep";
// 输入压缩包类型
const compressType = "zip";
// 单个脚手架项目打包后的输入的文件名
const buildName = "build";
//工作空间路径(git clone 、打包的暂存区,打包完成输出后,会清空对应文件)
const workSpacesPath = path.resolve(__dirname, "../../workspaces");
// 项目名映射
const projectList = Object.keys(gitProjectMap);
// 是否并发执行(默认串联执行),注意:并发执行效率更高,cpu占用资源更多,可能过多项目会出现主机卡死情况(node版本不同可能存在问题)
const isConcurrentExecute = false;
start({
  projectList,
  suffixReg,
  outputPutDir,
  outputFileName,
  compressType,
  buildName,
  workSpacesPath,
  gitProjectMap,
  isConcurrentExecute,
  defaultNodeVersion,
});

注意事项

  • 使用 node 切换版本的需要提前下载 nvm 工具
  • 对应项目自己的 git 账户一定要有权限拉取
  • 依赖下载报错需自己检查日志处理
  • 并发执行,自己电脑的配置要够高才行,不然直接卡死机(慎用)
相关推荐
GreenTea2 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd3 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌3 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈4 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫4 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝4 小时前
svg图片
前端·css·学习·html·css3
橘子编程4 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇4 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧5 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰5 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js