Jenkins Docker Pipeline Clone Build Deploy mysqldump

ops/2024/11/15 6:42:11/

本文首发在这里

先决条件

  • 装好 Docker 的 Ubuntu
  • 钉钉机器人 Webhook
curl -H 'Content-Type:application/json' -d '{"msgtype":"text","text":{"content":"hello world"}}' 'https://oapi.dingtalk.com/robot/send?access_token=secret'

Jenkins_8">安装 Jenkins

以下命令基本来自官方,列出仅做参考

sudo docker network create jenkins
mkdir -p docker/jenkins/certs docker/jenkins/data
sudo docker run --name jenkins-docker --rm --detach --privileged --network jenkins --network-alias docker --env DOCKER_TLS_CERTDIR=/certs --volume ~/docker/jenkins/certs:/certs/client --volume ~/docker/jenkins/data:/var/jenkins_home --publish 2376:2376 docker:dind --storage-driver overlay2
vi docker/jenkins/Dockerfile # 请从官方文档复制需要粘贴进去的内容
cd docker/jenkins && sudo docker build -t myjenkins-blueocean:2.426.1-1 .
sudo docker run --name jenkins-blueocean --restart=on-failure --detach --network jenkins --env DOCKER_HOST=tcp://docker:2376 --env DOCKER_CERT_PATH=/certs/client --env DOCKER_TLS_VERIFY=1 --publish 8080:8080 --publish 50000:50000 --volume ~/docker/jenkins/data:/var/jenkins_home --volume ~/docker/jenkins/certs:/certs/client:ro myjenkins-blueocean:2.426.1-1
sudo docker exec -it jenkins-blueocean bash
sudo docker logs jenkins-blueocean

安装后设置向导请遵循官方

Jenkins_22">配置 Jenkins

  • 下载插件 SSH Agent、DingTalk
  • 添加凭据 系统管理 -> 凭据管理 -> 全局 -> 添加凭据 -> 范围选择全局
  1. Username with password
  2. SSH Username with private key
ssh-keygen
ssh-copy-id -i ~/.ssh/id_rsa.pub ubuntu@192.168.1.188
cat ~/.ssh/id_rsa # 私钥
  • 添加钉钉机器人 id、名称、webhook

新建流水线

建议勾选丢弃旧的构建

Build_Deploy_37">Clone Build Deploy
pipeline {agent {docker {image 'golang:1.21.4-bookworm'args  '-u 0:0'}}parameters {choice(name: 'IP', choices: ['188'], description: 'pick one')}stages {stage('start') {steps {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins ${IP} start'])}}stage('clone') {steps {withCredentials([usernamePassword(credentialsId: 'git', usernameVariable: 'username', passwordVariable: 'password')]) {sh '''rm -rf frameworkgit clone https://$username:$password@github.com/panshiqu/framework.git'''}}post {failure {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins ${IP} clone failure'])}}}stage('build') {steps {sh '''echo choice: ${IP}cd frameworkpwdgo versiongo env -w GOPROXY=https://goproxy.cn,directgo env -w GOCACHE=/tmp/.cache/go-buildgo env -w GOFLAGS=-buildvcs=falsego mod tidygo build -o db_server db.gogo build -o manager_server manager.gogo build -o proxy_server proxy.gogo build -o login_server login.gogo build -o game_server game.go'''}post {failure {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins ${IP} build failure'])}}}stage('deploy') {steps {sshagent(credentials: ["${IP}"]) {sh '''ssh -o StrictHostKeyChecking=no -l ubuntu 192.168.1.${IP} uname -acd framework && scp *_server ubuntu@192.168.1.${IP}:~/server/update'''}}post {failure {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins ${IP} deploy failure'])}success {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins ${IP} clone && build && deploy success'])}}}}
}
mysqldump_116">mysqldump
pipeline {agent {docker {image 'mysql:5.7.44'}}parameters {string(name: 'fromIP', defaultValue: '192.168.1.177', description: 'ip')string(name: 'fromPWD', defaultValue: '123456', description: 'pwd')string(name: 'toIP', defaultValue: '192.168.1.188', description: 'ip')string(name: 'toPWD', defaultValue: '123456', description: 'pwd')}stages {stage('start') {steps {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins mysqldump ${fromIP}->${toIP} start'])}}stage('dump') {steps {sh '''mysqldump -h${fromIP} -uroot -p${fromPWD} --events --routines --add-drop-database --databases game log > dump.sqlmysql -h${toIP} -uroot -p${toPWD} < dump.sqlrm -f dump.sql'''}post {failure {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins mysqldump ${fromIP}->${toIP} failure'])}success {dingtalk(robot: 'bot', type: 'TEXT', text: ['jenkins mysqldump ${fromIP}->${toIP} success'])}}}}
}

远程构建

  • 流水线配置勾选触发远程构建,身份验证令牌填入abc
  • 全局安全配置勾选匿名用户具有可读权限
curl 'http://192.168.1.188:8080/job/framework/buildWithParameters?IP=188&token=abc'
curl 'http://192.168.1.188:8080/job/mysqlgame/buildWithParameters?fromIP=192.168.1.177&fromPWD=123456&toIP=192.168.1.188&toPWD=123456&token=abc'

http://www.ppmy.cn/ops/112038.html

相关文章

给纯 Node 项目添加 UI 页面笔记

文章目录 前提思路操作验证 前提 之前有一个纯 node 的脚本&#xff0c;用来处理一些逻辑&#xff0c;现在我想写一个页面来展示逻辑&#xff0c;或者说有一个 UI 去控制逻辑想法是&#xff0c;启动 node 之后&#xff0c;把页面的静态页面也引入 思路 把 用 vite 打包好的 …

Python应用指南:获取行政区最小外接矩形

有的时候我们用行政区的面层进行裁剪的时候&#xff0c;特别是在基于行政区裁剪的渔网&#xff0c;因为行政边界本身就是不规则的原因&#xff0c;在边界的渔网匹配数据会出现匹配不上的问题&#xff0c;其实如果周边有数据完全可以采用最近匹配的原则&#xff0c;但是就是因为…

车载软件架构 --- SOA设计与应用(上)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

【重学 MySQL】二十七、七种 join 连接

【重学 MySQL】二十七、七种 join 连接 union 的使用UNION 的基本用法示例UNION ALL 的用法 七种 join 连接代码实现语法格式小结 union 的使用 UNION 在 SQL 中用于合并两个或多个 SELECT 语句的结果集&#xff0c;并默认去除重复的行。如果希望包含重复行&#xff0c;可以使…

基于Python实现一个庆祝国庆节的小程序

功能&#xff1a; 添加互动功能&#xff1a;允许用户选择不同的祝福语或者查询不同的国庆节信息。动态背景音乐&#xff1a;播放国庆节相关的背景音乐。增加节日小测验&#xff1a;提供一些关于国庆节的趣味小测验&#xff0c;让用户参与。增强图形用户界面 (GUI)&#xff1a;…

2024世界技能大赛某省选拔赛“网络安全项目”B模块--数字取证解析②(超详细~)

2024世界技能大赛某省选拔赛“网络安全项目”B模块--数字取证解析 PS: 关注鱼影安全第一部分 网络安全事件响应第二部分 数字取证调查任务 3: 网络数据包分析取证解析:第三部分 应用程序安全:需要环境可以私信博主~PS: 关注鱼影安全 模块 B 竞赛项目试题 本文件为:2024世界…

android 发一个可以下载的的android studio历史版本

1、Android Studio 下载文件归档 | Android Developers 2、上个图&#xff1a;

Linux基础---10进程管理

一.查看和关闭进程 1.查看进程 基础指令: ps -efPID 进程编号&#xff0c;PPID 父进程编号&#xff0c; CMD命令名称 进阶指令–查看进程的树形结构&#xff1a; yum install psmisc -y #首先安装psmisc后可直接使用pstreepstree2.关闭进程 要想关闭某个或多个进程需要知道…