Jenkins运维之路(Jenkins使用Mysql作为信息存储)

在日常工作中我们会将一些环境变量的信息放在pipeline中执行定义,每次修改都要到jenkinsfile文件中进行修改或者操作,这两天看到jenkins可以直接操作数据库,忽然想到是否有一种可能将一些变量信息存入到数据库当中,在构建过程中通过从数据库中获取变量信息,这样会对运维更加的友好,目前我这只是一个测试(为每个项目创建了一张表),如果拿到生产环境中最好是创建一个表然后通过一些关键字作为搜索ID或匹配条件来从表中索取信息。

1、安装配置数据库插件

插件名称: Database , MySQL Database

null

image-20250928142535251

创建库的命令

CREATE DATABASE jenkins CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

2、创建测试表并插入测试数据

sql 复制代码
# 创建表
CREATE TABLE `HelloWorld-SqlPipeline` (
  `git_repo_url` varchar(255) DEFAULT NULL,
  `registry_url` varchar(255) DEFAULT NULL,
  `harbor_url` varchar(255) DEFAULT NULL,
  `project_group` varchar(255) DEFAULT NULL,
  `project_name` varchar(255) DEFAULT NULL,
  `container_name` varchar(255) DEFAULT NULL,
  `ops_share_library` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

# 插入数据(数据大家自己定义)
INSERT INTO `HelloWorld-SqlPipeline` (`git_repo_url`, `registry_url`, `harbor_url`, `project_group`, `project_name`, `container_name`, `ops_share_library`) 
VALUES 
('git@gitee.com:xxxx/spring-boot-3-hello-world-jdk21.git', 'harbor.xxx.xxx', 'https://harbor.xxx.xxx', 'devops', 'hello-world-jdk21', 'hello-world-jdk21', 'git@gitee.com:xxxx/ops-share-librarya.git');

3. 共享库中创建mysql方法

typescript 复制代码
package org.devops

def get_mysql_msg_map(String dbName, String tableName) {
    def resultMap = [:] // 创建一个空的 Map 用于存储结果

    getDatabaseConnection(type: 'GLOBAL') {
        def result = sql(sql: "SELECT * FROM `${dbName}`.`${tableName}`;")
        
        if (result) {
            println "查询结果: ${result}" // 调试输出
            result.each { row ->
                row.each { key, value ->
                    resultMap[key] = value // 将字段名作为键,字段值作为值
                }
            }
        } else {
            println "查询没有返回任何结果"
        }
    }
    
    return resultMap // 返回结果 Map
}
null

image-20250928143305092

4.在Jenkins中引入mysql方法并测试是否能够获取数据

这里我是每个流水线创建了一个表,这样其实不太合理,但是因为测试所以就无所谓了

typescript 复制代码
#!groovy

@Library('ops-share-librarya@master') _

def nexus = new org.devops.nexus()
def sonarq = new org.devops.sonarq()
def dingtalk = new org.devops.dingtalk()

//new一个对象
def mysql = new org.devops.mysql()
//调用对象中的方法并传入参数(数据库名,表名)来获取一个map
def job_msg_map = mysql.get_mysql_msg_map('jenkins','HelloWorld-SqlPipeline')
//定义个全局变量,并使用map中键对应的值
env.GIT_REPO_URL_MAP = job_msg_map.git_repo_url


pipeline {
    agent { node { label "node47"}}
    tools {
        //...省略
    } 
    environment {
        //...省略
    }
    options {
        //...省略
    }
    parameters {
        //...省略
    }
    stages {
        stage('获取数据') {
            steps {
                script {
                    // 测试调用结果
                    println "GIT_REPO_URL_MAP: ${GIT_REPO_URL_MAP}"
                }
            }
        }    
        stage('Example') {
            //...省略
        }
        stage('Check requirement') {
            //...省略
        }
        stage('CleanWorkDir') {
            //...省略
        }
        stage('Checkout') {
            //...省略
        }
        stage('Build') {
            //...省略
        }
        stage('Upload to Nexus') {
            //...省略
        }
        stage("SonarQube Analysis") {
            //...省略
        }
        stage("Quality Gate") {
            //...省略
        }
        stage('Wait for SonarQube Analysis') {
            //...省略
        }
    }
    post {
        //...省略
    }
}
null

image-20250928144137178

很多的项目变量信息其实都可以存储到数据库当中,这样很方便我们运维统一管理。

相关推荐
淡忘_cx9 小时前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins
晚风_END9 小时前
Linux|操作系统|elasticdump的二进制方式部署
运维·服务器·开发语言·数据库·jenkins·数据库开发·数据库架构
淡忘_cx9 小时前
使用Jenkins自动化部署spring-java项目+宝塔重启项目命令(2.528.2版本)
java·自动化·jenkins
闲人编程1 天前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
池央2 天前
CANN oam-tools 诊断体系深度解析:自动化信息采集、AI Core 异常解析与 CI/CD 流水线集成策略
人工智能·ci/cd·自动化
池央2 天前
CANN GE 深度解析:图编译器的核心优化策略、执行流调度与模型下沉技术原理
人工智能·ci/cd·自动化
3GPP仿真实验室2 天前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
小Tomkk2 天前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
人间打气筒(Ada)2 天前
jenkins基于Pipeline发布项目
java·pipeline·jenkins·流水线·ci·cd·cicd
_运维那些事儿3 天前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算