Jenkins实现CICD流程(jenkins checkout)
wptr33 2024-11-17 02:41 38 浏览
CICD
持续集成(Continuous Integration)、持续交付(Continuous Delivery) 、持续部署(Continuous Deployment)
项目提交到github,然后Jenkins通过github的变化拉取代码进行maven构建,并把构建好的项目Jar包制作成image上传到doker或者阿里云仓库中,k8s集群再从镜像仓库中拉取镜像进行部署运行,整个过程全是自动化的,这个过程就是CICD的过程。
1.环境准备
基础环境准备[在jenkins那台机器上安装]
- 安装java
(1)找到jdk资源上传到指定机器
#上传jdk到服务器的文件夹中
java/jdk-8u181-linux-x64.tar.gz
#解压jdk
tar -zxvf jdk-8u181-linux-x64.tar.gz
(2)配置jkd环境变量
#编辑文件
vim /etc/profile
#添加如下内容
export JAVA_HOME=/usr/local/java/jdk1.8.0_181
export CLASSPATH=.:${JAVA_HOME}/jre/lib/rt.jar:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
export PATH=$PATH:${JAVA_HOME}/bin
#使配置文件生效
source /etc/profile
#测试
java -version
- 安装maven
(1)找到maven资源上传到指定机器
#上传mavne到服务器的文件夹中
java/apache-maven-3.6.2-bin.tar.gz
#解压jdk
tar -zxvf apache-maven-3.6.2-bin.tar.gz
(2)配置maven环境变量
#编辑文件
vim /etc/profile
#添加如下内容
export MAVEN_HOME=/usr/local/maven/apache-maven-3.6.2
export PATH=$PATH:$JAVA_HOME/bin:$MAVEN_HOME/bin
#使配置文件生效
source /etc/profile
#测试
mvn -version
(3)配置maven的阿里云镜像
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
- 安装配置git
(1)下载安装
yum install git
(2)配置git
#全局设置
git config --global user.name "yp1527"
git config --global user.email "abm520@126.com"
#生成公钥并上传到github【公钥路径:/root/.ssh/id_rsa.pub】
ssh-keygen -t rsa -C "abm520@126.com"
安装配置Jenkins
jenkins官网:https://jenkins.io/
入门指南:<https://jenkins.io/zh/doc/pipeline/tour/getting-started/
(1)在对应的文件中上传jenkins war包:java/jenkins.war
wget http://mirrors.jenkins.io/war-stable/latest/jenkins.war
(2)启动jenkins[记得当前机器安装了jdk/jre,不然运行不了]
#后台运行并暴露8080端口
nohup java -jar jenkins.war --httpPort=8080 &
#查看日志
tail -f nohup.out
(3)win浏览器访问w2的ip 192.168.0.23:8080
#查看密码
cat /root/.jenkins/secrets/initialAdminPassword
(4)安装推荐的插件
(5)创建一个用户
username:yangping
password:yangping
(6)安装配置git,maven【 在jenkins上使用centos的java,git,maven等】 [系统管理]->[全局工具配置]->[Maven、JDK、Git等]
配置好后点击应用并保存。
jenkins配置从github上拉取代码并用maven进行构建
1.新建pipeline任务
在流水线中输入任务执行脚本【从git拉取代码后开始maven构建项目】
然后“保存和立即构建“,同时可以查看“Console Output”
来到w2节点:ls /root/.jenkins/workspace/springboot-demo
至此,我们已经可以通过在jenkins上手动构建的方式,拿到github上的代码,并且用maven进行构建。
git push触发jenkins自动构建
当用户进行git commit/push提交代码到github时,能够通知jenkins自动构建
注意:jenkins的ip一定要是github能够访问到的地址
(1)在github上配置jenkins的webhook地址http://121.40.56.193:8080/springboot-demo
(2)生成Personal access tokens
Jenkins访问github需要授权,所以在github上生成token交给jenkins使用,即 Personal access tokens github的Settings[个人信息右上角]-->Developer settings-->Personal access tokens-->Generate new token,最后保存好该token,比如:72f048b514e95d6fe36f86d84374f2dcce402b43
(3)jenkins安装插件
01 安装github plugin插件:[系统管理]->[插件管理]->[可选插件]
02 安装gitlab插件和gitlab hook插件:[系统管理]->[插件管理]->[可选插件]
(4)配置GitHub Server
[系统管理]->[系统配置]->[找到github服务器]->[添加github服务器]然后按照下面图片步骤进行操作
然后进行测试,最后点击最下面的保存
build镜像并push镜像到仓库
经过前面的步骤,我们已经可以获取到代码,并且用maven进行构建了,最终拿到一个target/xxx.jar。此时我们可以把jar包制作成Image并上传到阿里云仓库。
(1)准备一个文件,名称为springboot-demo-build-image.sh
#新建一个scripts目录
mkdir /root/.jenkins/workspace/scripts/
vi /root/.jenkins/workspace/scripts/springboot-demo-build-image.sh
(2)编写springboot-demo-build-image.sh文件
# 进入到springboot-demo目录
cd ../springboot-demo
# 编写Dockerfile文件
cat <<EOF > Dockerfile
FROM openjdk:8-jre-alpine
COPY target/springboot-0.0.1-SNAPSHOT.jar /springboot-demo.jar
ENTRYPOINT ["java","-jar","/springboot-demo.jar"]
EOF
echo "Dockerfile created successfully!"
# 基于指定目录下的Dockerfile构建镜像
docker build -t registry.cn-hangzhou.aliyuncs.com/yp2018/springboot-demo:v1.0 .
# push镜像,这边需要阿里云镜像仓库登录,在w2上登录
docker push registry.cn-hangzhou.aliyuncs.com/yp2018/springboot-demo:v1.0
(4)增加pipeline脚本
node {
def mvnHome
stage('Preparation') {
git 'https://github.com/yp1527/springboot-demo.git'
}
stage('Maven Build') {
sh "mvn clean package"
}
stage('Build Image') {
sh "/root/.jenkins/workspace/scripts/springboot-demo-build-image.sh"
}
}
(5)注意
# 01 文件权限
/root/.jenkins/workspace/springboot-demo@tmp/durable-7dbf7e73/script.sh: line 1: /root/.jenkins/workspace/scripts/springboot-demo-build-image.sh: Permission denied
# 解决
chmod +x /root/.jenkins/workspace/scripts/springboot-demo-build-image.sh
# 02 docker没有运行
Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
# 解决
systemctl start docker
systemctl enable docker
# 03 push权限
docker login --username=18224401527 registry.cn-hangzhou.aliyuncs.com
Kubernetes拉取镜像运行
经过前面的步骤,现在已经能够把镜像push到镜像仓库了,接下来就是k8s拉取镜像并且运行在集群中。根据前面的经验,肯定再创建一个stage,然后运行sh脚本,脚本中执行内容,包括yaml文件。【因为springboot项目要通过ingress进行外面访问所以要保证ingress-conttroller运行】
(1)编写springboot-demo.yaml文件【 在/root/.jenkins/workspace/scripts/目录下创建springboot-demo.yaml】
# 以Deployment部署Pod
apiVersion: apps/v1
kind: Deployment
metadata:
name: springboot-demo
spec:
selector:
matchLabels:
app: springboot-demo
replicas: 1
template:
metadata:
labels:
app: springboot-demo
spec:
containers:
- name: springboot-demo
image: registry.cn-hangzhou.aliyuncs.com/yp2018/springboot-demo:v1.0
ports:
- containerPort: 8080
---
# 创建Pod的Service
apiVersion: v1
kind: Service
metadata:
name: springboot-demo
spec:
ports:
- port: 80
protocol: TCP
targetPort: 8080
selector:
app: springboot-demo
---
# 创建Ingress,定义访问规则
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: springboot-demo
spec:
rules:
- host: yp.k8s.demo
http:
paths:
- path: /
backend:
serviceName: springboot-demo
servicePort: 80
(2)编写k8s-deploy-springboot-demo.sh文件【vi /root/.jenkins/workspace/scripts/k8s-deploy-springboot-demo.sh】
#删除服务
kubectl delete -f /root/.jenkins/workspace/scripts/springboot-demo.yaml
#部署服务
kubectl apply -f /root/.jenkins/workspace/scripts/springboot-demo.yaml
#打印
echo "k8s deploy success!"
(3)编写pipeline脚本
node {
def mvnHome
stage('Preparation') {
git 'https://github.com/yp1527/springboot-demo.git'
}
stage('Maven Build') {
sh "mvn clean package"
}
stage('Build Image') {
sh "/root/.jenkins/workspace/scripts/springboot-demo-build-image.sh"
}
stage('K8S Deploy') {
sh "/root/.jenkins/workspace/scripts/k8s-deploy-springboot-demo.sh"
}
}
注意:在k8s集群中的woerk节点上如果不能执行 kubectl 命令,是因为没有权限,可以把master节点中的.kube目录下的config内容复制到worker节点同样的地方就可以了。
# 给k8s-deploy-springboot-demo.sh执行权限
chmod +x /root/.jenkins/workspace/scripts/k8s-deploy-springboot-demo.sh
Push代码到git进行测试,验证Jenkins是否会拉取代码进行maven构建代码,然后根据Jar包进行生成Image并上传到阿里云仓库,最后k8s集群从阿里云仓库拉取进行进行部署运行。
至此一个项目的CICD过程搭建完成。
相关推荐
- 第 28 章:核心功能 SQL 查询 - PostgreSQL入门
-
欢迎来到我们史诗级教程的最终章!在上一章,我们成功地构建了博客系统的数据库骨架。现在,这个结构精良的数据库正静静地等待着我们去使用它。...
- postgresql的6种索引介绍_postgresql默认用户名和密码
-
postgresql几种索引PostgreSQL支持多种索引类型,每种索引的设计原理、适用场景和优缺点各有不同。以下是对主要索引类型的详细介绍:...
- 第 20 章:索引与性能优化 - PostgreSQL入门
-
到目前为止,我们已经学习了如何设计表、保证数据完整性、以及如何用各种方式查询数据。但当我们的表从几十行增长到几百万、甚至上亿行时,一个之前只需要0.1秒的查询,可能会变成需要几分钟甚至几小时的“灾...
- PostgreSQL 主从复制 完整指南_主从复制mysql
-
PostgreSQL主从复制(StreamingReplication)完整指南PostgreSQL主从复制是一种实时同步数据的机制,可以实现高可用性(HA)、读写分离和负载均衡。其...
- PostgreSQL监控神器,千万注意这5大关键指标!
-
PostgreSQL监控神器,千万注意这5大关键指标!在当今数据驱动的业务环境中,数据库的性能和稳定性直接关系到企业的运营效率与用户体验。PostgreSQL作为一款功能强大的开源关系型数据库,被广泛...
- Retool 如何升级主应用 4TB 的 PostgreSQL 数据库
-
本文最初发布于Retool官方博客。...
- PostgreSQL查询计划_postgresql查询计划中的cost组成
-
深入解析PostgreSQL查询计划:优化性能的关键在数据库管理系统中,查询计划是执行SQL查询时的关键组成部分。PostgreSQL作为一款功能强大的开源关系型数据库,其查询计划的生成与优化对于提升...
- 第 27 章:数据库与表结构实现 - PostgreSQL入门
-
在上一章,我们已经绘制好了博客系统的宏伟蓝图。现在,是时候戴上安全帽,化身“建筑工程师”,将图纸上的设计一砖一瓦地搭建成真实的数据库结构了。...
- PostgreSQL事务处理_postgresql时区问题
-
PostgreSQL事务处理:原理、应用与优化引言...
- 第 14 章:集合运算 (UNION, INTERSECT, EXCEPT) - PostgreSQL入门
-
在之前的章节里,我们所有的操作(JOIN...
- PostgreSQL 安装指南及日常使用_postgresql 11安装
-
PostgreSQL安装与日常使用PostgreSQL是一款功能强大、开源的对象关系型数据库,支持高级SQL标准、扩展功能、事务完整性和高并发。本指南涵盖安装、配置、日常使用、性能优化、常见...
- 第 23 章:函数与存储过程 (PL/pgSQL) - PostgreSQL入门
-
到目前为止,我们与数据库的交互方式都是从外部客户端(如psql...
- PostgreSQL是不是你的下一个JSON数据库?
-
根据Betteridge定律(任何头条的设问句可以用一个词来回答:不是),除非你的JSON数据很少修改,并且查询很多。最新版的PostgreSQL添加更多对JSON的支持,我们曾经问过PostgreS...
- "揭秘PostgreSQL:你必须掌握的数据类型全解析!"
-
揭秘PostgreSQL:你必须掌握的数据类型全解析!在数据库管理系统中,PostgreSQL以其强大的功能和稳定性而著称。为了充分发挥其性能,理解并熟练掌握其数据类型是至关重要的。本文将深入探讨Po...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
-
- 第 28 章:核心功能 SQL 查询 - PostgreSQL入门
- postgresql的6种索引介绍_postgresql默认用户名和密码
- 第 20 章:索引与性能优化 - PostgreSQL入门
- PostgreSQL 主从复制 完整指南_主从复制mysql
- PostgreSQL监控神器,千万注意这5大关键指标!
- Retool 如何升级主应用 4TB 的 PostgreSQL 数据库
- PostgreSQL查询计划_postgresql查询计划中的cost组成
- 第 27 章:数据库与表结构实现 - PostgreSQL入门
- 谁帮我看看,为啥我的PostgreSQL查询速度这么慢???
- PostgreSQL事务处理_postgresql时区问题
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)