美文网首页
搭建自己的npm私有库

搭建自己的npm私有库

作者: 硅谷干货 | 来源:发表于2022-03-26 13:17 被阅读0次

    写在前面

    为什么要学会搭建npm私有库
    

    答:

    • npm私有库只针对公司内部局域网开放,不对外部公开,具有一定的保密性
    • 速度比在直接在npm下载更快,甚至是比淘宝源更快。因为毕竟是在公司局域网
    • 对于发布和下载npm包配置权限管理
    • 私有库能够将包资源进行缓存,响应的话会加快下载速度
    • 搭建npm私有库算作对团队的一个技术亮点

    verdaccio

    verdaccionodejs 创建的轻量的私有npm proxy registryfrokedsinopia@1.4.0 ,是一个开源的npm私有库的搭建工具,可以搭建一套属于自己公司的npm仓库。

    • yarn 、npm 和pnmp 100%兼容
    • 提供的DockerKubernetes支持,很容易安装和使用
    • 发布的包是私有和配置访问权限
    • verdaccio是需要缓存所有相关项,并且在本地或者私有网络下可以加速安装

    搭建过程

    下载之前保证您的node版本>v8.x npm版本>v5.x 
    yarn>v1.x pnpm>v2.x ,web应用支持浏览器
    Chrome,Firefox,Edge和IE11以上
    
    复制代码
    

    安装verdaccio

    //在cmd输入
    npm install -g verdaccio  //npm下载
    
    yarn global add verdaccio  //yarn下载  用yarn下载的时候 verdaccio运行不起来的时候请换成npm下载
    
    //或者nrm切换下源地址  要是报权限错误的话,请选择cmd<以管理员身份运行>在输入一次
    //或者在cmd输入下面的命令:
    npm install -g verdaccio --unsafe-perm  
    //--unsafe-perm添加上是为了防止报 gyp ERR! permission denied 的权限问题
    
    //下载完成后会有红色字体表示:表示没有python的环境,这个时候不需要理会。
    
    //在cmd输入:verdaccio 执行效果如下:
    复制代码
    

    [图片上传失败...(image-f2cd11-1648271864227)]

    配置信息

    config.yaml文件的配置信息

    #
    # 这是默认的配置文件. 它会允许我们做任何事情,
    # 所以不要在生产环境(系统)使用它.
    #
    # 在这里可以看见更多的配置示例:
    # https://github.com/verdaccio/verdaccio/tree/master/conf
    #
    
    # 包含所有包的目录路径,npm私服包的存放目录以及缓存地址
    storage: ./storage
    # 包含plugins的目录路径,默认插件的文件位置,一般只对docker部署有关系
    plugins: ./plugins
    
    web:  #verdaccio的界面
      title: Verdaccio
      # comment out to disable gravatar support 注释掉gravatar禁止使用
      # gravatar: false
      # by default packages are ordercer ascendant (asc|desc)  默认的packages是准备好的两个选择
      # sort_packages: asc
      # convert your UI to the dark side  用户界面是黑夜模式
      # darkMode: true
    
    # translate your registry, api i18n not available yet  看看下你的注册表,i18n api还不能使用
    # i18n:
    # list of the available translations 查看可以使用的注册列表的地址:https://github.com/verdaccio/ui/tree/master/i18n/translations
    #   web: en-US
    
    auth:  
      htpasswd:
        file: ./htpasswd  #保存用户的账号信息比如用户名,密码等,还没有注册或者登录的话暂时看不到
        # Maximum amount of users allowed to register, defaults to "+inf".允许注册的最大用户数量,可以是无穷大
        # You can set this to -1 to disable registration. 你可以设置-1去禁止用户通过 npm adduser 去注册
        # max_users: 1000  #默认注册人数最大数量是1000
    
    # a list of other known repositories we can talk to  我们需要了解其他相关有名的存储库
    uplinks: #配置上游的npm服务器,主要用于请求的库不存在时可以去到上游服务器去获取,可以多配置下上游链路的链接
      npmjs:
        url: https://registry.npmjs.org/
        agent_options:  #代理的配置项
          keepAlive: true 
          maxSockets: 40
          maxFreeSockets: 10
    
    packages: # 配置模块,access访问下载权限,pushlish包的发布权限
      '@*/*': # 一种是@/表示某下面所属的某项目,关键字匹配
        # scoped packages   配置权限管理
        access: $all # 表示哪一类用户可以对匹配的项目进行安装(install)和查看包的信息
        publish: $authenticated # 表示哪一类用户可以对匹配的项目进行发布(publish)
        unpublish: $authenticated # 表示哪一类用户可以对匹配的项目进行卸载(publish)
        proxy: npmjs # 这里的值是对应于 uplinks 的名称,如果本地不存在,允许去对应的uplinks去拉取
    
      '**': # 另一种是*匹配项目名称(名称在package.json中有定义)
        # allow all users (including non-authenticated users) to read and
        # publish all packages
        # 允许所有用户(包括未经身份验证的用户)读取和发布所有包
        # you can specify usernames/groupnames (depending on your auth plugin) 您可以指定用户名/组织名称(取决于验证身份的插件)
        # and three keywords: "$all", "$anonymous", "$authenticated" 三个关键字:所有的,匿名的,验证过的  也可以使用具体的用户名或者组织名称(公司私有的名字)和配置的用户表 htpasswd 有关
        access: $all
    
        # allow all known users to publish/publish packages 允许所有用户去发布包
        # (anyone can register by default, remember?)  任何人都可以默认注册
        publish: $authenticated
        unpublish: $authenticated
    
        # if package is not available locally, proxy requests to 'npmjs' registry 如果包不允许在本机使用,可以用proxy请求npmjs注册表的代理
        proxy: npmjs
    
    # You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections. 传入的指定连接的HTTP/1.1服务器保持活跃状态直到超时,以秒为单位
    # A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout.  值为0的时候的服务表现行为和8.0.0之前版本的nodejs链接的时候没有保持活跃状态导致超时
    # WORKAROUND: Through given configuration you can workaround following issue  解决办法:通过已知的配置,你可以解决这些问题: https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough.  如果60不够的话可以设置为0
    server:
      keepAliveTimeout: 60 
    
    middlewares:
      audit:
        enabled: true
    
    # log settings  设置日志
    logs:
      - { type: stdout, format: pretty, level: http }
      #- {type: file, path: verdaccio.log, level: info}
    #experiments: 实验性的
    #  # support for npm token command  支持npm的token令牌
    #  token: false
    #  # support for the new v1 search endpoint, functional by incomplete read more on ticket 1732
    #  search: false
    #  # disable writing body size to logs, read more on ticket 1912
    #  bytesin_off: false
    
    # This affect the web and api (not developed yet) 这些会影响web和api(尚未开发的功能)
    #i18n:
    #web: en-US
    
    #默认是没有的,只能在本机访问,添加后可以通过外网访问
    listen:0.0.0.0:4873
    复制代码
    

    通过pm2启动verdaccio

    • 什么是pm2?

    pm2 是一款著名的nodejs进程守护和管理工具,下面我们用pm2来启动verdaccio:

    npm install -g pm2 //安装pm2
    
    pm2 start verdaccio //启动verdaccio  status为online即为成功 如下图所示:
    复制代码
    

    [图片上传失败...(image-dece0d-1648271864227)]

    pm2常见命令

     npm install pm2 -g     // 命令行安装 pm2
     pm2 start app.js       // 启动app.js应用程序
     pm2 start app.js -i 4  // 后台运行pm2,启动4个app.js
                            // 也可以把'max' 参数传递给 star
                            // 正确的进程数目依赖于Cpu的核心数目
    
    pm2 start app.js  --watch      // 当文件变化时自动重启应用
    pm2 list                       // 列表 PM2 启动的所有的应用程序
    pm2 monit                      // 显示每个应用程序的CPU和内存占用情况
    pm2 logs                       // 显示所有进程日志
    pm2 start app.js --name="api"  // 启动应用程序并命名为 "api"
    pm2 start script.sh            // 启动 bash 脚本
    pm2 show [app-name]            // 显示应用程序的所有信息
    pm2 logs [app-name]            // 显示指定应用程序的日志
    pm2 stop all                   // 停止所有的应用程序
    pm2 stop 0                     // 停止 id为 0的指定应用程序
    pm2 restart all                // 重启所有应用
    pm2 restart 0                  // 重启指定的进程
    pm2 delete all                 // 关闭并删除所有应用
    pm2 delete 0                   // 删除指定应用程序id为0的
    ...可以百度查阅下  ^_^
    复制代码
    

    发布npm包的流程

    1. 新建一个文件夹名称为npm-test ,在cmd控制台上输入
    cd npm-test  
    npm init        //初始化   默认指向index.js文件,所以新建一个index.js文件
    
    //index.js文件
    module.exports.Say = function(name){
        return  ("Hello " + name);
    }
    复制代码
    

    好了,执行verdaccio命令就可以发布了

     npm adduser --registry http://localhost:4873      //添加功能,无账号的添加完毕直接包
     npm login --registry=http://localhost:4873        //登录功能,有账号的话可以直接使用这个
     npm publish --registry http://localhost:4873      //发布包
    复制代码
    

    可以使用nrm进行管理npm源,来避免手动输入registry

    nrm add company http://localhost:4873  //company可以换任意名称  url地址  添加功能
    nrm use company       //使用company的源地址
    
    //这样的话简单了结,不用手动输入registry
    npm addUser  
    npm login
    npm publish
    
    //注意:registry要切换到公司私有服务器地址,如果不是用nrm管理切换,则需要带上私有registry(重复啦!)
    复制代码
    

    此时在http://localhost:4873/ 页面上进行更新,就会发现你发布的包(包的名称就是文件的名称)。

    接下来呢,我们来下载刚刚发布的包

    //注意:registry要切换到公司私有服务器地址,如果不是用nrm管理切换,则需要带上私有registry(再来一遍)
    //新建一个文件夹名为  app
    cd app
    npm install npm-test  //要是没有切换的话,请手动添加 --registry=http://localhost:4873
    //成功如图所示
    复制代码
    
    • 删除发布的包
    npm unpublish npm-test --force  //清除发布的包
    复制代码
    

    npm私有库的权限管理

    因为verdaccio默认是人人都可以注册的,所以需要先将注册窗口关闭

    auth:
      htpasswd:
        file: ./htpasswd
        // 此配置项可以关闭注册功能
        max_users: -1
    复制代码
    

    verdaccio 的认证是基于 verdaccio-htpasswd, 可以通过官方提供的工具来生成 www.htaccesstools.com/htpasswd-ge… htpasswd 中即可,这样的话就可以登录npm私有库

    之后就需要修改verdaccio文件下的config.yaml的配置:针对不同的包来设置access,publish,unpublish对应的权限组,因为htpasswd是默认的鉴权插件,所以只能写入相应的用户名,all,authenticated,$anonymous

    //小小实例下:
    auth:
      htpasswd:
        file: ./htpasswd
        // 此配置项可以关闭注册功能
        max_users: -1 
        duGroup:
        // 这里可以自定义用户组
        demoPublish: [xiaoming, xiaohong, xiaoli]
        demoUnpublish: [xiaojun, xiaoming]
        testPublish: [xiaoming,xiaojun]
    
     packages:
            '@demo/*':
                access: $all
            // 针对不同的包,可以指定不同的用户组来满足权限控制
                publish: demoPublish
                unpublish: demoUnpublish
                proxy: npmjs
         'test': 
                access: $all
                publish: testPublish
                unpublish: demoUnpublish
                proxy: npmjs
    复制代码
    

    或者通过安装htpasswd-for-sinopia工具来添加账号

     npm install htpasswd-for-sinopia -g
    
     sinopia-adduser   // 在 htpasswd 目录执行
    复制代码
    

    为其他登录的用户生成用户名和密码,之后将用户名和密码写入verdaccio文件夹下的htpasswd文件中,然后就跟上文是一样的步骤。

    相关文章

      网友评论

          本文标题:搭建自己的npm私有库

          本文链接:https://www.haomeiwen.com/subject/wmfsjrtx.html