Nexus安装
1
检查服务器上是否安装有 JDK 1.8 +,如果没有则需要下载安装JDK。
2
到sonatype官网下载Nexus Repository Manager OSS
nexus有OSS版和PRO版。OSS版开源免费,PRO版需要付费。
此处下载OSS版
3
将下载的压缩包放到服务器解压
sonatype将Nexus安装包托管到了 Fastly CDN,国内访问Fastly CDN非常卡顿。可能会下载失败,需要多试几次。
解压后会有两个文件夹:
○
nexus-3.69.0-02
nexus软件
○
sonatype-work
nexus工作目录。
该文件夹和nexus软件在相同路径中,最好不要改动。
4
修改nexus的配置
编辑 nexus-3.69.0-02/etc/nexus-default.properties 文件。
或者编辑sonatype-work/nexus3/etc/nexus.properties文件(推荐)
5
在linux上创建nexus用户:
6
使用nexus用户登录,并启动nexus:
7
浏览器放问nexus
启动较缓慢,需要等待一段时间才能连上
http://192.168.xxx.xxx:9091/
首次登录时修改密码
1
进入nexus的web管理页面后,所有的配置都是只读的,需要登录才能操作
2
点击Sign In 进行登录默认用户名:admin默认密码:在 /home/nexus/sonatype-work/nexus3/admin.password 文件中
旧版本Nexus没有该密码文件,默认密码为:admin123
3
首次登录需要修改密码,将密码改为:admin
修改密码后,admin.password文件会被自动删除
4
配置是否允许匿名访问(配置为允许)
启用匿名访问意味着,用户可以在没有凭据的情况下从仓库搜索、浏览和下载组件。
Maven私仓
创建maven私仓
1
使用admin登录nexus
2
点击系统管理设置按钮(左上角小齿轮)
3
创建文件夹保存maven数据:进入 Repository -> Blob Stores,create blob store,类型选择File,名称输入my-maven-file,路径会自动生成,也可以自己调整。
4
创建私仓:进入 Repository -> Repositories,create repository,选择 maven2(hosted)(内网无法连接代理,只能为本机Maven)。
Name: my-mavenOnline:默认勾选Version policy:选择Mixed(快照版和发布版都允许上传)Layout policy:默认StrictContent Disposition:默认 inlineBlob store:选择刚刚创建的my-maven-fileStrict Content Type Validation:默认勾选Deployment policy:选择 Allow redeploy(允许重复上传)点击Create repository完成创建
向maven私仓上传jar包
方式1(适合上传单个jar):使用admin登录页面,点击左侧Upload,选择my-maven,将需要上传的jar包上传即可。
方式2(适合上传多个jar):将需要上传的自己本地的资源库整体上传。
1
先将本地repository仓库文件夹打成一个完整的zip压缩包
2
上传到nexus服务器上
3
解压zip
4
进入repository目录
5
清理*.lastUpdated、_remote.repositories文件
6
将本地仓库里面所有的maven-metadata-alimaven.xml改名为maven-metadata.xml(alimaven是本地maven的settings文件中设置的镜像仓库名)
7
编写 mvnimport.sh 脚本,内容如下
8
将私仓文件、sh脚本授权
9
执行shell脚本并传入参数
10
等全部导入完毕后,在nexus控制台页面刷新即可看到已导入的jar
项目中使用该私仓
配置本地的maven的settings.xml配置文件,加入该私仓。例如:
Docker私仓
创建Docker私仓
1
使用admin登录nexus
2
点击系统管理设置按钮(左上角小齿轮)
3
nexus默认docker是失效的,需要 在security --> Realms,将docker配置成Active
4
创建文件夹保存maven数据:进入 Repository -> Blob Stores,create blob store,类型选择File,名称输入my-docker-file,路径会自动生成,也可以自己调整。
5
创建私仓:进入 Repository -> Repositories,create repository,选择 docker(hosted)。
Name: my-dockerOnline:默认勾选Http: 勾选,并填入将来连接该Docker仓库的端口号8889Https:已经勾选了http,可以不再勾选httpsAllow anonymous docker pull:勾选。(允许不登录时匿名下载镜像)Enable Docker V1 API:默认不勾选。(无需启动对V1旧版本API的支持)Blob store:选择刚刚创建的 my-docker-fileDeployment policy:选择 Allow redeploy(允许重复提交)点击Create repository完成创建
docker客户端对私仓镜像上传下载
需要先安装好Docker客户端,在/etc/docker/daemon.json中加入可信仓库,允许http连接:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
{
"insecure-registries": [
"https://cce.test.com",
"192.168.xxx.xxx:8889"
],
"data-root":"/data/docker",
"log-driver":"json-file",
"log-opts":{
"max-size":"200m",
"max-file":"3"
},
"features": {
"buildkit": true
}
}
加入配置后,重启docker:
1
2
sudo systemctl daemon-reload
sudo systemctl restart docker
下载镜像:
1
2
docker私仓配置了允许匿名下载,无需登录即可进行pull镜像
docker pull 192.168.xxx.xxx/my/tomcat:9.0.90-jre8
上传镜像:
1
2
3
4
5
6
上传镜像到私仓时,需要先登录
docker login -u admin -p admin 192.168.xxx.xxx:8889
将镜像push到私仓
docker push 192.168.xxx.xxx/aaa/aaa-portal:20241031-100820
登出
docker logout 192.168.xxx.xxx:8889
其他仓库
npm私仓、helm私仓等与前面搭建几乎一致。
与docker私仓类似,nexus默认npm也是是失效的,需要 在security --> Realms,将npm配置成Active