centos7 搭建公司私有的cnpm 包

2019-08-12  本文已影响0人  易剑圣

首先你已经安装了centos7虚拟机,下面是在centos7下完成的

安装node

下载 nodejs压缩包

 将包复制到服务器root目录下,路径:用户名@服务器ip:目录

scp node-v10.16.1-linux-x64.tar.gz root@192.168.10.110:/root/

解压

tar -xvf node-v10.16.1-linux-x64.tar.gz

3.部署bin文件

ln -s ~/node-v10.16.1-linux-x64/bin/node /usr/bin/node

ln -s ~/node-v10.16.1-linux-x64/bin/npm /usr/bin/npm

4.查看版本 node -v    npm -v

npm install --unsafe-perm  //这是解决gyp报错的方法

安装git 这个可以不安装

yum install git

mysql 安装

  wget http://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

  rpm -ivh mysql57-community-release-el7-11.noarch.rpm

  yum install mysql-community-server

当 node npm mysql  已经安装完毕,就执行下面步骤

服务器端

安装 cnpmjs.org 在root目录执行

npm i -g cnpmjs.org

vi /root/node-v10.16.1-linux-x64/lib/node_modules/cnpmjs.org/config/index.js

修改下列项

 bindingHost: '',  //监听绑定的 Host,默认127.0.0.1,外网访问注释掉此项即可

  database config //数据库相关设置

  database: {

      db: 'cnpmjs',      //数据库名称

      username: 'root',      //数据库访问账号

      password: '123456',          //数据库访问密码

      // the sql dialect of the database

      // - currently supported: 'mysql', 'sqlite', 'postgres', 'mariadb'

      dialect: 'mysql',      //使用数据库,默认sqlite,这里我们改成mysql

      // custom host; default: 127.0.0.1

      host: '127.0.0.1',      //数据库访问IP,通常127.0.0.1

      // custom port; default: 3306

      port: 3306,            //数据库访问端口,通常3306

      // registry url name //模块注册列表访问域名,默认r.cnpmjs.org,安装模块时会到这个域名下查找,这个默认设置略坑,建议没有外网域名的先清空回头再配

      registryHost: '',

      // default system admins    //默认管理员账号

      admins: {

        // name: email

        //fengmk2: 'fengmk2@gmail.com',

        admin: 'admin@cnpmjs.org',

        //dead_horse: 'dead_horse@qq.com',

      },

      // registry mode config  私有模块发布相关配置

    //是否开启私有模式,默认为 false;

    //私有模式下只有管理员能发布模块,其他账号只有同步权限

    //非私有模式,注册用户都可以发布模块

    enablePrivate: false,

    // registry scopes

    //若为非私有模式发布则此项必填,非管理员发布模块式命名必须以scopes字段开头,模块命名示例“@cnpm/packagename”

    //更多了解npm-scope请查阅https://docs.npmjs.com/misc/scope

    scopes: [ '@cnpm', '@cnpmtest', '@cnpm-test' ],

    // 私有模块非scopes白名单,各种非以scope方式发布的老模块的白名单管理,数组形式维护

    privatePackages: [],

    // sync configs 同步源仓库相关设置

  //npm官方registry地址,不会直接从这个地址同步模块,但有时会从这里获取模块信息,除非必要请勿更改

  officialNpmRegistry: 'https://registry.npmjs.com',

  officialNpmReplicate: 'https://replicate.npmjs.com',

  //同步模块上游registry地址

  sourceNpmRegistry: 'https://registry.npm.taobao.org',

  //上游registry是否是cnpm,默认true,若要使用npm官方地址作为同步上游,请设置为false

  sourceNpmRegistryIsCNpm: true,

  //若安装时模块不存在,是否向源registry进行同步,默认true

  syncByInstall: true,

  // 同步模式选项

  // none: 不进行同步,只管理用户上传的私有模块,公共模块直接从上游获取

  // exist: 只同步已经存在于数据库的模块

  // all: 定时同步所有源registry的模块

  syncModel: 'exist', // 'none', 'all', 'exist'

  // 同步时间间隔,默认10分钟

  syncInterval: '10m',

  // 是否同步模块中devDependencies,默认false

  syncDevDependencies: false,

  //用户账号系统接入,可以扩展接入公司的账号系统

  //本文暂不涉及,详见https://github.com/cnpm/cnpmjs.org/wiki/Use-Your-Own-User-Authorization

  userService: null,

按 esc

:wq 就报错退出

配置完成之后

mysql -uroot 进入数据库  或者  mysql -u root -p

创建cnpm所需的数据库

create database cnpmjs;

切换到cnpm数据库

use cnpmjs;

导入cnpm数据库配置文件 文件位于cpm安装目录docs/db.sql下

source docs/db.sql;

在 cnpm.org目录下 安装依赖

npm install

启动cnpm.org

npm run start

启动数据库

 mysql 启动 ,注意是mysqld

  启动 

 service mysqld start

  如果不成功

  mysqld --user=root --skip-grant-tables &

  如果已经启动

  ps -e |grep mysql  // 查看进程

  kill -9 id号   //结束对应进程

  mysqld --user=root --skip-grant-tables &

vim /etc/rc.local  自动启动, 这里没有实验,可以试一下

添加

service mysqld start

正常情况,就可以看到页面了

注意如果仓库页面能访问,而搜索报错的话,肯定是数据库启动失败了,重启一下数据库

客户端

npm i -g cnpm

把cnpm的registry指向我们的私有npm服务ip,端口使用registry端口;

cnpm config set registry http://192.xxx.x.x:7001

cnpm login

登陆成功之后

cnpm publish  // 就可以了

如果报错,看看报什么错,对应解决一下

总结:

准备: node npm mysql 确保安装好

安装 cnpmjs.org

修改 cnpmjs.org的配置

启动 cnpmjs.org

启动数据库

上一篇下一篇

猜你喜欢

热点阅读