【云原生】Jenkins集成Kubernetes详解

举报
陈橘又青 发表于 2022/09/28 15:44:03 2022/09/28
【摘要】 一. Jenkins集成Kubernetes 1.1 准备部署的yml文件apiVersion: apps/v1kind: Deploymentmetadata: namespace: test name: pipeline labels: app: pipelinespec: replicas: 2 selector: matchLabels: app: ...

一. Jenkins集成Kubernetes

1.1 准备部署的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.11.102:80/repo/pipeline:v4.0.0
        imagePullPolicy: Always
        ports:
        - containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:
  namespace: test
  labels:
    app: pipeline
  name: pipeline  
spec:
  selector:
    app: pipeline
  ports:
  - port: 8081
    targetPort: 8080
  type: NodePort
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  namespace: test
  name: pipeline
spec:
  ingressClassName: ingress
  rules:
  - host: mashibing.pipeline.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: pipeline
            port:
              number: 8081

1.2 Harbor私服配置

在尝试用kubernetes的yml文件启动pipeline服务时,会出现Kubernetes无法拉取镜像的问题,这里需要在kubernetes所在的Linux中配置Harbor服务信息,并且保证Kubernetes可以拉取Harbor上的镜像。

设置Master和Worker的私服地址信息:

设置Harbor私服地址
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rUCVaRkc-1661176293454)(Pictures/1642498962716.png)]

在Kuboard上设置私服密文信息:

设置密文并测试
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c6CtzKz9-1661176293455)(Pictures/1642498994935.png)]

按照复制指令的位置测试认证,效果如下:

测试效果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-b2Slq7bV-1661176293456)(Pictures/1642499172789.png)]

1.3 测试使用效果

执行kubectl命令,基于yml启动服务,并且基于部署后服务的提示信息以及Ingress的设置,直接访问:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0mfcqFjw-1661176293456)(Pictures/1642499368121.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qTOeBtip-1661176293457)(Pictures/1642499788199.png)]

1.4 Jenkins远程调用

将pipeline.yml配置到Gitlab中:

配置yml文件
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j4FThVQQ-1661176293457)(Pictures/1642499885324.png)]

配置Jenkins的目标服务器,可以将yml文件传输到K8s的Master上:

设置目标服务器
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kaF8b7an-1661176293458)(Pictures/1642499992148.png)]

修改Jenkinsfile,重新设置流水线任务脚本,并测试效果:

传递yml文件脚本
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R6QQXAj3-1661176293459)(Pictures/1642500061153.png)]
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IbYU8K1d-1661176293459)(Pictures/1642500102996.png)]](https://img-blog.csdnimg.cn/ff4e58a338ba47b385bebfd0cfde9de6.png

设置Jenkins无密码登录k8s-master。

将Jenkins中公钥信息复制到k8s-master的~/.ssh/authorized_keysz中,保证远程连接无密码:

远程执行命令无需密码
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mSlLF6qQ-1661176293460)(Pictures/1642500239406.png)]

设置执行kubectl的脚本到Jenkinsfile:

设置Jenkinsfile
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qdh1SWHA-1661176293461)(Pictures/1642500378788.png)]

执行查看效果:

执行流水线
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j4xjDzJR-1661176293461)(Pictures/1642500413802.png)]

可以查看到yml文件是由变化的, 这样k8s就会重新加载

查看效果:

效果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mUZV4ppZ-1661176293462)(Pictures/1642500474036.png)]
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。