热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

基于Kubernetes/K8S构建Jenkins持续集成平台

Jenkins-Master-Slave架构图回顾:安装和配置NFSNFS简介NFS(NetworkFileSystem),它最大的功能就是可以通过网络,让不同的机器、不同的操作系

Jenkins-Master-Slave 架构图回顾:


安装和配置 NFS

NFS简介

NFS(Network File System),它最大的功能就是可以通过网络,让不同的机器、不同的操作系统可以共享彼此的文件。我们可以利用NFS共享Jenkins运行的配置文件、Maven的仓库依赖文件等


NFS安装

我们把 NFS 服务器安装在 master 192.168.10.90 服务器上


(1)安装NFS服务(在所有K8S的节点都需要安装)

yum install -y nfs-utils

(2)创建共享目录

mkdir -p /opt/nfs/jenkins

vim /etc/exports #编写NFS的共享配置
/opt/nfs/jenkins *(rw,no_root_squash) #*代表对所有IP都开放此目录,rw是读写

(3)启动服务

systemctl enable nfs #开机启动
systemctl start nfs #启动

(4)查看 NFS 共享目录

showmount -e 192.168.10.90


Kubernetes 安装 Jenkins-Master


创建NFS client provisioner

nfs-client-provisioner 是一个Kubernetes的简易NFS的外部provisioner,本身不提供NFS,需要现有的NFS服务器提供存储。


(1)上传nfs-client-provisioner构建文件

其中注意修改 deployment.yaml,使用之前配置NFS服务器和目录

vim deployment.yaml


(2)构建nfs-client-provisioner的pod资源

cd nfs-client
kubectl create
-f .


(3)查看pod是否创建成功

kubectl get pods


安 装 Jenkins-Master


(1)上传Jenkins-Master构建文件

其中有两点注意:

第一、在StatefulSet.yaml文件,声明了利用nfs-client-provisioner进行Jenkins-Master文件存储

第二、Service发布方法采用NodePort,会随机产生节点访问端口


(2)创建kube-ops的namespace

因为我们把Jenkins-Masterpod放到kube-ops

kubectl create namespace kube-ops

(3)构建Jenkins-Masterpod资源

cd jenkins-master
kubectl create
-f .


(4)查看pod是否创建成功

kubectl get pods -n kube-ops


(5)查看信息,并访问

查看Pod运行在那个Node上

kubectl describe pods -n kube-ops

查看分配的端口

kubectl get service -n kube-ops

查看Pod在哪个节点上运行(用该节点的ip+端口访问浏览器)

kubectl get pods --namespace kube-ops -o wide


(6)浏览器访问

最终访问地址为:http://192.168.10.100:31881/ 192.168.10.100 k8s-node1IP

安装过程跟之前是一样的!

找到密钥复制粘贴

/opt/nfs/jenkins/kube-ops-jenkins-home-jenkins-0-pvc-f3e2aa49-5a83-48ba-a308-a4eb56296648/secrets
ls
cat initialAdminPassword

选择插件来安装 --> 无 --> 安装

Kubernetes 中 Jenkins 部署完成!!!


 (7)设置插件下载地址

cd /opt/nfs/jenkins/
ls
cd kube
-ops-jenkins-home-jenkins-0-pvc-f3e2aa49-5a83-48ba-a308-a4eb56296648/ #注意:这个目录每个人是不一样的,不要直接复制
ls
cd updates
/
ls
sed
-i 's/http:\/\/updates.jenkins- ci.org\/download/https:\/\/mirrors.tuna.tsinghua.edu.cn\/jenkins/g' default.json && sed -i 's/http:\/\/www.google.com/https:\/\/www.baidu.com/g' default.json

Manage Jenkins --> Manage Plugins --> Advanced  -->  Update Site 改为国内插件下载地址

https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json

 

提交后重启 Jenkins


(8)先安装基本的插件



  • Localization:Chinese

  • Git

  • Pipeline

  • Extended Choice Parameter

   安装完成后重启 Jenkins


Jenkins 与 Kubernetes 整合


安装 Kubernetes 插件

系统管理 --> 插件管理 --> 可选插件


实现 Jenkins 与 Kubernetes 整合

系统管理 --> 系统配置 --> --> 新建云 --> Kubernetes

 


kubernetes 地 址 采 用 了 kube 的 服 务 器 发 现 :

https://kubernetes.default.svc.cluster.local namespace填kube-ops,然后点击Test Connection,如果出现 Connection test successful 的提示信息证明 Jenkins 已经可以和 Kubernetes 系统正常通信

Jenkins URL 地址http://jenkins.kube-ops.svc.cluster.local:8080



构建 Jenkins-Slave 自定义镜像

Jenkins-Master在构建Job的时候,Kubernetes 会创建Jenkins-Slave的Pod来完成Job的构建。我们选择  运行Jenkins-Slave的镜像为官方推荐镜像:jenkins/jnlp-slave:latest,但是这个镜像里面并没有Maven    环境,为了方便使用,我们需要自定义一个新的镜像:

准备材料:

           

 

Dockerfile文件内容如下:

FROM jenkins/jnlp-slave:latest
MAINTAINER xxx
# 切换到 root 账户进行操作
USER root
# 安装 maven
COPY apache
-maven-3.6.2-bin.tar.gz .
RUN tar
-zxf apache-maven-3.6.2-bin.tar.gz && \
mv apache
-maven-3.6.2 /usr/local && \
rm
-f apache-maven-3.6.2-bin.tar.gz && \
ln
-s /usr/local/apache-maven-3.6.2/bin/mvn /usr/bin/mvn && \
ln
-s /usr/local/apache-maven-3.6.2 /usr/local/apache-maven && \
mkdir
-p /usr/local/apache-maven/repo
COPY settings.xml
/usr/local/apache-maven/conf/settings.xml
USER jenkins

//构建镜像

docker build -t jenkins-slave-maven:latest .

构建出一个新镜像:jenkins-slave-maven:latest

登录 Harbor仓库、打标签、推送镜像到 harbor( ip为 harbor仓库地址 )

docker login -u admin -p Harbor12345 192.168.10.60:85
docker tag jenkins
-slave-maven:latest 192.168.10.60:85/library/jenkins-slave-maven:latest
docker push
192.168.10.60:85/library/jenkins-slave-maven:latest

刷新 harbor 网页


测试 Jenkins-Slave 是否可以创建


(1)创建一个 Jenkins 流水线项目

新建 item: test_jenkins_slave

进入配置页面后不做任何配置 点击应用保存

 

要先去配置凭证:

系统管理 --> Manage Credential --> 全局 --> 添加凭据

回到项目 test_jenkins_slave --> 配置

checkout([$class: 'GitSCM', branches: [[name: '*/master']], extensions: [], userRemoteConfigs: [[credentialsId: 'fc0fab00-287d-4803-aba2-42ee7714028a', url: 'http://192.168.10.10:82/xxx_group/tensquare_back.git']]])

def git_address = "http://192.168.10.10:82/xxx_group/tensquare_back.git"
def git_auth
= "fc0fab00-287d-4803-aba2-42ee7714028a"
//创建一个Pod的模板,label为jenkins-slave
podTemplate(label: 'jenkins-slave', cloud: 'kubernetes', containers: [
containerTemplate(
name:
'jnlp',
image:
"192.168.10.60:85/library/jenkins-slave-maven:latest"
)
]
)
{
//引用jenkins-slave的pod模块来构建Jenkins-Slave的pod
node("jenkins-slave"){
stage(
'拉取代码'){
checkout([$
class: 'GitSCM', branches: [[name: '*/master']], extensions: [], userRemoteConfigs: [[credentialsId: "${git_auth}", url: "${git_address}"]]])
}
}
}

(2)编写 Pipeline,从GItlab拉取代码(使用http方式)

再启动一个 Jenkins 终端,

构建前的节点列表:


(3)构建项目 test_jenkins_slave

构建中,刷新状态

构建完成后,刷新状态


小结:

底层跑的是 k8s,在 k8s 基础之上建立的 Jenkins,而 Jenkins 完成里面当中的 devops 的CI/CD一整套持续性交互集成:从代码拉取、代码检查、编译打包、镜像制作、镜像上传、拉取镜像、应用发布,这些个工作全部交给 slave 去完成,而不是 master 工作,slave 完成工作后会自动销毁,不占用资源。

 

 

 

 

 

 

 

 


原文链接:https://www.cnblogs.com/darryallen/p/15981641.html



推荐阅读
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
  • 该平台旨在为大型企业提供一个高效、灵活且可扩展的分布式微服务架构解决方案。它采用模块化、微服务化和热部署的设计理念,结合当前最先进且无商业限制的主流开源技术,如Spring Cloud、Spring Boot2、MyBatis、OAuth2和Element UI,实现前后端分离的系统管理平台。 ... [详细]
  • 本文档详细规划了从基础到高级的软件测试学习路径,包括但不限于测试基础、Linux和数据库、功能测试、Python编程、接口测试、性能测试、金融项目实战、UI自动化测试等内容,旨在为初学者和进阶者提供全面的学习指导。 ... [详细]
  • 本文详细介绍了如何利用go-zero框架从需求分析到最终部署至Kubernetes的全过程,特别聚焦于微服务架构中的网关设计与实现。项目采用了go-zero及其生态组件,涵盖了从API设计到RPC调用,再到生产环境下的监控与维护等多方面内容。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨了一家企业的制度体系重构与升级过程,通过具体案例展示了如何在战略意图和管理理念指导下,系统性地提升企业管理制度的有效性和可操作性。 ... [详细]
  • 如何优化2060显卡设置以提升《Apex英雄》游戏体验
    《Apex英雄》作为一款热门的战术竞技游戏,吸引了大量玩家。本文将探讨如何通过优化GeForce RTX 2060显卡设置,确保在《Apex英雄》中获得最佳性能和流畅的游戏体验。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文详细探讨了Netty中Future及其子类的设计与实现,包括其在并发编程中的作用和具体应用场景。我们将介绍Future的继承体系、关键方法的实现细节,并讨论如何通过监听器和回调机制来处理异步任务的结果。 ... [详细]
  • 如何在PostgreSQL中查看数据表
    本文将指导您使用pgAdmin工具连接到PostgreSQL数据库,并展示如何浏览和查找其中的数据表。通过简单的步骤,您可以轻松访问所需的表结构和数据。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 深入解析:OpenShift Origin环境下的Kubernetes Spark Operator
    本文探讨了如何在OpenShift Origin平台上利用Kubernetes Spark Operator来管理和部署Apache Spark集群与应用。作为Radanalytics.io项目的一部分,这一开源工具为大数据处理提供了强大的支持。 ... [详细]
author-avatar
Xlady贩卖__铺
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有