npm 和 maven 使用 Nexus3 私服 | 前后端一起学

前文《Docker 搭建 Nexus3 私服 》介绍了在 docker 环境下安装 nexus3 以及 nexus3 的基本操作和管理,本文分别介绍 npm(前端)和 maven(后端)如何使用 nexus3 作为私服。文中的 demo 可以在 github 上搜索 youyage_nexus3_demos 获取。

本篇内容分为上下两个部分,上篇是npm使用 Nexus3 私服,下篇是maven 使用 Nexus3 私服。

1 npm 中使用 Nexus3

这里以一个 JS 库为例来说明前端公共库如何发布到 Nexus3 私服。Vue或其他组件库的发布也是一样的操作,只是打包等发布前的操作不同。本文中所有的 demo 都放在 youyage_nexus3_demo

1.1 JavaScript 库开发

1) 创建 JS 库项目目录: js-demo-lib

2)使用 npmyarn 等包管理工具初始化项目:

yarn init

3)由于咱们重点是演示 nexus3 发布 JS 库,故 webpack 打包等操作咱们都略过。修改 package.json,指定 type 属性值为 module:

{
  "name": "js-demo-lib",
  "version": "1.0.1",
  "type": "module",
  "main": "index.js",
  "license": "MIT",
  "author": {
    "name": "youyage",
    "email": "heroyyg@126.com"
  }
}

4)在项目根目录下创建入口文件 index.js:

export const testMsg = (str) => {
    return hello ${str}
}

export default {
    testMsg
}

该文件中就只提供了一个 testMsg 方法。

1.2 创建 Nexus3 前端仓库

1)创建仓库,仓库类型选择 npm(hosted),Name 填写 demo-npm-hosted,点击页面底部的 Create repository按钮创建仓库;

2)创建仓库,仓库类型选择 npm(proxy),Name 填写 demo-npm-proxy

Remote storage 即远程仓库的地址,可以填 npm 官方的地址,也可填写淘宝镜像或其他地址,这里我填写官方地址: https://registry.npmjs.org,点击页面底部的 Create repository按钮创建仓库;

3)创建仓库,仓库类型选择 npm(group),Name 填写 demo-npm-group,在下面的 Group 中将左侧两个刚创建的仓库移动到右边:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

点击页面底部的 Create repository按钮创建仓库。

通过上面的三个步骤,便创建了npm的三种类型的仓库。

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

点击 demo-npm-group 后面的 copy 按钮可以查看并复制私服地址:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

1.3 JS 库发布到 Nexus3 私服仓库

要发布 JS 库,需要先通过 npm 指定 Registry 登录。Registry 为私服 hosted 仓库的地址:

http://localhost:8081/repository/demo-npm-hosted/

在命令行中使用 npm 登录 nexus3 私服:

npm login --registry http://localhost:8081/repository/demo-npm-hosted/

依次填写上文创建的用户的用户名 username、密码 password、邮箱 email:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

401 错误处理

如果登录失败,出现 401 错误:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

在确保用户名、密码、邮箱都正确的前提下,可以采用下面的方式进行处理:

打开系统当前用户主目录中的 .npmrc 文件:

vi /Users/liuyun/.npmrc

删除该文件中对应私服地址的 authToken,如下图,删除该行,然后重新登录。

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

登录成功后会提示:

npm notice Log in on http://localhost:8081/repository/demo-npm-hosted/

发布 JS 库:

npm publish --registry http://localhost:8081/repository/demo-npm-hosted/

如果发布时提示 401,可按照上述登录 401 进行检查;如果还是失败,则检查 nexus3 的 Realms 设置,查看 npm Bearer Token Realm 是否激活。

JS 库发布成功,可以在 Nexus 中看到:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

1.4 应用通过 Nexus3 使用 JS 库

1) 创建 JS 库项目目录: js-demo-app

2)使用 npmyarn 等包管理工具初始化项目:

yarn init

3)使用 yarn 添加依赖:上面发布的 JS 库 js-demo-lib:

yarn add js-demo-lib --registry http://localhost:8081/repository/demo-npm-group/

4)修改 package.json,指定 type 属性值为 module

5)在项目根目录下创建入口文件 index.js:

import lib from 'js-demo-lib'

console.log(lib.testMsg('程序员优雅哥'))

该文件中引入 JS 库,并调用 JS 库的 testMsg 方法。

6)在控制台中测试运行:

node ./index.js

控制台中输出:

hello 程序员优雅哥

如果 JS 库升级了,可以使用如下命令在应用端升级:

yarn upgrade js-demo-lib --registry http://localhost:8081/repository/demo-npm-group/

1.5 命令总结

npm 登录私服使用 hosted 地址:

npm login --registry http://localhost:8081/repository/demo-npm-hosted/

npm 发布使用 hosted 地址:

npm publish --registry http://localhost:8081/repository/demo-npm-hosted/

npm 添加 / 更新私服上的包,使用 group 地址:

yarn add js-demo-lib --registry http://localhost:8081/repository/demo-npm-group/
yarn upgrade js-demo-lib --registry http://localhost:8081/repository/demo-npm-group/

2 Maven 中使用 Nexus3

2.1 Nexus3 Maven 仓库

安装好 nexus3 后,默认有四个 maven 仓库:

maven-central:类型为 proxy,对中央仓库的代理,默认配置了 https://repo1.maven.org/maven2/,可以将其修改为阿里云镜像: http://maven.aliyun.com/nexus/content/groups/public/
maven-release:类型为 hosted,开发人员部署自己的 release 版本 jar 包的宿主仓库
maven-snapshots:类型为 hosted,开发人员部署自己的 snapshots 版本 jar 包的宿主仓库
maven-public:类型为 group,组仓库,聚合了上面三者。

可以按照这四者进行创建,也可以直接使用。这里就直接使用这四个仓库了。

2.2 配置 Maven

打开 maven 的配置文件 settings.xml,如果只是从 nexus3 拉取包,则只需要配置镜像(mirror)即可;如果要发布包到 nexus3 上,除了配置镜像 mirror,还需要配置 server。

  • 镜像配置(group类型 – maven-public 的地址)

                nexus3-maven-public
                central
                Nexus3 Maven Public
                http://localhost:8081/repository/maven-public/

  • 配置 server

        nexus3-releases
        youyage
        111111

        nexus3-snapshots
        youyage
        111111

server 中的 username 和 password 就是 上文在 nexus3 中创建的用户的 id 和 password。

2.3 Java 包发布到 Nexus3 私服仓库

现在创建一个 Maven 项目,将其发布到 Nexus3 中。

1)新建 Maven 项目,项目名为: java-demo-lib

2)pom.xml 如下:


    4.0.0

    com.yygnb.demo.lib
    java-demo-lib
    1.0-SNAPSHOT

        8
        8

            nexus3-releases
            nexus3-releases
            http://localhost:8081/repository/maven-releases/

            nexus3-snapshots
            nexus3-snapshots
            http://localhost:8081/repository/maven-snapshots/

由于需要将该项目发布到 Nexus3 中,故需要在 distributionManagement 节点中配置 repositoryrepository 中需配置三个子节点:

  • id:与 settings.xml 中配置的 server 中的 id 一致;
  • name:无特殊要求
  • url:type 为 hosted 的 maven 仓库。由于 hosted 类型的仓库分为 release 和 snapshots,故两个地址分别对应 maven-snapshots 和 maven-release 的地址。

3)编写 DemoUtils:

package com.yygnb.demo.lib;

public class DemoUtils {

    public static String test(String str) {
        return "snapshot - Hello " + str;
    }
}

发布 snapshots 包:

由于现在 pom.xml 中 version 为: 1.0-SNAPSHOT,将其发布到 maven-snapshots 中。执行

mvn clean deploy

执行成功如下:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

在 nexus3 页面上也可以看到在 maven-snapshots 仓库中有这个包:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

发布 release 包:

为了方便后面看效果,此处将DemeUtils 中 test 方法返回值修改为:

return "release - Hello " + str;

将 pom.xml 中 version 修改为 1.0:

1.0

再次执行 mvn clean deploy。执行成功后,可以在 maven-release 仓库中看到这个包:

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

如此一来,release 和 snapshots 都成功发布到 nexus3 的 hosted 仓库中了。

2.4 应用通过 Nexus3 使用 Java 通用包

最后创建一个项目,分别测试拉取上面发布的 snapshots 和 release 包。

创建 Maven 项目,项目名为 java-demo-app。在 pom.xml 中添加repository,指定 nexus3 的 maven-public 地址:


        nexus3-maven-public
        nexus3-maven-public
        http://localhost:8081/repository/maven-public/

            true

            true

添加上面 java-demo-lib snapshot 依赖:


        com.yygnb.demo.lib
        java-demo-lib
        1.0-SNAPSHOT

刷新 Maven,可以看到从 nexus3 中拉取了该依赖。

写个 main 方法测试:

package com.yygnb.demo.app;

import com.yygnb.demo.lib.DemoUtils;

public class MainDemo {

    public static void main(String[] args) {
        System.out.println(DemoUtils.test("程序员优雅哥"));
    }
}

执行该方法,控制台输出:

snapshot - Hello 程序员优雅哥

先将依赖版本修改为 1.0,即:

<dependencies>
    <dependency>
        <groupid>com.yygnb.demo.lib</groupid>
        <artifactid>java-demo-lib</artifactid>
        <version>1.0</version>
    </dependency>
</dependencies>

刷新 Maven,重新执行 main 方法,控制台输出:

release - Hello &#x7A0B;&#x5E8F;&#x5458;&#x4F18;&#x96C5;&#x54E5;

2.5 配置总结

1) settings.xml

...

                nexus3-maven-public
                central
                Nexus3 Maven Public
                http://localhost:8081/repository/maven-public/

        nexus3-releases
        youyage
        111111

        nexus3-snapshots
        youyage
        111111

...

2)pom.xml

...

        nexus3-maven-public
        nexus3-maven-public
        http://localhost:8081/repository/maven-public/

            true

            true

        nexus3-releases
        nexus3-releases
        http://localhost:8081/repository/maven-releases/

        nexus3-snapshots
        nexus3-snapshots
        http://localhost:8081/repository/maven-snapshots/

...

关于 nexus3 在 npm 或 maven 环境下的更多操作,在后面的实战部分再继续,如 Vue3 组件库开发和发布、基于 SpringBoot / Spring Cloud 通用权限服务等。

npm 和 maven 使用 Nexus3 私服 | 前后端一起学

感谢你阅读本文,如果本文给了你一点点帮助或者启发,还请三连支持一下,点赞、关注、收藏,作者会持续与大家分享更多干货

Original: https://www.cnblogs.com/youyacoder/p/16650210.html
Author: 程序员优雅哥(/同)
Title: npm 和 maven 使用 Nexus3 私服 | 前后端一起学

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/578493/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • windows系统命令行cmd查看显卡驱动版本号CUDA

    好看请赞,养成习惯:) 本文来自博客园,作者:靠谱杨, 转载请注明原文链接:https://www.cnblogs.com/rainbow-1/p/16656547.html 关于…

    Linux 2023年6月14日
    0128
  • vue+vant音乐播放器(andriod)项目

    新建项目 在适合的目录下打开终端输入vue create music_player,回车 选择Default([Vue 2] babel,eslint) 等待项目构建完成 项目构建…

    Linux 2023年6月13日
    096
  • Ubuntu无法telnet

    (1)/etc/hosts被修改过 (2)防火墙没有关闭 (3)没有安装相关服务 (4)/etc/inetd.conf文件没有telnet相关内容 (1)把/etc/hosts文件…

    Linux 2023年6月8日
    0101
  • Linux的安装和配置

    Linux的安装和网络配置 CentOS7安装教程 https://www.php.cn/centos/472898.html 1.虚拟网络编辑器配置 通过VMware菜单栏,依次…

    Linux 2023年6月11日
    098
  • docker安装zabbix

    Zabbix 为每个组件都提供了 Docker 镜像 ,作为弹性和自给自足的容器,促使加快部署和更新过程。Zabbix 组件支持 MySQL 和 PostgreSQL 数据库、Ap…

    Linux 2023年6月6日
    094
  • 让滚动条自动滚动到最底部(可用)

    代码: <body> </body> 需求: main高度不断增加,保持页面滚动条始终在底部 解决方案: $(function(){ ….//main&…

    Linux 2023年6月13日
    0124
  • Paxos 协议简单介绍

    一、简介 Paxos 协议是少数在工程实践中证实的强一致性、高可用的去中心化分布式协议。Google 的很多大型分布式系统都采用了 Paxos 算法来解决分布式一致性问题,如 Ch…

    Linux 2023年6月16日
    0146
  • 部署前后端为独立的 Docker 节点

    在『服务器部署 Vue 和 Django 项目的全记录』一文中,介绍了在服务器中使用 Nginx 部署前后端项目的过程。然而,当 Web 应用流量增多时,需要考虑负载均衡、流量分发…

    Linux 2023年6月7日
    0123
  • 单片机 MCU 固件打包脚本软件

    ​ 1 前言 开发完 MCU 软件后,通常都会生成 hex 文件或者 bin 文件,用来做固件烧录或者升级,如果用来做产品开发,就涉及到固件版本的问题,初学者通常采用固件文件重命名…

    Linux 2023年6月7日
    0106
  • jarwarSpringBoot加载包内外资源的方式,告别FileNotFoundException吧

    工作中常常会用到文件加载,然后又经常忘记,印象不深,没有系统性研究过,从最初的war包项目到现在的springboot项目,从加载外部文件到加载自身jar包内文件,也发生了许多变化…

    Linux 2023年6月6日
    0116
  • git 的使用

    git 的使用 1、介绍 代码版本管理、协同开发 对文件(代码)进行版本管理 完成协同开发 项目,帮助程序员整合代码 i)帮助开发者合并开发的代码 ii)如果出现冲突代码的合并,会…

    Linux 2023年6月14日
    0100
  • nginx配置文件讲解及示例(可复制)

    【示例一】 运行用户 user www-data; 启动进程,通常设置成和cpu的数量相等 worker_processes 1; 全局错误日志及PID文件 error_log /…

    Linux 2023年6月6日
    086
  • 剑指offer计划20( 搜索与回溯算法中等)—java

    1.1、题目1 剑指 Offer 07. 重建二叉树 1.2、解法 注释解法。 1.3、代码 class Solution { int[] preorder; HashMap ma…

    Linux 2023年6月11日
    0113
  • Laxcus集群操作系统应用软件:远程终端

    今天介绍一个Laxcus集群操作系统上的应用软件:远程终端。 远程终端提供和控制台相同的功能,都是由用户使用分布式命令操纵计算机集群上的服务器,处理各种各样的分布计算任务。所不同的…

    Linux 2023年6月6日
    081
  • CentOS 压缩解压

    打包:将多个文件合成一个总的文件,这个总的文件通常称为 “归档”。 压缩:将一个大文件通过某些压缩算法变成一个小文件。 1.1、tar 压缩格式: tar …

    Linux 2023年6月8日
    095
  • 我最鄙视的程序员

    今天在技术群里看到关于优秀程序员特质的话题,让我想起多年前的一个同事,一个我最鄙视的程序员。 他的名字叫李伟(化名),是入职没多久的员工,我所在的开发二组和他在的一组,以前没有过工…

    Linux 2023年6月6日
    094
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球