通过Jenkins + Docker实现antdPro自动化推送私服、自动容器化部署功能
Docker与Docker私服
1. 安装docker
https://docs.docker.com/install/
2. 配置docker镜像加速
https://www.daocloud.io/mirror
3. 安装启动docker私服
https://docs.docker.com/registry/deploying/
# 启动docker私服
docker run -d -p 5000:5000 --restart=always --name registry registry:2
4. docker配置私服地址,并且加入http访问私服名单
# 方案1
vim /etc/docker/daemon.json
# 添加配置`"insecure-registries":["172.18.123.72:5000"],`到json对象中
systemctl reload-daemon
systemctl restart docker
# 方案2
# 修改docker启动命令,注入配置参数
vim /usr/lib/systemd/system/docker.service
# ExecStart=/usr/bin/dockerd后添加配置:” --insecure-registry 172.16.48.129:5000“
systemctl reload-daemon
systemctl restart docker
5. docker施一公ubuntu镜像验证私服功能
拉取镜像发送到私服,使用ubuntu:16.04
镜像,并且重新打tagmy-ubuntu
, 然后推送到私人仓库. 最后镜像
ubuntu:16.04
和my-ubuntu
镜像从本地删除my-ubuntu
镜像从私服中拉取。
$ docker pull ubuntu:16.04
$ docker tag ubuntu:16.04 localhost:5000/my-ubuntu
$ docker push localhost:5000/my-ubuntu
$ docker image remove ubuntu:16.04
$ docker image remove localhost:5000/my-ubuntu
$ docker pull localhost:5000/my-ubuntu
6. docker私服api操作参考文档
https://docs.docker.com/registry/spec/api/#detail
配置自动化集成环境
1. 安装jenkins
# 先安装java环境:参考百度
# 获取官方jar包
wget http://ftp-nyc.osuosl.org/pub/jenkins/war-stable/2.164.2/jenkins.war
# 使用命令行直接启动,配置文件生成在home目录中的.jenkins目录中
java -jar jenkins.war --httpPort=8080 &
# 日志中含有启动验证秘钥,或者在文件中
cat /var/jenkins_home/secrets/initialAdminPassword
# 默认配置安装,设定管理员账号,进入jenkins
2. fork antd-design-pro项目到自己的github仓库
git clone https://github.com/fly-piglet/ant-design-pro.git
3. 添加编译脚本
docker-publish.sh
记得赋予可执行权限
# 设定私服地址
registryhosts="localhost:5000"
# 设定项目名称
imageName="project"
# 设定容器启动名称
containerName="project"
# 设定tag,默认使用latest、实际按照生产版本进行使用
tag="latest"
# 拼接镜像的名字
allImageNmae="${registryhosts}/${imageName}:${tag}"
echo "1. 安装依赖 + 编译项目"
npm install && npm run build
echo "2. 编译镜像 + 标签镜像"
docker build -f Dockerfile.hub -t ${allImageNmae} ./
echo "3. 推送镜像"
docker push ${allImageNmae}
4. 添加启动脚本
docker-start.sh
启动镜像脚本,可以在部署目标机器执行
# 设定私服地址
registryhosts="localhost:5000"
# 设定项目名称
imageName="project"
# 设定容器启动名称
containerName="project"
# 设定tag,默认使用latest、实际按照生产版本进行使用
tag="latest"
# 拼接镜像的名字
allImageNmae="${registryhosts}/${imageName}:${tag}"
# 启动的端口地址
port="8060"
echo "1. 停止容器 + 删除容器 + 删除镜像"
docker stop ${containerName} && docker rm ${containerName} && docker rmi ${allImageNmae}
echo "2. 拉取镜像"
docker pull ${allImageNmae}
echo "3. 启动镜像"
docker run -d -p ${port}:80 --name=${containerName} --restart=always ${allImageNmae}
echo "4. 部署完毕: http://localhost:${port}/"
最佳实践
Ci流程
:通过git的webhook + jenkins自动化编译 + 自动化ssh远端机器 + 自动化部署。
环境区分
:默认的配置文件为开发环境的配置,生产环境通过-v
外挂配置文件实现环境切换
使用配置文件进行区分,方便保证镜像经过开发环境的测试,只是配置不同,保证一致性。
版本区分
:tag:无或者默认为latest,需要管理版本按照1.0.0的顺序递增修改版本号即可
前端docker镜像,暂时没哟版本管理的需求,使用最新版,需要则启用。
后续优化
使用Jenkinsfile以及管道的形式配置,内置docker容器进行打包编译
引入docker-compose.yml配置环境启动,通过配置文件进行环境配置
npm中引入命令体系,直接进行打包和发布
后端引入docker部署
- 配置中心:默认一套jar包配置实现一个项目不同环境固定部署,基于这个条件在通过-e、或者-v修改配置文件实现配置修改,项目暂时不引入配置中心
- 日志中心:引入elk服务,后续入口集成redis或者kafka进行缓存
- 工程化流程:
- 使用maven插件进行镜像的打包和推送,通过命令进行服务的启动
- 优化内部jar包名称,在dockerfile进行处理的时候,统一化外部端口映射,保证启动脚本的统一抽象。
遇到的问题
- jenkins使用docker部署的使用,出现既需要node环境,🈶需要docker环境的情况,使用容器部署无法解决
- jenkins改用war包部署,含有node和docker环境,但是使用容器中进行publish的时候,无法推送到本地端口,容器网络的问题
参考命令
查看镜像
curl http:/localhost:5000/v2/_catalog
查看镜像版本
curl http:/localhost:5000/v2/project/tags/list
清理镜像
删除所有镜像,-f "dangling=true"过滤没有打标签的:默认是有打标签,-q:只显示ids编号
docker rmi $(docker images -f "dangling=true" -q)
停止容器 删除容器
docker stop <contrinerId> && docker rm <contrinerId>
推送和拉取每次都会更新最新的镜像,只要私服有更新本地就会更新