nexus创建maven私服

目前版本已经更新到了3.X
下载地址:https://www.sonatype.com/download-oss-sonatyp点击打开链接
下载文件名:nexus-3.16.1-02-win64.zip
下载完成后直接解压到想要的目录,解压后会有两个目录:
sonatype-work(工作目录)
nexus-3.16.1-02(安装文件目录)
执行命令安装私服(使用管理员权限在dos下执行命令安装私服)以便开机自启不需要每次都启动,虽然维护maven仓库的私服应该是局域网中一台一直开启的机器,但还是说一下这里想把nexus做成win10服务的一个坑
nexus.exe /install //安装
nexus.exe /uninstall//卸载
net start nexus //启动
net stop nexus//停止

0.前提都是在bin目录下执行命令的例如我的D:\java\application\nexus\nexus-3.16.1-02\bin
1.首先报这个错是因为没有管理员权限Could not open SCManager.
所以win+x 打开windows powershell管理员
2.然后执行nexus.exe /install报错
nexus.exe : 无法将“nexus.exe”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确
保路径正确,然后再试一次。
所在位置 行:1 字符: 1

  • nexus.exe /install
  •   + CategoryInfo          : ObjectNotFound: (nexus.exe:String) [], CommandNotFoundException
      + FullyQualifiedErrorId : CommandNotFoundException
    
    

3.这是因为找不到命令 nexus.exe,但它确实存在于当前位置。默认情况下,Windows PowerShell 不会从当前位置加载 命令。如果信任此命令,请改为键入“.\nexus.exe”
所以执行.\nexus.exe /install
4.执行成功,启动这个服务,稍等一会时间,在浏览器中访问 http://localhost:8081/。就能够得到这个页面.如下图所示:

image.png

image.png
image.png

私服是指私有服务器,是架设在局域网的一种特殊的远程仓库,目的是代理远程仓库及部署第三方构建。有了私服之后,当 Maven 需要下载构件时,直接请求私服,私服上存在则下载到本地仓库;否则,私服请求外部的远程仓库,将构件下载到私服,再提供给本地仓库下载。

image

为什么要构建Nexus私服?
如果没有Nexus私服,我们所需的所有构件都需要通过maven的中央仓库和第三方的Maven仓库下载到本地,而一个团队中的所有人都重复的从maven仓库下载构件无疑加大了仓库的负载和浪费了外网带宽,如果网速慢的话,还会影响项目的进程。很多情况下项目的开发都是在内网进行的,连接不到maven仓库怎么办呢?开发的公共构件怎么让其它项目使用?这个时候我们不得不为自己的团队搭建属于自己的maven私服,这样既节省了网络带宽也会加速项目搭建的进程,当然前提条件就是你的私服中拥有项目所需的所有构件。

  1. 仓库介绍
    1)Maven可直接从宿主仓库下载构件,也可以从代理仓库下载构件,而代理仓库间接的从远程仓库下载并缓存构件
    2)为了方便,Maven可以从仓库组下载构件,而仓库组并没有时间的内容(下图中用虚线表示,它会转向包含的宿主仓库或者代理仓库获得实际构件的内容).

3.1 代理仓库(Proxy Repository)
顾名思义是代理第三方仓库的,如:

maven-central

nuget.org-proxy

版本策略(Version Policy):

Release: 正式版本

Snapshot: 快照版本

Mixed:混合模式

布局策略(Layout Policy):

Strict:严格

Permissive:宽松

3.2 宿主仓库(Hosted Repository)
存储本地上传的组件和资源的,如:

maven-releases

maven-snapshots

nuget-hosted

部署策略(Deployment Policy):

Allow Redeploy:允许重新部署

Disable Redeploy:禁止重新部署

Read-Only:只读

3.3 仓库组(Repository Group)
通常包含了多个代理仓库和宿主仓库,在项目中只要引入仓库组就可以下载到代理仓库和宿主仓库中的包,如:

maven-public

nuget-group

4登录
右上角登录,默认的用户名是admin密码是admin123

4.4 搜索(Search)

这个就是类似Maven仓库上的搜索功能,就是从私服上查找是否有哪些包。

注意:

1) 在Search这级是支持模糊搜索的,如图所示:

image

2)如果进入具体的目录,好像不支持模糊搜索,如图所示:

image

注意下面几点说明:
1.component name的一些说明:
1)maven-central:maven中央库,默认从https://repo1.maven.org/maven2/拉取jar
2)maven-releases:私库发行版jar
3)maven-snapshots:私库快照(调试版本)jar
4)maven-public:仓库分组,把上面三个仓库组合在一起对外提供服务,在本地maven基础配置settings.xml中使用。
2.Nexus默认的仓库类型有以下四种:
1)group(仓库组类型):又叫组仓库,用于方便开发人员自己设定的仓库;
2)hosted(宿主类型):内部项目的发布仓库(内部开发人员,发布上去存放的仓库);
3)proxy(代理类型):从远程中央仓库中寻找数据的仓库(可以点击对应的仓库的Configuration页签下Remote Storage Location属性的值即被代理的远程仓库的路径);
4)virtual(虚拟类型):虚拟仓库(这个基本用不到,重点关注上面三个仓库的使用);
3.Policy(策略):表示该仓库为发布(Release)版本仓库还是快照(Snapshot)版本仓库;
4.Public Repositories下的仓库
1)3rd party: 无法从公共仓库获得的第三方发布版本的构件仓库,即第三方依赖的仓库,这个数据通常是由内部人员自行下载之后发布上去;
2)Apache Snapshots: 用了代理ApacheMaven仓库快照版本的构件仓库
3)Central: 用来代理maven中央仓库中发布版本构件的仓库
4)Central M1 shadow: 用于提供中央仓库中M1格式的发布版本的构件镜像仓库
5)Codehaus Snapshots: 用来代理CodehausMaven 仓库的快照版本构件的仓库
6)Releases: 内部的模块中release模块的发布仓库,用来部署管理内部的发布版本构件的宿主类型仓库;release是发布版本;
7)Snapshots:发布内部的SNAPSHOT模块的仓库,用来部署管理内部的快照版本构件的宿主类型仓库;snapshots是快照版本,也就是不稳定版本
所以自定义构建的仓库组代理仓库的顺序为:Releases,Snapshots,3rd party,Central。也可以使用oschina放到Central前面,下载包会更快。
5.Nexus默认的端口是8081,可以在etc/nexus-default.properties配置中修改。
6.Nexus默认的用户名密码是admin/admin123
7.当遇到奇怪问题时,重启nexus,重启后web界面要1分钟左右后才能访问。
8.Nexus的工作目录是sonatype-work(路径一般在nexus同级目录下)
[root@master-node local]# pwd
/usr/local
[root@master-node local]# ls nexus/
bin deploy etc lib LICENSE.txt NOTICE.txt public system
[root@master-node local]# ls sonatype-work/
nexus3
[root@master-node local]# ls sonatype-work/nexus3/
backup blobs cache db elasticsearch etc generated-bundles health-check instances keystores lock log orient port tmp

4.5 Browse

image

1)Assets

这是能看到所有的资源,包含Jar,已经对Jar的一些描述信息。

2)Components

这里只能看到Jar包。

4.6 BlobStores

文件存储的地方,创建一个目录的话,对应文件系统的一个目录,如图所示:

image

4.7 Repositories

image
  1. Proxy

这里就是代理的意思,代理中央Maven仓库,当PC访问中央库的时候,先通过Proxy下载到Nexus仓库,然后再从Nexus仓库下载到PC本地。
这样的优势只要其中一个人从中央库下来了,以后大家都是从Nexus私服上进行下来,私服一般部署在内网,这样大大节约的宽带。

创建Proxy的具体步骤
1--点击“Create Repositories”按钮

image

2--选择要创建的类型

image

3--填写详细信息

Name:就是为代理起个名字

Remote Storage: 代理的地址,Maven的地址为: https://repo1.maven.org/maven2/

Blob Store: 选择代理下载包的存放路径

image
  1. Hosted
    Hosted是宿主机的意思,就是怎么把第三方的Jar放到私服上。
    Hosted有三种方式,Releases、SNAPSHOT、Mixed
    Releases: 一般是已经发布的Jar包
    Snapshot: 未发布的版本
    Mixed:混合的
    Hosted的创建和Proxy是一致的,具体步骤和上面基本一致。

值得注意的是:
Deployment Pollcy: 需要把策略改成“Allow redeploy”。

image
  1. 能把两个仓库合成一个仓库来使用,目前没使用过,所以没做详细的研究。

4.8 Security

这里主要是用户、角色、权限的配置(上面已经提到了在这里添加用户和角色等)

image

4.9 Support

包含日志及数据分析。

image

4.10 System
这主要是邮件服务器,调度设置的地方。

这部分主要讲怎么和Maven做集成,集成的方式主要分以下种情况:代理中央仓库、Snapshot包的管理、Release包的管理、第三方Jar上传到Nexus上。

  1. 代理中央仓库

只要在PMO文件中配置私服的地址(比如http://192.168.23.38:8081)即可,配置如下:

<repositories>

  <repository>

   <id>maven-central</id>

   <name>maven-central</name>

  <url>http://192.168.23.38:8081/repository/maven-central/</url>

   <snapshots>

      <enabled>true</enabled>

   </snapshots>

   <releases>

     <enabled>true</enabled>

   </releases>

  </repository>

</repositories>

  1. Snapshot包的管理
  1. 修改Maven的settings.xml文件,加入认证机制。
<servers>

<server>

  <id>nexus</id>

  <username>admin</username>

  <password>admin123</password>

   </server>

</servers>

2.修改工程的Pom文件

<distributionManagement>

  <snapshotRepository>

    <id>nexus</id>

    <name>Nexus Snapshot</name>

 <url>http://192.168.23.38:8081/repository/maven-snapshots/</url>

   </snapshotRepository>

   <site>

     <id>nexus</id>

     <name>Nexus Sites</name>

<url>dav:http://192.168.23.38:8081/repository/maven-snapshots/</url>

    </site>

</distributionManagement>

注意事项:

image

上面修改的Pom文件如截图中的名字要跟settings.xml文件中的名字一定要对应上。

  1. 上传到Nexus上

1--项目编译成的jar是Snapshot(POM文件的头部)

groupId>com.woasis</groupId>

<artifactId>test-nexus</artifactId>

<version>1.0.0-SHAPSHOT</version>

<packaging>jar</packaging>

2--使用mvn deploy命令运行即可(运行结果在此略过)

3--因为Snapshot是快照版本,默认他每次会把Jar加一个时间戳,做为历史备份版本。

  1. Release包的管理
  1. 与Snapshot大同小异,只是上传到私服上的Jar包不会自动带时间戳
    
  2. 与Snapshot配置不同的地方,就是工程的PMO文件,加入repository配置
    

<distributionManagement>

<repository>

<id>nexus</id>

<name>Nexus Snapshot</name>

<url>http://192.168.23.38:8081/repository/maven-releases/</url>

</repository>

   3. 打包的时候需要把Snapshot去掉
  1. 第三方Jar上传到Nexus上

[root@master-node src]#mvn deploy:deploy-file -DgroupId=org.jasig.cas.client-DartifactId=cas-client-core -Dversion=3.1.3 -Dpackag
注意事项:
-DrepositoryId=nexus 对应的就是Maven中settings.xml的认证配的名字。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容