技术博客 技术博客
  • JAVA
  • 仓颉
  • 设计模式
  • 人工智能
  • Spring
  • Mybatis
  • Maven
  • Git
  • Kafka
  • RabbitMQ
  • RocketMQ
  • Redis
  • Zookeeper
  • Nginx
  • 数据库套件
  • MySQL
  • Elasticsearch
  • MongoDB
  • Hadoop
  • ClickHouse
  • Hbase
  • Hive
  • Flink
  • Flume
  • SQLite
  • linux
  • Docker
  • Jenkins
  • Kubernetes
  • 工具
  • 前端
  • AI
GitHub (opens new window)
  • JAVA
  • 仓颉
  • 设计模式
  • 人工智能
  • Spring
  • Mybatis
  • Maven
  • Git
  • Kafka
  • RabbitMQ
  • RocketMQ
  • Redis
  • Zookeeper
  • Nginx
  • 数据库套件
  • MySQL
  • Elasticsearch
  • MongoDB
  • Hadoop
  • ClickHouse
  • Hbase
  • Hive
  • Flink
  • Flume
  • SQLite
  • linux
  • Docker
  • Jenkins
  • Kubernetes
  • 工具
  • 前端
  • AI
GitHub (opens new window)
  • Docker

    • Docker 概念、命令及Dockerfile介绍
    • Docker-Compose 命令及基本使用
    • Docker私有库的开发
  • Jenkins

    • Jenkins(一) 持续集成及Jenkins介绍
    • Jenkins(二) Jenkins安装和环境配置
    • Jenkins(三) Jenkins用户管理及凭证
    • Jenkins(四) Maven安装和配置
    • Jenkins(五) Jenkins构建Maven项目
    • Jenkins(六) Jenkins项目构建细节
    • Jenkins(七) Jenkins+Docker+SpringCloud微服务持续集成(上)
    • Jenkins(八) Jenkins+Docker+SpringCloud微服务持续集成(下)
      • 优化Jenkins工程中可以选择多个微服务
      • 优化Jenkins工程中可以选择多台生产服务器
      • 脚本编写
  • Kubernetes

    • kubernetes(一) 概念及介绍
    • kubernetes(二) 集群环境搭建
    • kubernetes(三) 资源管理
    • kubernetes(四) Namespace、Pod、Lable、Deployment、Service 的资源介绍
    • kubernetes(五) Pod 介绍及配置
    • kubernetes(六) Pod 生命周期
    • kubernetes(七) Pod 调度
    • kubernetes(八) Pod 控制器详解
    • kubernetes(九) Service介绍、类型及使用
    • kubernetes(十) Ingress介绍及使用
    • kubernetes(十一) 数据存储(挂载卷管理)
    • kubernetes(十二) 安全认证
    • kubernetes(十三) DashBoard
  • linux

    • linux 创建用户及权限操作
    • Linux 磁盘操作相关命令
    • Linux 文本数据处理工具awk命令
    • Linux 定时任务
    • Linux 命令总结
    • Linux 22端口对外攻击解决
目录

Jenkins(八) Jenkins+Docker+SpringCloud微服务持续集成(下)

第七章中部署方案存在的问题:

  1. 一次只能选择一个微服务部署
  2. 只有一台生产者部署服务器
  3. 每个微服务只有一个实例,容错率低

优化方案:

  1. 在一个 Jenkins 工程中可以选择多个微服务同时发布
  2. 在一个 Jenkins 工程中可以选择多台生产服务器同时部署
  3. 每个微服务都是以集群高可用形式部署

# 优化 Jenkins 工程中可以选择多个微服务

安装 Extended Choice Parameter 插件,到项目配置中,可以看到选择参数多了一个选项

# 优化 Jenkins 工程中可以选择多台生产服务器

1. 在 Manager Jenkins->Configure System->Publish over SSH-> 在添加服务器

2. 在到项目配置中添加服务器选择,和工程中选择多个微服务是类似的

# 脚本编写

// 版本
def tag = "1.0"
// 镜像仓库的地址
def harbor_url = "192.168.81.102:85"
// 镜像仓库的项目,这里建议项目名称和jenkins的item项目名称、以及harbor的项目名称保持一致,否则用一下脚本会出问题
def harbor_project = "demo"

node {

    // 获取当前选择的项目名称
    def selectDProjectName = "${project_name}".split(",")
    // 获取服务器列表
    def selectDServers = "${publish_server}".split(",")

    // 拉取代码
    stage('pull code') {
        checkout([$class: 'GitSCM', branches: [[name: '*/${branch}']], extensions: [], userRemoteConfigs: [[credentialsId: '80dfe5c5-1684-47b1-a410-6f53ceb3c543', url: 'http://192.168.81.15:3000/biguncle/test.git']]])
    }
    // 编译并推送镜像仓库
    stage('build project') {

        for(int i=0;i<selectDProjectName.length;i++){

            def project = selectDProjectName[i].split("@")[0]
            def port = selectDProjectName[i].split("@")[1]
            // 编译
            sh "mvn -f ${project} clean package dockerfile:build"
            echo "把jar上传镜像仓库"
            def oldImageName = "${project}:latest"
            def newImageName = "${harbor_url}/${harbor_project}/${project}:${tag}"
            // 改名称 做规范
            sh "docker tag ${oldImageName} ${newImageName}"
            // 删除之前的 镜像
            sh "docker rmi ${oldImageName}"
            // 推送到 dockers仓库
            withCredentials([usernamePassword(credentialsId: '8a3d7ab1-4cd6-482c-86c9-a12aa6404d98', passwordVariable: 'harbor_password', usernameVariable: 'harbor_account')]) {
                // 登录
                sh "docker login -u ${harbor_account} -p ${harbor_password} ${harbor_url}"
                // 上传
                sh "docker push ${newImageName}"
                echo "镜像推送成功"
            }
            for(int k=0;k<selectDServers.length;k++){
                // 获取服务器名称
                def currentServerName = selectDServers[k]
                echo "执行远程命令 /home/server/deploy.sh ${harbor_url} ${harbor_project} ${project_name} ${tag} ${port}"
                sshPublisher(publishers: [sshPublisherDesc(configName: "${currentServerName}", transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: "/home/server/deploy.sh ${harbor_url} ${harbor_project} ${project_name} ${tag} ${port}", execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])

            }
        }
    }
}


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
上次更新: 6/11/2025, 4:10:30 PM
Jenkins(七) Jenkins+Docker+SpringCloud微服务持续集成(上)
kubernetes(一) 概念及介绍

← Jenkins(七) Jenkins+Docker+SpringCloud微服务持续集成(上) kubernetes(一) 概念及介绍→

Theme by Vdoing | Copyright © 2023-2025
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式