资讯专栏INFORMATION COLUMN

从0开始使用sinopia搭建私有npm仓库

BlackFlagBin / 1075人阅读

摘要:因为业务安全需要等种种原因,不能够把插件都发布到公共的仓库,所以需要搭建自己的私有仓库,最近自己搭建了一个简单的仓库,踩了些坑,和大家分享一下,希望能够帮到有需要的童鞋本次讲述用从开始搭建仓库,讲得会比较细,觉得啰嗦的童鞋可以只看自己需要的

因为业务安全需要等种种原因,不能够把插件都发布到公共的npm仓库,所以需要搭建自己的私有npm仓库,最近自己搭建了一个简单的npm仓库,踩了些坑,和大家分享一下,希望能够帮到有需要的童鞋

本次讲述用sinopia从0开始搭建npm仓库,讲得会比较细,觉得啰嗦的童鞋可以只看自己需要的哈([原文链接[1])

服务器端 安装nodejs和npm

因为我的linux服务器是centos的,所以我这边讲的是一种在centos上安装node 环境

1.安装wget
yum install -y wget
2.下载最新的node包

可以在nodejs的官网找到最新的下载地址(找到需要的,右键复制链接地址就可以拿到最新的地址啦)

wget https://nodejs.org/en/download/node-v10.15.0-linux-x64.tar.xz
解压安装包
xz -d node-v10.15.0-linux-x64.tar.xz
tar -xf node-v10.15.0-linux-x64.tar.xz
部署bin文件

重点是要找到你的nodejs的文件路径(你将node文件解压到哪里就是哪里。),找不到node路径的童鞋请执行

whereis node

然后执行

ln -s node路径 /usr/bin/node
ln -s node路径 /usr/bin/npm

eg:
//我的node解压路径为/opt/node-v10.15.0-linux-x64/bin/node

ln -s /opt/node-v10.15.0-linux-x64/bin/node /usr/bin/node
ln -s /opt/node-v10.15.0-linux-x64/bin/node /usr/bin/npm

如果出现

ln: failed to create symbolic link ‘/usr/bin/node’: File exists

执行:rm /usr/bin/node
查看是否安装成功
node -v
npm -v
搭建npm仓库 sinopia安装

装好node以后,我们就可以在服务器直接安装sinopia了,一行命令全局安装

npm install -g sinopia 

安装好了可以启动试一下

sinopia

出现下面的结果说明成功跑起来了,这个时候可以打开http://localhost:4873/访问了

Sinopia doesn"t need superuser privileges. Don"t run it under root.
 warn  --- config file  - /root/.config/sinopia/config.yaml
 warn  --- http address - http://localhost:4873/

如果报sinopia: command not found,请添加关联,找到你的sinopia路径(这个路径在之前node路径的子目录里面)

ln -s /opt/node-v10.15.0-linux-x64/bin/sinopia  /usr/bin
pm2

node服务非常脆弱,一般在实际中使用都会配合守护进程。这里我用的是 pm2 做守护进程

安装
npm install -g pm2
pm2 -v

如果出现 pm2: command not found,和sinopia的方法一样

ln -s /opt/node-v10.15.0-linux-x64/bin/pm2 /usr/bin
通过 PM2 启动 sinopia:
pm2 start `which sinopia`

结果类似如下:
┌─────────┬────┬──────┬────────┬────────┬─────┬────────┬───────────┐
│ Name    │ id │ mode │ status │ ↺      │ cpu │ memory │
├─────────┼────┼──────┼────────┼────────┼─────┼────────┼───────────┤
│ sinopia │ 0  │ N/A  │ fork   │ online │ 0   │ 0%     │ 16.7 MB   │
└─────────┴────┴──────┴────────┴────────┴─────┴────────┴───────────┘
sinopia配置修改

默认情况下,sinopia 的配置是不适合直接使用的,所以我们需要对它的配置文件按需酌情修改

我们找到上面提到的配置文件目录,打开配置文件进行编辑

#
# This is the default config file. It allows all users to do anything,
# so don"t use it on production systems.
#
# Look here for more config file examples:
# https://github.com/rlidwka/sinopia/tree/master/conf
#

# path to a directory with all packages
storage: ./storage  #npm包存放的路径

auth:
  htpasswd:
    file: ./htpasswd   #保存用户的账号密码等信息
    # Maximum amount of users allowed to register, defaults to "+inf".
    # You can set this to -1 to disable registration.
    max_users: -1  #默认为1000,改为-1,禁止注册

# a list of other known repositories we can talk to
uplinks:
  npmjs:
    url: http://registry.npm.taobao.org/  #默认为npm的官网,由于国情,修改 url 让sinopia使用 淘宝的npm镜像地址
    
packages:  #配置权限管理
  "@*/*":
    # scoped packages
    access: $all  #表示哪一类用户可以对匹配的项目进行安装 【$all 表示所有人都可以执行对应的操作,$authenticated 表示只有通过验证的人可以执行对应操作,$anonymous 表示只有匿名者可以进行对应操作(通常无用)】
    publish: $authenticated  #表示哪一类用户可以对匹配的项目进行发布

  "*":
    # 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"
    access: $all  #表示哪一类用户可以对匹配的项目进行安装

    # allow all known users to publish packages
    # (anyone can register by default, remember?)
    publish: $authenticated  #表示哪一类用户可以对匹配的项目进行发布

    # if package is not available locally, proxy requests to "npmjs" registry
    proxy: npmjs  #如其名,这里的值是对应于 uplinks

# log settings
logs:
  - {type: stdout, format: pretty, level: http}
  #- {type: file, path: sinopia.log, level: info}

# you can specify listen address (or simply a port) 
listen: 0.0.0.0:4873  #默认没有,只能在本机访问,添加后可以通过外网访问

==listen: 0.0.0.0:4873 这一条一定得加,然后记得把服务器的4873的端口开放==

访问

在自己的电脑浏览器上输入服务器ip地址+端口号,端口号默认为4873

eg:192.186.1.343:4873

到这里,我们可以成功的在自己的服务器上搭建我们的私有npm啦~~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/63164.html

相关文章

  • 0开始使用sinopia搭建私有npm仓库

    摘要:因为业务安全需要等种种原因,不能够把插件都发布到公共的仓库,所以需要搭建自己的私有仓库,最近自己搭建了一个简单的仓库,踩了些坑,和大家分享一下,希望能够帮到有需要的童鞋本次讲述用从开始搭建仓库,讲得会比较细,觉得啰嗦的童鞋可以只看自己需要的 因为业务安全需要等种种原因,不能够把插件都发布到公共的npm仓库,所以需要搭建自己的私有npm仓库,最近自己搭建了一个简单的npm仓库,踩了些坑,...

    yuxue 评论0 收藏0
  • 使用docker和docker-sinopia搭建私有npm

    作为新时代的前端,我们现在很多的项目都已经使用npm作为包管理器了,我们会把一些通用组件发布到npm,但是有时候一些组件涉及到业务或者安全方面的,我们不希望把包发布到所有人都能看到的npm上,这时候我们就需要有一个私有的npm资源库。这里我们选用sinopia来搭建我们自己的npm,然后利用docker来进行打包和部署. 首先我们找到了这个项目https://github.com/kfatehi/...

    oliverhuang 评论0 收藏0
  • 【趣味连载】攻城狮上传视频与普通人上传视频:(一)生成结构化数据

    摘要:背景当知道要上传的视频资料从条变成条时,我就明白,绝对不能再人工处理了。 背景 当知道要上传的视频资料从20条变成100条时,我就明白,绝对不能再人工处理了。他们总是想当然的认为,录入一条数据需要1分钟,那录入20条数据就是20分钟,录入100条数据,不就是100分钟吗?我有时候,真的很想问问他们,没有考虑过人是会犯错的吗?数据越多,出错的可能就越大;但是数据本身,又是不允许出现纰漏的...

    mindwind 评论0 收藏0
  • 【趣味连载】攻城狮上传视频与普通人上传视频:(一)生成结构化数据

    摘要:背景当知道要上传的视频资料从条变成条时,我就明白,绝对不能再人工处理了。 背景 当知道要上传的视频资料从20条变成100条时,我就明白,绝对不能再人工处理了。他们总是想当然的认为,录入一条数据需要1分钟,那录入20条数据就是20分钟,录入100条数据,不就是100分钟吗?我有时候,真的很想问问他们,没有考虑过人是会犯错的吗?数据越多,出错的可能就越大;但是数据本身,又是不允许出现纰漏的...

    MadPecker 评论0 收藏0
  • 使用 docker + verdaccio 搭建npm私有仓库

    摘要:本文介绍如何使用搭建私有仓库,以及使用时如何映射到本地目录,方便简单对仓库进行各种操作。其次,创建目录,并添加的配置文件。当需要把某个项目发布到私有库时,直接。使用包名,即可安装私有包了。本文介绍如何使用 verdaccio 搭建私有npm仓库,以及使用 docker 时如何映射到本地目录,方便简单对仓库进行各种操作。系统环境是 Linux。 verdaccio verdacci...

    fantix 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<