npm 私有包收费? 不妨试试GitLab Package Registry

最近做了一个基础功能的项目,需要在别的一系列项目中引入。

本来想着发在npm上,后来折腾了一番下来发现,不花钱的话,没法发布私有的包。

后来发现了github packages,这是个好东西。

不过我们公司的代码都放在gitlab里面,那gitlab有没有类似github packages的功能呢,当然有,这就是gitlab package registry

我们可以发布一个npm包到我们的gitlab实例上,在别的项目使用的时候,和普通的包没有区别,我们只需要npm install 包名就可以下载包,然后在正常的引入就可以了。同时,我们在npm上是搜索不到这个包的,没有权限的人也无法安装这个包。

是不是很棒!

接下来我们就一步一步实现他。

官方文档: docs.gitlab.com/ee/user/pac...

创建项目

首先我们先把我们的本地项目关联到gitlab的仓库中。

这时候我们在本地的项目中操作。

如果没有.npmrc文件,我们需要新建一个。

配置文件

我们先看package.json中的配置

js 复制代码
{
"name": "@kg/tg",
"publishConfig": {
    "@kg:registry": "http://localhost: 3000/api/v4/projects/227/packages/npm/"
  }
}

首先是我们的项目名这里,我们需要改为@kg/tg的格式:

其中,tg是我们可以自己起的包的名字,可以是任意的名字。

那么这个kg是什么?

kg是从我们gitlab项目的地址栏里取出来的,比如 https://localhost: 3000/kg/tg kg一般就代表了组group的名字。

我们还需要加一个publishConfig的配置:

其中kg和上面一样,是group的名字,后面的:registry不用变

后面需要自行替换的部分是http://localhost: 3000,这是我们gitlab的地址,我这里用的是localhost,大家自行替换。

后面的/api/v4/projects//packages/npm/是固定的。

中间的227数字是我们的project id,一般在gitlab项目的首页,项目名称下面。

以上就是package.json的配置,总结一下:

  • 项目名称需要加上@和group的名字
  • 加上publishConfig字段,里面包含gitlab地址以及project id

接下来我们还要改一下.npmrc文件的配置

js 复制代码
@kg:registry = https://localhost: 3000/api/v4/projects/227/packages/npm/

//https://localhost: 3000/api/v4/projects/227/packages/npm/:_authToken="HfQc433hioycJzerrfdeft546624w6TCw4438G8u"

这里主要加两行配置:

第一行配置和上面package.json的配置一样,主要标注了gitlab地址,group和project id

第二行的配置要注意一下,这里除了要加上gitlab地址,project id,还有一个重要的东西,就是authToken后面的部分,Access Tokens

access token需要在gitlab中生成:

access token在这个页面获取,注意的是,点了create project aeecss token按钮之后,token会显示在上面,在token name的上面,而且这只会出现这一次,再次进入这个页面的时候,就看不见token了,所以立刻马上保存下来。

到这里,配置项的工作基本就完成了。

接下来我们只需要执行npm publish就可以把我们的包发布了。

install

说完了包的发布,那么接下来就是如何在项目里面引入这个包了。

首先,要引入的项目必须和包在同一个group下,在我这里就是kg组。

然后想要成功引入包,还必须在项目里也加一下配置。

项目的.npmrc文件中:

js 复制代码
@kg:registry = https://localhost: 3000/api/v4/projects/227/packages/npm/

//https://localhost: 3000/api/v4/projects/227/packages/npm/:_authToken="HfQc433hioycJzerrfdeft546624w6TCw4438G8u"

和上面的.npmrc的配置一样。

这时候我们执行npm install @kg/tg就可以下载下来我们刚刚发布的包了。

在npm上是找不到这个包的,这个是挂载在我们gitlab实例上的包,是属于我们的私有包。

相关推荐
闲云一鹤19 小时前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化
臣妾没空2 天前
里程碑5:完成框架npm包抽象封装并发布
前端·npm
sudo_jin2 天前
前端包管理器演进史:为什么 npm 之后,Yarn 和 pnpm 成了新宠?
前端·npm
vibecoding日记4 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
codingWhat4 天前
前端组件库开发实践:从零到发布
前端·npm·vite
程序员小崔日记4 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger5 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP6 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思6 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat