DevOps搭建(十六)-Jenkins+K8s部署详细步骤

这篇具有很好参考价值的文章主要介绍了DevOps搭建(十六)-Jenkins+K8s部署详细步骤。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

1、整体部署架构图

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

2、编写脚本

vi pipeline.yml
apiVersion: apps/v1
kind: Deployment
metadata:
  namespace: test
  name: pipeline
  labels:
    app: pipeline
spec:
  replicas: 2
  selector:
    matchLabels:
      app: pipeline
  template:
    metadata:
      labels:
        app: pipeline
    spec:
      containers:
        - name: pipeline
          image: 192.168.88.125:80/repo/devops-pipeline-test:v4.0.0
          #镜像拉取策略,不管内容变不变都重新拉取
          imagePullPolicy: Always
          ports:
            - containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:
  namespace: test
  #注意:这里要和Deployment的名称一致
  name: pipeline
  labels:
    app: pipeline
spec:
  selector:
    #注意:这里要和Deployment的app名称一致
    app: pipeline
  ports:
    #Service的端口
    - port: 8081
      #容器内的端口
      targetPort: 8080
  type: NodePort
---
#apiVersion值必须写成networking.k8s.io/v1
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  namespace: test
  name: pipeline
spec:
  #可视化界面配置的ingress名称
  ingressClassName: ingress
  rules:
    #映射的域名
    - host: k8s.pipeline.com
      http:
        paths:
          #访问什么样的路径
          - path: /
            #匹配方式,前缀匹配,即匹配上path配置的斜杠就可以
            pathType: Prefix
            backend:
              #自定用哪个service
              service:
                name: pipeline
                port:
                  #映射的端口
                  number: 8081

3、配置daemon.json

要想从Harbor仓库中拉取镜像,首先要往主机和从机的daemon.json文件中添加Harbor的地址信息

"insecure-registries":["192.168.88.125:80"],别忘了80端口

vi /etc/docker/daemon.json

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

添加完之后,重启下docker

systemctl restart docker

4、配置Docker私服信息

要拉取镜像,需要Harbor登录进行拉取,到Kuboard控制台对应的命名空间找到密文菜单,点击创建Secret

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

填写对应的信息即可

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

复制上图中的复制命令在k8s主机上运行

docker login 192.168.88.125:80/ -u admin -p Harbor12345

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

5、测试脚本

kubectl apply -f pipeline.yml

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

浏览器请求服务正常返回,脚本测试通过。

http://192.168.88.126:31603/test/test

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

6、Jenkins整合Kubernetes

6.1、将pipeline.yml推送到k8smaster

先在SpringBoot项目下创建pipeline.yml文件,内容为步骤2中的脚本内容。

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

接着生成流水线脚本,目标服务器选择k8smaster服务器,文件写pipeline.yml文件。

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

将流水线脚本粘贴到Jenkinsfile对应的步骤中

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

6.2、Jenkinsfile增加远程执行kubectl命令

在Jenkinsfile文件中,流水线步骤增加如下增加远程执行kubectl命令步骤。

原始脚本

kubectl apply -f /usr/local/k8s/pipeline.yml
#强制刷新deployment,防止pipeline.yml没发生变化时不重新部署
kubectl rollout restart deployment pipeline -n test

生成流线脚本:

sshPublisher(publishers: [sshPublisherDesc(configName: 'k8smaster', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'kubectl apply -f /usr/local/k8s/pipeline.yml', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])

粘贴到Jenkinsfile文件对应的步骤中

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

完整的Jenkinsfile文件内容如下:

//所有的脚本命令都放在pipeline中
pipeline {
    //指定任务在哪个集群节点中执行
    agent any

    //声明全局变量,方便后面使用
    environment {
        harborUser = 'admin'
        harborPassword = 'Harbor12345'
        harborAddress = '192.168.88.125:80'
        harborRepo = 'repo'
    }

    stages {
        stage('拉取代码') {
            steps {
                echo '开始拉取git仓库代码……'
                checkout scmGit(branches: [[name: '$tag']], extensions: [], userRemoteConfigs: [[url: 'http://192.168.88.125:8929/root/devops-test.git']])
                echo '开始拉取git仓库代码完毕。'
            }
        }
        stage('构建项目') {
            steps {
                echo '开始通过maven构建项目……'
                sh '/var/jenkins_home/maven/bin/mvn clean package -DskipTests'
                echo '通过maven构建项目完毕'
            }
        }
        stage('代码检查') {
            steps {
                echo 'TODO 通过SonarQube做代码质量检测'
            }
        }
        stage('制作镜像') {
            steps {
                echo '通过Docker制作自定义镜像……'
                sh '''mv ./target/*.jar ./docker/
                docker build -t ${JOB_NAME}:${tag} ./docker/'''
                echo '通过Docker制作自定义镜像完毕'
            }
        }
        stage('推送镜像') {
            steps {
                echo '将自定义对象推送到Harbor仓库……'
                sh '''docker login -u ${harborUser} -p ${harborPassword} ${harborAddress}
                docker tag ${JOB_NAME}:${tag} ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}
                docker push ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}
                docker image prune -f'''
                echo '将自定义对象推送到Harbor仓库完成'
            }
        }
        stage('将yml文件传到k8smaster') {
            steps {
                echo '将yml文件传到k8smaster……'
                sshPublisher(publishers: [sshPublisherDesc(configName: 'k8smaster', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: 'pipeline.yml')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
                echo '将yml文件传到k8smaster完毕'
            }
        }
		stage('远程执行k8smaster的kubectl命令') {
            steps {
                echo '远程执行k8smaster的kubectl命令……'
                sshPublisher(publishers: [sshPublisherDesc(configName: 'k8smaster', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'kubectl apply -f /usr/local/k8s/pipeline.yml', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
                echo '远程执行k8smaster的kubectl命令完毕'
            }
        }
    }
}

7、构建测试

执行Jenkins项目构建

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

构建成功后,去Kuboard可以到对应的Service

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

DevOps搭建(十六)-Jenkins+K8s部署详细步骤,devops,jenkins,kubernetes,自动化部署,docker,运维

kubernetes2

DevOps8

Docker4

Jenjins6

架构师5

kubernetes · 目录

上一篇DevOps搭建(十五)-kubernetes部署项目详细步骤文章来源地址https://www.toymoban.com/news/detail-792800.html

到了这里,关于DevOps搭建(十六)-Jenkins+K8s部署详细步骤的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Kubernetes(K8s)从入门到精通系列之十六:linux服务器安装minikube的详细步骤

    安装Docker的详细步骤,可以阅读博主下面这篇技术博客文章:

    2024年02月12日
    浏览(2)
  • Vmware虚拟机搭建 K8S ingress Jenkins Gitlab Harbor Docker 一键部署SpringCloud微服务

    本文主要基于Kubernetes1.22.2和Linux操作系统Ubuntu 20.04.6。 操作系统 主机名 IP地址 进程 功能 Ubuntu 20.04.6 k8s-master 192.168.189.128 docker,kube-apiserver,etcd,kube-scheduler,kube-controller-manager,kubelet,kube-proxy,coredns,calico 主节点 Ubuntu 20.04.6 k8s-node1 192.168.189.129 docker,kubelet,kube-proxy,c

    2024年02月03日
    浏览(1)
  • Gitlab+Jenkins+Docker+Harbor+K8s集群搭建CICD平台(持续集成部署Hexo博客Demo)

    目录 涉及内容: 一、CICD服务器环境搭建 1、docker 环境安装 (1)、拉取镜像,启动并设置开机自启 (2)、配置docker加速器 2、安装并配置GitLab (1)、创建共享卷目录 (2)、创建 gitlab 容器 (3)、关闭容器修改配置文件 (4)、修改完配置文件之后。直接启动容器 (5)、相关

    2024年03月15日
    浏览(1)
  • 实践:devops之K8s环境持续部署

    https://www.yuque.com/xyy-onlyone/aevhhf?# 《玩转Typora》 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X2Q6MzL1-1688896509292)(https://bucket-hg.oss-cn-shanghai.aliyuncs.com/img/image-20230709101119001.png)] CI流水线: 下载代码 构建单元测试 代码扫描 构建镜像 更新发布文件

    2024年02月13日
    浏览(1)
  • (详细步骤+各项报错处理)windows11 安装Docker和部署K8S单节点(minikube)

    (1)win11系统(win10应该也可以,但没试过) (2)保证cpu虚拟化开启 (3)主机要留有一定的内存 满足以上即可安装docker desktop版本 (1)获取Docker Desktop并安装Download For Windows(使用了WSL2技术,直接可以在windows上运行,不需要额外的虚拟化环境) (2)开始安装,按照安装向

    2024年02月03日
    浏览(1)
  • k8s 部署 jenkins

    一.前提条件 1.安装helm 二.安装harbor 1.添加harbor helm仓库 helm repo add jenkins https://charts.jenkins.io 2.更新仓库 helm repo update

    2023年04月08日
    浏览(1)
  • Devops系列四(使用argocd部署java应用到k8s容器)

    上文已为我们准备好了以下内容: 制作java应用的docker镜像,并推送至镜像仓库 上传helm yaml代码至gitlab仓库(此gitlab和java应用所在的gitlab可以独立,也可以在一起,但是不宜在同一个工程,所以这里特此区分) 安装k8s和argocd argocd的权限设计和对接ldap(非必须) 本文先梳理出整

    2024年02月13日
    浏览(1)
  • k8s 部署Jenkins项目

    要求:当前集群配置了storageClass,并已指定默认的storageClass,一般情况下,创建的storageClass即为默认类 指定默认storageClass的方式 1.1 部署helm 1.2 部署jenkins 1.3 检查 jenkins 1.4 配置访问 3.1 准备ruoyi数据 3.2 准备k8s证书 3.3 准备maven配置文件 3.4 配置钉钉插件 在系统管理的下方有未

    2024年01月21日
    浏览(2)
  • jenkins部署K8S应用

      PS:这种方式是jenkins独立,然后slave已容器方式运行,master是独立出来的,减少运维成本,还能提高效率。 如果使用master部署需要把master加入k8s集群 jenkins安装不赘述 在k8s-master节点上生成对应的证书 在jenkins里添加凭据 凭据类型选Certificate 上传cert.pfx,输入刚才设置的密码

    2024年02月04日
    浏览(1)
  • k8s的jenkins部署java项目到k8s集群cicd持续集成

    k8s1.16.0-k8s的jenkins部署java项目到k8s集群cicd(ci成,cd手动部署的) 注意: 本文档只是实现了ci,cd是通过ci生成的镜像,再手工再k8s-master执行的部署(只因pod部署的jenkins连接k8s的认证不知怎么操作,若jenkins是单独部署在k8s-master机器上,能直接在master执行kubectl命令就没这个问题了

    2024年02月03日
    浏览(2)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包