💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
[TOC] ## 前言 我们常常会遇到npm请求慢,对模块介绍不清楚的情况;我们也会遇到自己想发布一个模块,但是只想自己或者部分内部人员使用;诸如此类,因此我们可能会需要一个企业仓库来实现以上的需求,它能够帮我们实现:1 将模块请求设置为内网响应,请求更快;2 在你需要的时候,将模块强制更新,也可以选择性的控制企业仓库只提供模块的对应版本;3 发布一些与业务或者公司内部的技术模块 ## 图解cnpm ![](https://box.kancloud.cn/860e0c2c543cfab3109a60f947014004_480x356.png) ## 快速入手 ### 全局安装cnpm ``` bash $ npm install -g cnpm --registry='http://192.168.0.129:7001' ``` 如果你已经安装了cnpm模块,那么重新设置请求地址即可,不需要覆盖安装(淘宝cnpm地址:https://registry.npm.taobao.org) ``` bash $ cnpm set registry 'http://192.168.0.129:7001' ``` ### 基本模块安装 cnpm的使用与npm完全相同,只是把npm改为cnpm即可,没有使用难度。 安装机制:从 http://192.168.0.129:7001 安装所有模块. 当安装的时候发现安装的模块还没有同步过来, 企业NPM会自动在后台进行同步, 并且会让你从淘宝NPM:registry.npm.taobao.org 进行安装. 下次你再安装这个模块的时候, 就会直接从企业NPM安装了. ``` bash $ cnpm install [name] ``` ### 手动同步模块 ``` bash $ cnpm sync [name] ``` ### 更新模块 ``` bash $ cnpm update [name] ``` ### 发布与删除模块 备注:需要先用户登录,用户账号以及密码可以找运维部门索要配置。 * 用户登录 ``` bash $ cnpm login ``` * 模块初始化 模块要想发布到npm仓库,必须有package.json的包说明文件,其他不做具体要求,可根据自己的需要灵活开发私属模块。建议通过cnpm init来实现模块包文件初始化。 ``` bash $ cd [name] $ cnpm init ``` * 发布模块 ``` bash $ cnpm publish [name] ``` * 删除模块 ``` bash $ cnpm unpublish [name] ``` ### 其他 * 查看已知包名模块详情 ``` bash $ cnpm info [name] ``` * 也可以通过网址:http://192.168.0.129:7002 ,搜索响应的模块,查看web版本的介绍 * 更多详情参考: [公司内网cnpm仓库](http://192.168.0.129:7002/) ## 参考文章 [在使用cnpm的公司](https://github.com/cnpm/cnpmjs.org/wiki)