Jenkins自动化部署之后端

准备工作参考本人另外几篇Jenkins相关的文章

  1. 新建任务

  2. 添加参数配置

    字符串参数:分支名称

    多选框:项目名称(Extended Choice Parameter插件必备,插件安装参考我另外的文章)


这个分割规则自定义。只要根据Jenkinsfile脚本处理规则能够对上就可以,此处本人图片是老的,懒得重新替换新的

下面的项目配置才是最新的

bash 复制代码
travel-system@8201@travel-modules/,travel-auth@8200,travel-gateway@7070,travel-backend@8204@travel-modules/,travel-ticket@8205@travel-modules/

以@分割:

0位标识项目名称

1位标识端口

2位若存在则标识上级目录

如果项目存在依赖情况B依赖A,需要先部署A才能部署B,则可以通过调整此处项目顺序

此处如果项目名称没有转换为中文,检查Choose Source for Value Description 中描述直接的分割符号是否与前面的相同,假如前面是英文逗号,后面是中文逗号此处也是会有问题

  1. 配置代码拉去

    应用,报存

  2. 配置远程部署服务器

  • 拷贝公钥到远程服务器
bash 复制代码
ssh-copy-id 远程服务器IP
  • 系统配置->添加远程服务器
  1. 参数添加

    多选框:部署服务器

  2. Harbor的登录凭证ID获取

    添加凭证

    点击确定之后会生成ID,这个ID将作为Jenkinsfile脚本中的 harbor_auth 参数

Jenkinsfile脚本

groovy 复制代码
//git凭证ID
def git_auth = "896fd2e4-623a-41a3-96ac-e664d92d3f94"
//git的url地址
def git_url = "git@127.0.0.1:xxx/xxxx.git"

//镜像的版本号
def tag = "latest"
//Harbor的url地址
def harbor_url = "127.0.0.1"
//镜像库项目名称
def harbor_project = "travel"

//Harbor的登录凭证ID
def harbor_auth = "31da7f5d-5f34-4267-989e-9edef7844b01"

node {

    //获取当前选择的项目名称 :项目名称@端口,项目名称@端口,项目名称@端口@父级目录,
   def selectedProjectNames = "${project_name}".split(",")

   //获取当前选择的服务器名称
   def selectedServers = "${publish_server}".split(",")


   stage("拉取代码") {
      checkout([$class: 'GitSCM', branches: [[name: "*/${branch}"]], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: "${git_auth}", url: "${git_url}"]]])
   }

   stage('编译,安装公共子工程') {
      sh "mvn -f travel-common clean install"
      sh "mvn -f travel-api clean install"
   }

   stage('编译,打包微服务工程') {

        for(int i=0;i<selectedProjectNames.length;i++){
                 //tensquare_eureka_server@10086
                 def projectInfo = selectedProjectNames[i];


                 //当前遍历的项目名称
                 def currentProjectName = "${projectInfo}".split("@")[0]
                 //当前遍历的项目端口
                 def currentProjectPort = "${projectInfo}".split("@")[1]

                 //多级目录下的项目上级目录,格式:项目名@端口@上级项目名
                 //非多级目录格式:项目名@端口
                 def packPathArray = "${projectInfo}".split("@")

                 if(packPathArray.size() == 3){
                    def packPath = packPathArray[2]
                    sh "mvn -pl ${packPath}${currentProjectName} clean package dockerfile:build"
                  }else{
                    sh "mvn -f ${currentProjectName} clean package dockerfile:build"
                  }


                 //定义镜像名称
                 def imageName = "${currentProjectName}:${tag}"

                 //对镜像打上标签
                 sh "docker tag ${imageName} ${harbor_url}/${harbor_project}/${imageName}"

                //把镜像推送到Harbor
                withCredentials([usernamePassword(credentialsId: "${harbor_auth}", passwordVariable: 'password', usernameVariable: 'username')]) {

                    //登录到Harbor
                    sh "docker login -u ${username} -p ${password} ${harbor_url}"

                    //镜像上传
                    sh "docker push ${harbor_url}/${harbor_project}/${imageName}"

                    sh "echo 镜像上传成功"
                }
                //删除本地镜像
                sh "docker rmi -f ${imageName}"
                sh "docker rmi -f ${harbor_url}/${harbor_project}/${imageName}"

                //遍历所有服务器,分别部署
                for(int j=0;j<selectedServers.length;j++){
                       //获取当前遍历的服务器名称
                      def currentServerName = selectedServers[j]

                       //加上的参数格式:--spring.profiles.active=
                      def activeProfile = "--spring.profiles.active=dev"

                       //根据不同的服务名称来读取不同的配置信息
                       //if(currentServerName=="master_server"){
                       //   activeProfile = activeProfile+"eureka-server1"
                      // }else if(currentServerName=="slave_server"){
                       //   activeProfile = activeProfile+"eureka-server2"
                      // }

                       //部署应用
                     sshPublisher(publishers: [sshPublisherDesc(configName: "${currentServerName}", transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: "/opt/jenkins_shell/deployCluster.sh $harbor_url $harbor_project $currentProjectName $tag $currentProjectPort $activeProfile", execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])

                     echo "${currentProjectName}完成编译,构建镜像"

                }

        }
   }
}

deployCluster.sh 脚本:

bash 复制代码
# ! /bin/sh
#接收外部参数
harbor_url=$1
harbor_project_name=$2
project_name=$3
tag=$4
port=$5
profile=$6

imageName=$harbor_url/$harbor_project_name/$project_name:$tag

echo "$imageName"

#查询容器是否存在,存在则删除
#containerId=`docker ps -a | grep -w ${project_name}:${tag}  | awk '{print $1}'`
containerId=`docker ps -aqf "name=${project_name}"`
echo "容器ID=${containerId}"



if [ "$containerId" !=  "" ] ; then
    
    #停掉容器
    docker stop $containerId

    #删除容器
    docker rm $containerId
	
echo "成功删除容器"
fi

#查询镜像是否存在,存在则删除
imageId=`docker images | grep -w $project_name  | awk '{print $3}'`
echo "镜像ID=${imageId}"


if [ "$imageId" !=  "" ] ; then
      
    #删除镜像
    docker rmi -f $imageId
	
echo "成功删除镜像"
fi


# 登录Harbor
docker login -u admin -p Dx@123456  $harbor_url
echo "Harbor登录成功"

# 下载镜像
docker pull $imageName

# 启动容器
#docker run -di -p $port:$port $imageName $profile
docker run -di --network host  --name $project_name -v /var/log/travelLogs/$project_name:/logs/$project_name  $imageName

echo "容器启动成功"

问题处理:

问题原因是文本格式问题,windows和Linux文本格式不一致

解放方案:

  • 使用vim编辑器,可以执行以下命令来进行转换:
bash 复制代码
:set ff=unix
:wq
  • 批量处理
bash 复制代码
sed -i 's/[[:cntrl:]]//g' xxx.txt
相关推荐
2401_8576226624 分钟前
SpringBoot框架下校园资料库的构建与优化
spring boot·后端·php
2402_8575893628 分钟前
“衣依”服装销售平台:Spring Boot框架的设计与实现
java·spring boot·后端
哎呦没2 小时前
大学生就业招聘:Spring Boot系统的架构分析
java·spring boot·后端
_.Switch2 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
杨哥带你写代码3 小时前
足球青训俱乐部管理:Spring Boot技术驱动
java·spring boot·后端
Pythonliu74 小时前
茴香豆 + Qwen-7B-Chat-Int8
linux·运维·服务器
你疯了抱抱我4 小时前
【RockyLinux 9.4】安装 NVIDIA 驱动,改变分辨率,避坑版本。(CentOS 系列也能用)
linux·运维·centos
AskHarries4 小时前
读《show your work》的一点感悟
后端
A尘埃4 小时前
SpringBoot的数据访问
java·spring boot·后端
yang-23074 小时前
端口冲突的解决方案以及SpringBoot自动检测可用端口demo
java·spring boot·后端