02-Jenkins配置编译项目
Jenkins配置编译任务项目的大致流程:从gitlab上拉取程序运行 maven/Node 编译打包运行Dockerfile打包成镜像上传镜像到cce云上镜像仓库使用kubectl更新cce云上的负载镜像需要打包编译的内容:后台项目的app-web模块后台项目的system-server模块前端VUE项目后台编译以admin登录Jenkins,选择新建任务。任务名称:任意起,例如dev_myproject_java选择构建一个自由风格的软件项目(也可以选择复制,填写需要复制的任务的任务名称)General组:限制项目的运行节点:填写节点服务器的标签表达式,限制只在该服务器上运行任务。myproject_dev点击高级使用自定义的工作空间:填写源程序下载到的服务器路径。/root/build/source/myproject/myproject-vue显示名称:可以配置一个中文名,用于在列表页面展示。dev-后台-app源码管理组:选择GitRepository URL:代码路径。填写git@xxxxxx那个。http:xxxxx的没有设置会报错。从gitlab复制下来的路径需要进行调整,前面加上ssh://前缀,ip后面加上gitlab的22端口映射出来的端口号8022。例如:从gitlab复制出来的路径为git@192.168.xxx.xxx:myproject/myproject-vue.git,调整后为ssh://git@192.168.xxx.xxx:8022/myproject/myproject-vue.gitCredentials:选择前面创建的Jenkins用户私钥的那个凭据Branches to build:指定要拉取的分支。例如本项目的*/dev_20240712源码库浏览器:用于在jenkins上直接看本地构建时的代码差异。源码库浏览器:gitlabURL:gitlab的本项目页面:http://192.168.xxx.xxx:8090/myproject/myproject-vue/version:gitlab版本:17.0构建触发器组:可以配置每次有代码push到gitlab时自动构建。为避免频繁构建,项目采用手动点击构建,不配置触发器。构建环境组:用于给节点服务器准备构建环境,使用Ant构建时可以配置。项目使用Maven、Node构建,且已经在节点服务器上手工部署了Maven、Node,无需进行配置。Build Steps组:配置从gitlab拉取代码之后操作,即具体的构建执行步骤。项目全部使用shell方式执行。登录CCE云:
执行Maven编译打包执行Dockerfile制作镜像、推送CCE镜像仓库、更新cce上的负载镜像
curDate=`date +%Y%m%d`
curTime=`date +%H%M%S`
export VERSION_ALL_TAG=${curDate}-${curTime}
# build app-web image; push to cce; delete local image
cd /root/build/source/myproject/myproject-vue/app-web
docker build -t cce.test.com/myproject/app-web:${VERSION_ALL_TAG} .
docker push cce.test.com/myproject/app-web:${VERSION_ALL_TAG}
docker rmi cce.test.com/myproject/app-web:${VERSION_ALL_TAG}
# build system-server image; push to cce; delete local image
cd /root/build/source/myproject/myproject-vue/system/system-server
docker build -t cce.test.jinanbank.com/myproject/system-server:${VERSION_ALL_TAG} .
docker push cce.test.jinanbank.com/myproject/system-server:${VERSION_ALL_TAG}
docker rmi cce.test.jinanbank.com/myproject/system-server:${VERSION_ALL_TAG}
# update cce deployment
export KUBECONFIG=/root/.kube/config
kubectl set image deployment/myproject container-app=cce.test.com/myproject/app-web:${VERSION_ALL_TAG} container-system=cce.test.com/myproject/system-server:${VERSION_ALL_TAG} -n myproject
登出CCE
/root/cce logout
前端VUE编译与app-web模块的操作步骤类似,只是将Maven编译换成Node编译:
cd /root/build/source/myproject/vue-web
export NODE_HOME=/root/build/node-v12.22.12
export PATH=$NODE_HOME/bin:$PATH
npm run build:clouddev
Jenkins打包docker镜像86服务器上安装的Docker版本比较高,save出来的docker镜像tar文件无法直接在页面导入进CCE中。164服务器上的Docker版本低,导出的镜像可以在页面导入CCE中,但是无法使用CCE客户端。所以项目源码拉取、编译打包、生成镜像、kubectl更新等操作在86服务器上进行。如果需要导出docker镜像,则在164服务器上进行。