部署nexus 并使用 docker仓库
一、Nexus简介
Nexus 是一个强大的仓库管理器,极大地简化了内部仓库的维护和外部仓库的访问。
2016 年 4 月 6 日 Nexus 3.0 版本发布,相较 2.x 版本有了很大的改变:
- 对低层代码进行了大规模重构,提升性能,增加可扩展性以及改善用户体验。
- 升级界面,极大的简化了用户界面的操作和管理。
- 提供新的安装包,让部署更加简单。
- 增加对 Docker, NeGet, npm, Bower 的支持。
- 提供新的管理接口,以及增强对自动任务的管理。
二、为什么用Nexus
- 团队在开发一个项目的各个模块,为了让自己开发的模块能够快速让其他人使用,你会想要将snapshot版本的构件部署到Maven仓库中,其他人只需要在POM添加一个对于你开发模块的依赖,就能随时拿到最新的snapshot。
- 上传第三方Jar包。有时候某些jar包官方仓库中是没有的,之前发过一篇文章也提到了解决这个依赖的问题,如果时候用了Nexus可以直接把第三方的Jar包上传到Nexus,开发者可以直接从Nexus私服中下载Jar包。
- 使用了私服之后,项目寻找依赖的顺序会发生改变,首先在本地仓库中寻找,本地仓库没有的话在到私服寻找,最后才到官方仓库中寻找,找到之后又把jar下载到私服,在从私服下载到本地。这样做的好处是如果使用公司内网下载maven插件或者依赖会非常快,提供了效率
三、容器部署
本次部署为了简单方便直接使用官方镜像,二进制安装请参考官方文档
1. 安装docker
#创建工具目录
mkdir -p /opt/tools
cd /opt/tools
#下载tar包
wget https://download.docker.com/linux/static/stable/x86_64/docker-20.10.2.tgz
tar -xvf docker-20.10.2.tgz
cp -rf docker/* /usr/bin/
#systemd 管理
cat > /etc/systemd/system/docker.service << EOF
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
[Service]
Type=notify
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -s HUP $MAINPID
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
TimeoutStartSec=0
Delegate=yes
KillMode=process
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target
EOF
#启动服务
systemctl daemon-reload
systemctl start docker
systemctl enable docker
官方容器使用简单例子:
- 持久目录
/nexus-data
用于配置、日志和存储。此目录需要可由 Nexus 进程写入,该进程以 UID 200 运行。
#因为官方容器运行用户有所指定,挂载目录必须授权
mkdir /some/dir/nexus-data && chown -R 200 /some/dir/nexus-data
docker run -d -p 8081:8081 --name nexus -v /some/dir/nexus-data:/nexus-data sonatype/nexus3
登录默认管理员admin,密码在 /some/dir/nexus-data/admin.password
2. 使用docker-compose部署
2.1 安装docker-compose
compose官方文档:https://docs.docker.com/compose/install/#install-compose
#安装docker-compose
curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
2.2 创建相关目录
- 持久目录
/nexus-data
用于配置、日志和存储。此目录需要可由 Nexus 进程写入,该进程以 UID 200 运行。
#因为官方容器运行用户有所指定,挂载目录必须授权
mkdir -p /home/docker/data/{
nginx,nexus-data}
mkdir -p /home/docker/data/nginx/{
ssl,conf}
chown -R 200 /home/docker/data/nexus-data