Jenkins + Kubernetes + Docker 完成微服务持续集成
Jenkins + Kubernetes + Docker 完成微服务持续集成
一:完成编译,制作镜像,上传镜像
创建NFS共享目录
复制#配置nfs
echo '/opt/nfs/maven *(rw,no_root_squash)' >> /etc/exports
systemctl restart nfs
showmount -e 192.168.23.15
#创建共享目录
mkdir -p /opt/nfs/maven
#设置共享目录权限(否则Jenkins没有权限操作)
chmod 777 /opt/nfs/maven/
配置Harbor凭证,并获取凭证id
点击凭证-->更新--->复制id
新建pipeline项目
选择参数化构建过程---->Extend Choice Parameter
编写pipeline
复制def git_address = "http://192.168.23.10:82/my_group/tensquare_back.git"
def git_auth = "9972329a-8a9c-4504-83bd-1ed89556f824"
//构建版本的名称
def tag = "latest"
//Harbor私服地址
def harbor_url = "192.168.23.13:85"
//Harbor的项目名称
def harbor_project_name = "tensquare"
//Harbor的凭证
def harbor_auth = "20b7dd57-b611-48c2-834f-191998020bff"
podTemplate(label: 'jenkins-slave', cloud: 'kubernetes', containers: [
containerTemplate(
name: 'jnlp',
image: "192.168.23.13:85/library/jenkins-slave-maven:latest"
),
containerTemplate(
name: 'docker',
image: "docker:stable",
ttyEnabled: true,
command: 'cat'
),
],
volumes: [
hostPathVolume(mountPath: '/var/run/docker.sock', hostPath: '/var/run/docker.sock'),
nfsVolume(mountPath: '/usr/local/apache-maven/repo', serverAddress: '192.168.23.15' , serverPath: '/opt/nfs/maven'),
],
)
{
node("jenkins-slave"){
// 第一步
stage('pull code'){
checkout([$class: 'GitSCM', branches: [[name: '*/master']], extensions: [], userRemoteConfigs: [[credentialsId: "${git_auth}", url: "${git_address}"]]])
}
// 第二步
stage('make public sub project'){
//编译并安装公共工程
sh "mvn -f tensquare_common clean install"
}
// 第三步
stage('make image'){
//把选择的项目信息转为数组
def selectedProjects = "${project_name}".split(',')
for(int i=0;i<selectedProjects.size();i++){
//取出每个项目的名称和端口
def currentProject = selectedProjects[i];
//项目名称
def currentProjectName = currentProject.split('@')[0]
//项目启动端口
def currentProjectPort = currentProject.split('@')[1]
//定义镜像名称
def imageName = "${currentProjectName}:${tag}"
//编译,构建本地镜像
sh "mvn -f ${currentProjectName} clean package dockerfile:build"
container('docker') {
//给镜像打标签
sh "docker tag ${imageName} ${harbor_url}/${harbor_project_name}/${imageName}"
//登录Harbor,并上传镜像
withCredentials([usernamePassword(credentialsId: "${harbor_auth}", passwordVariable: 'password', usernameVariable: 'username')])
{
//登录
sh "docker login -u ${username} -p ${password} ${harbor_url}"
//上传镜像
sh "docker push ${harbor_url}/${harbor_project_name}/${imageName}"
}
//删除本地镜像
sh "docker rmi -f ${imageName}"
sh "docker rmi -f ${harbor_url}/${harbor_project_name}/${imageName}"
}
}
}
}
}
配置node 节点的docker.sock文件权限
复制chmod 777 /var/run/docker.sock
构建
在构建过程中,在master 上 使用 kubectl get pods -n kube-ops
构建完成
项目构建结束后,jenkins-slave 的pod 被删除
查看mster节点的/opt/nfs/maven 目录下载的maven组件都在这里,后续的构建就不用再次下载
分类:
Jenkins+k8s 持续集成
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)