Spring Cloud 运维篇1——Jenkins CI/CD 持续集成部署

news2024/9/21 4:39:27

Jenkins

1、Jenkins是什么?

Jenkins 是一款开源 CI/CD 软件,用于自动化各种任务,包括构建、测试和部署软件。

Jenkins 支持各种运行方式,可通过系统包、Docker 或者一个独立的 Java 程序。

Jenkins + Docker Compose持续集成流程:
在这里插入图片描述
官方文档:https://www.jenkins.io/zh/doc/

学习教程【尚硅谷】: https://www.bilibili.com/video/BV1bS4y1471A?p=1&vd_source=523286d09af90fc35a40df46c3742b63

2、JenKins 安装

2.1 安装需求

机器要求:

  • 256 MB 内存,建议至少有 2GB 空闲内存,否则使用过程可能会卡死(亲测)
  • 10 GB 的硬盘空间(用于 JenKins 和 Docker 镜像)

需要安装以下软件:

  • JDK(仅安装 JRE 是不行的)
  • Maven
  • Docker
  • Git

2.2 Java JDK安装

Oracle JDK 官方下载:http://www.oracle.com/technetwork/java/javase/downloads/index.html

在这里插入图片描述

上传到服务器,解压:

tar -zxvf jdk-17_linux-x64_bin.tar.gz

在这里插入图片描述

# 配置环境变量
vim /etc/profile

# 在文本结尾加上下面内容
# set oracle jdk environment
export JAVA_HOME=/usr/soft/java/jdk-17.0.10  ## 这里要注意目录要换成自己解压的jdk 目录
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

# 更新环境配置
source /etc/profile

# 查看 Java 版本
java -version

2.3 Maven 安装

下载 maven 包:https://maven.apache.org/download.cgi

# 配置环境变量
vim /etc/profile

# 在文本结尾加上下面内容
# set maven
export MAVEN_HOME=/usr/soft/maven/apache-maven-3.9.6
export CLASSPATH=${MAVEN_HOME}/lib:$CLASSPATH
export PATH=${MAVEN_HOME}/bin:$PATH

# 更新环境配置
source /etc/profile

# 查看 Maven 版本
mvn -v

找到 xx/maven/apache-maven-3.9.6/conf/settings.xml :

# 编辑 settings.xml 文件
vim settings.xml

# 更换镜像
<mirror>
    <id>aliyunmaven</id>
    <mirrorOf>*</mirrorOf>
    <name>阿里云公共仓库</name>
    <url>https://maven.aliyun.com/repository/public</url>
</mirror>

2.3 JenKins 安装配置

安装包下载地址:https://www.jenkins.io/zh/download/

在这里插入图片描述

jenkins.war 上传到服务器,并使用 java 命令启动(默认在 8080 端口启动):

nohup java -jar jenkins.war --httpPort=8180 &

访问 ip:8180 进入 JenKins 控制台,将控制台的初始化密码填进去:

在这里插入图片描述

等待插件安装(插件安装失败可能的原因是推荐插件的版本需要更高版本的 jenkins 才能安装,我这里用的是当前最新的版本因此没有遇到插件安装失败的情况,前面用老版本测试是会安装失败的。所以要么换高版本的 jenkins,要么忽略这部分安装失败的插件,等 jenkins 安装完成后去里面的插件商店下载低版本的插件):


创建管理员用户:

安装完成:
在这里插入图片描述

2.4 Maven Plugin 安装

进入 插件 管理页面:

在这里插入图片描述

检查是否安装了 Maven Plugin 插件,如果没有需要在 Available plugin 进行安装:

在这里插入图片描述

3、Git

想要获取远程仓库的信息或者代码,需要配置 Git 的相关凭证,确保 Jenkins 所在服务器能够连接上 Github/Gitee 并拉取项目源码:

3.1 Git 安装

下面安装过程以 Ubuntu 服务器为例。

# Git 安装
sudo apt-get install git
# 更新操作
sudo apt-get update
# 安装完成后,执行
git
# 有信息输出,表示安装完成
3.2 Git 配置
# Git 用户名
git config --global user.name 'yangzhenyu322'
# Git 邮箱
git config --global user.email '2807975464@qq.com'
# 生成 ssh 密钥
ssh-keygen -t rsa -C '2807975464@qq.com'

在这里插入图片描述

# 密钥会生成在 ~/.ssh 目录下
cd ~/.ssh
# 查看生成的密钥(id_rsa 是密钥,用于远程连接 Github/Gitee 仓库;id_rsa.pub 是公钥,需要上传到 Github/Gitee 设置中)
ls
# 查看公钥
cat id_rsa.pub

将公钥上传到 Github/Gitee 设置中:

在这里插入图片描述

测试 ssh 连接:

ssh -T -v git@github.com

连接成功结果:

在这里插入图片描述

3.3 JenKins Git 凭证添加

在这里插入图片描述
在这里插入图片描述

4、构建 Maven 项目

如果你的项目是 Spring Boot 或者 Spring Cloud 项目,那么构建一个 maven 项目可以极大的简化你的 CI/CD 过程。这里我以自己的 Spring Cloud 项目作为演示。

配置Git仓库信息(ps: URL 尽量别用 https,否则可能会出现连接超时的问题,用 git@XXX/XX.git 无需翻墙也能正常拉取项目代码):

在这里插入图片描述

配置 maven:

然后填写 maven 名称,并取消勾选 Install automatically,在填写 maven 安装目录:

在这里插入图片描述

配置根目录的 pom 文件:

在这里插入图片描述

回到主页面,执行一次项目构建:

在这里插入图片描述

在这里插入图片描述

项目的第一次构建会比较慢,它需要时间去拉取依赖,后面再次构建会比较快,构建成功结果如下:

在这里插入图片描述

当然,可以会出现构建失败的情况,这时候你需要根据控制台的报错信息在网上搜索解决办法。

5、打包后执行操作

前面我们成功在 Jenkins 服务器从 Github 拉取代码下来并打包完成了,下面需要将项目启动的文件(包含刚才打好的 Jar 包)通过 SSH 远程上传到项目运行的目标服务器,并执行项目自动命令。

5.1 SSH 连接目标服务器

安装 publish Over SSH 插件:用于把打好的包发到远端服务器,同时需要配置和远端服务器的免密登录
在这里插入图片描述

系统配置 中最下方的 Publish over SSH 新增 SSH Servers 配置,添加一台目标服务器:
在这里插入图片描述
在这里插入图片描述
测试 SSH 连接是否成功:
在这里插入图片描述

5.2 项目配置

设置项目构建后的操作:

在这里插入图片描述
在这里插入图片描述

可以发现 SSH 服务已经填入我们刚才设置的目标服务器:

在这里插入图片描述

然后配置所需要上传的项目文件、项目启动脚本等:
在这里插入图片描述

重新执行项目构建:
在这里插入图片描述

可以看到已经成功将项目部署到远程服务器了。

ssh 连接远程服务器,进入 /usr/soft/jenkins/app/mingink 目录下,查看文件:

cd /usr/soft/jenkins/app/mingink
ls -al
docker ps -a

在这里插入图片描述
可以看到文件已经成功上传到目标服务器的指定目录下,并成功启动 Web 项目。

6、Git 钩子自动构建项目

假如你希望当项目代码 push 到远程仓库后,自动触发 Jenkins 的构建任务重新部署项目,那么就往下走。(ps: 这种方式适用于开发和测试环境,企业中生产环境更多是通过控制台手动或定时触发 JenKins 构建任务)

安装 Generic Webhook Trgger 插件,重启 Jenkins 后生效:

在这里插入图片描述
配置项目中的构造触发器:
在这里插入图片描述
然后通过访问 http://ip:8180/generic-webhook-trigger/invoke?token=jV2eIyBZzAD0JmEZ0JjR 这个 URL 就可以触发 Jenkins 的构建任务了。

在 Github -> 项目 -> Settings -> Webhooks 下,Add webhook:
在这里插入图片描述
之后修改项目,提交一次 git push,到 Github 合并请求:
在这里插入图片描述

这时候在 Jenkins 控制台你会发现已经自动触发了构建任务:

在这里插入图片描述

可以看到,当代码提交到 Github 仓库,就触发了构建任务。

注意:如果希望当 Pull Request 触发自动构建任务时,可以在 webhook -> Let me select individual events. -> 选择 Pull Request 更改触发条件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1612695.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

linux中/etc/hosts文件的内容和功能

更准确的说是主机和ip地址映射绑定配置文件 用于主机名解析成ip地址的 转换配置 效果&#xff1a; 这个东西是局域网下面的解析&#xff0c;老师说是本地局域网解析 windows对应的就是

开源项目-汽车租赁管理系统

哈喽,大家好,今天主要给大家带来一个开源项目-汽车租赁管理系统 汽车租赁管理系统的主要功能包括汽车管理,新闻管理,用户管理,订单管理,数据展示等模块 注:后续文章都会附上安装教程,有问题也欢迎大家评论私信。 登录 汽车管理 汽车管理可以查看所有汽车进行线上汽…

python爬虫笔记1

1 爬虫介绍 爬虫概述&#xff1a; 获取网页并提取和保存信息的自动化程序 1.获取网页 2.提取信息 css选择器 xpath 3.保存数据&#xff08;大数据时代&#xff09; 4.自动化 爬虫&#xff08;资产收集&#xff0c;信息收集&#xff09; 漏扫&#xff08;帮我发现漏洞&#xff…

【机器学习】《ChatGPT速通手册》笔记

文章目录 第0章 前言第1章 ChatGPT的由来&#xff08;一&#xff09;自然语言处理任务&#xff08;二&#xff09;ChatGPT所用数据数据大小&#xff08;三&#xff09;ChatGPT的神经网络模型有175亿个参数&#xff08;四&#xff09;模型压缩 方案 第2章 ChatGPT页面功能介绍&a…

每日算法4/21

LCR 073. 爱吃香蕉的狒狒 题目 狒狒喜欢吃香蕉。这里有 N 堆香蕉&#xff0c;第 i 堆中有 piles[i] 根香蕉。警卫已经离开了&#xff0c;将在 H 小时后回来。 狒狒可以决定她吃香蕉的速度 K &#xff08;单位&#xff1a;根/小时&#xff09;。每个小时&#xff0c;她将会选…

Json三方库介绍

目录 Json是干什么的Json序列化代码Json反序列化代码 Json是干什么的 Json是一种轻量级的数据交换格式&#xff0c;也叫做数据序列化方式。Json完全独立于编程语言的文本格式来存储和表述数据。易于人阅读和编写&#xff0c;同时也易于机器解析和生成&#xff0c;并有效地提升…

MATLAB求和函数

语法 S sum(A) S sum(A,“all”) S sum(A,dim) S sum(A,vecdim) S sum(,outtype) S sum(,nanflag) 说明 示例 S sum(A) 返回沿大小大于 1 的第一个数组维度计算的元素之和。 如果 A 是向量&#xff0c;则 sum(A) 返回元素之和。 如果 A 是矩阵&#xff0c;则 sum(A) 将…

2023年网络安全行业:机遇与挑战并存

2023年全球网络安全人才概况 根据ISC2的《2023年全球网络安全人才调查报告》&#xff0c;全球的网络安全专业人才数量达到了550万&#xff0c;同比增长了8.7%。然而&#xff0c;这一年也见证了网络安全人才短缺达到了历史新高&#xff0c;缺口数量接近400万。尤其是亚太地区&am…

【题解】NC40链表相加(二)(链表 + 高精度加法)

https://www.nowcoder.com/practice/c56f6c70fb3f4849bc56e33ff2a50b6b?tpId196&tqId37147&ru/exam/oj class Solution {public:// 逆序链表ListNode* reverse(ListNode* head) {// 创建一个新节点作为逆序后链表的头节点ListNode* newHead new ListNode(0);// 当前…

Spring Boot中接收各种各样的参数

一、接收json参数&#xff0c;封装为Map 1.1、核心代码 /*** 接收json参数&#xff0c;封装为Map* param servletRequest* return* throws Exception*/ PostMapping("/getParam") public R getParam(HttpServletRequest servletRequest) throws Exception {Map<…

MyCat 分片

一、垂直拆分 1、场景概述&#xff1a; 在业务系统中&#xff0c;由于用户与订单每天都会产生大量的数据&#xff0c;单台服务器的数据存储及处理能力是有限的&#xff0c;可以对数据库表进行进行垂直分库操作。将商品相关的表拆分到一个数据库服务器&#xff0c;订单表拆分到…

Spring(下)

接上篇&#xff0c;从第八个问题讲起 八.Spring工厂创建复杂对象 1.什么是复杂对象 简单对象就是可以直接new出来的&#xff0c;也就是直接调用构造方法创建 所以复杂对象就是不能直接通过调用构造方法创建。就比如JDBC中的Connection 2.三种方法 &#xff08;1&#xff…

【LeetCode刷题记录】206. 反转链表

206 反转链表 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1] 示例 2&#xff1a; 输入&#xff1a;head [1,2] 输出&#xff1a;[2,1] 示例…

毕业设计——基于ESP32的智能家居系统(语音识别、APP控制)

ESP32嵌入式单片机实战项目 一、功能演示二、项目介绍1、功能演示2、外设介绍 三、资料获取 一、功能演示 多种控制方式 ① 语音控制 ②APP控制 ③本地按键控制 ESP32嵌入式单片机实战项目演示 二、项目介绍 1、功能演示 这一个基于esp32c3的智能家居控制系统&#xff0c;能实…

MyCat 数据库中间件

一、介绍 1、单数据库进行数据存储的问题&#xff1a; IO瓶颈&#xff1a;热点数据太多&#xff0c;数据库缓存不足以容纳这些热点数据&#xff0c;产生大量磁盘IO&#xff0c;效率较低。 CPU瓶颈&#xff1a;排序、分组、连接查询、聚合统计等SQL会耗费大量的CPU资源。 2、…

Rest接口/Nginx日志记录和采集

文章目录 一、Rest接口日志二、Nginx日志三、采集日志四、夜莺查看Nginx日志五、夜莺查看Rest接口日志 一、Rest接口日志 记录日志字典定义 接口URL接口名称,类别,入参全记录,出参全记录,入参字段1:中文名1/入参字段2:中文名2,出参字段1:中文名1/test/api/login账户登录,登录…

【C++】开始使用优先队列

送给大家一句话: 这世上本来就没有童话&#xff0c;微小的获得都需要付出莫大的努力。 – 简蔓 《巧克力色微凉青春》 开始使用优先队列 1 前言2 优先队列2.1 什么是优先队列2.2 使用手册2.3 仿函数 3 优先队列的实现3.1 基本框架3.2 插入操作3.3 删除操作3.4 其他函数 4 总结T…

kubernetes的网络通信实现原理

网络原理 Kubernetes网络原理详解&#xff1a;一、Kubernetes 网络实现1.容器到容器&#xff08;同一Pod内&#xff09;通信流程&#xff1a;2. pod之间的通信&#xff08;以Calico为例&#xff09;&#xff1a; 二、CNI 网络模型三、网络策略四、开源的容器网络方案五、 常见网…

Linux管道共享内存

前言 进程虽然是独立运行的个体&#xff0c;但它们之间有时候需要协作才能完成一项工作&#xff0c;比如有两个进程需要同步数据&#xff0c;进程 A 把数据准备好后&#xff0c;想把数据发往进程 B&#xff0c;进程 B 必须被提前通知有数据即将到来&#xff0c;或者进程 A 想发…

Spark集群的搭建

1.1搭建Spark集群 Spark集群环境可分为单机版环境、单机伪分布式环境和完全分布式环境。本节任务是学习如何搭建不同模式的Spark集群&#xff0c;并查看Spark的服务监控。读者可从官网下载Spark安装包&#xff0c;本文使用的是spark-2.0.0-bin-hadoop2.7.gz。 1.1.1搭建单机版…