原文地址:https://www.cnblogs.com/yalong/p/12837461.html
前言
隨着Nodejs開發的項目越來越多,Node項目管理就成了一個需要思考的問題了。如果所有項目都開源統一用 NPM 進行管理也沒什么問題,但總有一些是我們不希望的完全開放的代碼,作為企業是核心秘密保留在公司內部,這個時候就需要在公司內網也搭建一套 NPM 依賴管理系統。
CNPM正好就提供了這個功能。
CNPM官方githuib地址, 但是官方文檔不夠全面:點我 。
大家可以下載我的這份, 我在官方項目基礎上進行了配置 點我, 具體配置下面會講。
官網上寫的是在linux環境下,其實在什么環境都可以,這里就講在mac下部署cnpm服務。
整個過程可以分為如下幾步:
1.下載cnpm項目代碼。
git clone https://github.com/YalongYan/private-cnpm
或者直接下載壓縮包。大家下載官方的git地址也可以,做相應的配置修改就可。
2.下載mysql & 導入數據表
mac下mysql的下載安裝參考 這里
這里先記下數據庫的用戶名,密碼,下面會用到。
安裝 MySql的可視化工具 MySqlWorkBench。
首次打開,MySqlWorkBench, 需要連接數據庫,如下,點擊加號, 下面的local是我之前連接好的,像這樣連接好的, 下次直接雙擊這個數據庫就可直接進入。

依次填入信息,最后Apply(這個test是數據庫名字)

然后就可以看到新增的數據庫了。

導入數據表:
記得在最上面加上一行, use test;
test是剛才的數據庫名字。然后點擊左邊起第一個⚡️
這樣就導入成功了,如下:
3.修改cnpm里面對應的配置
修改config/index.js 里面的一些參數
database: {
// 設置數據庫信息
db: 'test',
username: 'root',
password: '123456',
// the sql dialect of the database
// - currently supported: 'mysql', 'sqlite', 'postgres', 'mariadb'
dialect: 'mysql',
// custom host; default: 127.0.0.1
// host: '127.0.0.1',
host: '0.0.0.0',// 用這個 是為了 用電腦ip訪問
// custom port; default: 3306
port: 3306,
// use pooling in order to reduce db connection overload and to increase speed
// currently only for mysql and postgresql (since v1.5.0)
pool: {
maxConnections: 10,
minConnections: 0,
maxIdleTime: 30000
},
dialectOptions: {
// if your server run on full cpu load, please set trace to false
trace: true,
},
// the storage engine for 'sqlite'
// default store into ~/.cnpmjs.org/data.sqlite
storage: path.join(dataDir, 'data.sqlite'),
logging: !!process.env.SQL_DEBUG,
},
enablePrivate: true, // 只有管理員可以發布 npm 包,默認為 false,即任何人都可以發布包
scopes: ['@company'], // 私有包必須依附於 scope 下, 這個compan可以是公司名字啥的,自己定義。
// default system admins
admins: {
// name/密碼: email,
// 這里這個admin 既是用戶名, 也是密碼
admin: 'admin@cnpmjs.org',
dead_horse: 'dead_horse@qq.com',
},
4.啟動cnpm項目
npm install & npm run start
訪問 http://127.0.0.1:7002/
訪問 http://127.0.0.1:7001/
返回的是一堆json 就成功了。
這里其實可以吧127.0.0.1 換成本機ip, 這樣在局域網內的其他電腦,可以直接通過ip訪問我們的服務。
5.發布npm包
我們需要先做兩件事
1.為了方便管理npm的源, 我們安裝 nrm
$ npm install nrm -g $ nrm ls # npm ---- https://registry.npmjs.org/ # cnpm --- http://r.cnpmjs.org/ # * taobao - https://registry.npm.taobao.org/ # nj ----- https://registry.nodejitsu.com/ # rednpm - http://registry.mirror.cqupt.edu.cn/ # npmMirror https://skimdb.npmjs.com/registry/ # edunpm - http://registry.enpmjs.org/
上面可以看出可以用的npm倉庫地址,*標明當前使用的倉庫地址,使用npm use 'name'切換倉庫
2.添加本地私有倉庫
cnpm提供兩個端口:7001和7002,其中7001用於NPM的注冊服務,7002用於Web訪問
$ nrm add local http://127.0.0.1:7001/
add registry local success
$ nrm ls
# npm ---- https://registry.npmjs.org/
# cnpm --- http://r.cnpmjs.org/
# * taobao - https://registry.npm.taobao.org/
# nj ----- https://registry.nodejitsu.com/
# rednpm - http://registry.mirror.cqupt.edu.cn/
# npmMirror https://skimdb.npmjs.com/registry/
# edunpm - http://registry.enpmjs.org/
# local -- http://127.0.0.1:7001/
local就是我們剛才添加的本地私有npm倉庫,執行nrm use local
使用本地倉庫
然后就可以正常使用了
npm login // 輸入用戶名,密碼 npm publish
對於如何發布npm包,可以參考我之前寫的這篇https://www.cnblogs.com/yalong/p/10388384.html
發布成功后 ,在7002頁面可以看到 total packages 增加了。
6.下載npm包
這里下載就跟正常的下載是一樣的,npm install @company/xxx-test
因為目前我們的npm源 還是local。
以后如果想下載公網的npm, 需要切換源nrm use npm
期間遇到的問題:
出現下面這個問題, 是連不上數據庫
code: 'ER_NOT_SUPPORTED_AUTH_MODE',
errno: 1251,
sqlMessage: 'Client does not support authentication protocol requested by server; consider upgrading MySQL client',
sqlState: '08004',
fatal: true
解決辦法如下:
1.首先進入mysql命令行 mac下如何進入mysql命令行
2.然后執行如下代碼:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456'; FLUSH PRIVILEGES;
123456換成自己的數據庫密碼。 重啟node服務即可。
參考鏈接:
https://www.cnblogs.com/JimmyLuo/p/7079634.html
http://blog.fens.me/nodejs-cnpm-npm/
https://www.jianshu.com/p/4e7414f7fcc8
https://github.com/zhengyange/blog/blob/master/window-cnpmjs.md
