您当前的位置:首页 > 网站建设 > 网站维护
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery |

Kubernetes安装Jenkins的思路详解

51自学网 2022-07-22 18:47:03
  网站维护

环境

生产实践-k8s安装Jenkins和Jenkins Kubernetes插件
环境要求:你需要一个正常可以使用的Kubernetes集群,集群中可以使用的内存大于等于4G。
Kubernetes版本1.18

思路

Jenkins插件可以在Kubernetes集群中运行动态jenkins-slave代理。

基于Kubernetes的docker,自动化在Kubernetes中运行的Jenkins-slave代理的缩放。

该插件为每个jenkins-slave代理创建Kubernetes Pod,并在每个构建后停止它。

在Kubernetes中jenkins-slave代理启动,会自动连接到Jenkins主控制器。 对于某些环境变量,会自动注入:

Jenkins_URL:Jenkins Web界面URL
jenkins_secret:身份验证的秘密密钥
jenkins_agent_name:jenkins代理的名称
jenkins_name:jenkins代理的名称(已弃用。仅用于向后兼容性)
不需要在Kubernetes内运行Jenkins Controller。

1、NFS(动态存储)

#安装yum install -y nfs-utils rpcbindmkdir -p /data/nfsdata # 修改配置$ vim /etc/exports/data/nfsdata 192.168.31.* (rw,async,no_root_squash) # 使配置生效$ exportfs -r # 服务端查看下是否生效$ showmount -e localhost Export list for localhost:/data/nfsdata (everyone)

2、helm安装nfs-client

stable       	https://kubernetes.oss-cn-hangzhou.aliyuncs.com/chartshelm添加这个源
下载helm包helm pull aliyuncs/nfs-client-provisioner解压tar -zxvf nfs-client-provisioner-1.2.8.tgz修复values.yaml 三处image:  repository: quay.io/external_storage/nfs-client-provisioner  tag: v3.1.0-k8s1.11  pullPolicy: IfNotPresentnfs:  server: 192.168.31.73  path: /data/nfsdata  reclaimPolicy: Retain

3、创建namespace

kubectl create namespace jenkinskubectl get namespaces

4、持久化Jenkins数据

pvc.yaml

 apiVersion: v1kind: PersistentVolumeClaimmetadata:  name: jenkins-pvc  namespace: jenkinsspec:  storageClassName: "nfsdata"  accessModes:    - ReadWriteMany  resources:    requests:      storage: 10Gi

通过kubectl部署volume

kubectl apply -f pvc.yaml

5、创建service account

创建pod时,如果不指定服务账户,则会自动为其分配一个名为default的同一namespace中的服务账户。但是通常应用程序时存在权限不足的情况,所以需要我们自己创建一个服务账户。
①下载jenkins-sa.yaml

wget https://raw.githubusercontent.com/jenkins-infra/jenkins.io/master/content/doc/tutorials/kubernetes/installing-jenkins-on-kubernetes/jenkins-sa.yaml

②通过kubectl部署jenkins-sa.yaml

kubectl apply -f jenkins-sa.yaml

或者使用下面的文件

jenkins-sa.yaml

 ---apiVersion: v1kind: ServiceAccountmetadata:  name: jenkins  namespace: jenkins---apiVersion: rbac.authorization.k8s.io/v1kind: ClusterRolemetadata:  annotations:    rbac.authorization.kubernetes.io/autoupdate: "true"  labels:    kubernetes.io/bootstrapping: rbac-defaults  name: jenkinsrules:- apiGroups:  - '*'  resources:  - statefulsets  - services  - replicationcontrollers  - replicasets  - podtemplates  - podsecuritypolicies  - pods  - pods/log  - pods/exec  - podpreset  - poddisruptionbudget  - persistentvolumes  - persistentvolumeclaims  - jobs  - endpoints  - deployments  - deployments/scale  - daemonsets  - cronjobs  - configmaps  - namespaces  - events  - secrets  verbs:  - create  - get  - watch  - delete  - list  - patch  - update- apiGroups:  - ""  resources:  - nodes  verbs:  - get  - list  - watch  - update---apiVersion: rbac.authorization.k8s.io/v1kind: ClusterRoleBindingmetadata:  annotations:    rbac.authorization.kubernetes.io/autoupdate: "true"  labels:    kubernetes.io/bootstrapping: rbac-defaults  name: jenkinsroleRef:  apiGroup: rbac.authorization.k8s.io  kind: ClusterRole  name: jenkinssubjects:- apiGroup: rbac.authorization.k8s.io  kind: Group  name: system:serviceaccounts:jenkins

6、安装Jenkins

jenkins-deployment.yaml

apiVersion: apps/v1kind: Deploymentmetadata:  name: jenkins  namespace: jenkinsspec:  replicas: 1  selector:    matchLabels:      app: jenkins  template:    metadata:      labels:        app: jenkins    spec:      serviceAccountName: jenkins   #指定我们前面创建的服务账号      containers:      - name: jenkins        image: registry.cn-hangzhou.aliyuncs.com/s-ops/jenkins:2.346        ports:        - containerPort: 8080        - containerPort: 50000        volumeMounts:        - name: jenkins-home          mountPath: /var/jenkins_home      volumes:      - name: jenkins-home        persistentVolumeClaim:          claimName: jenkins-pvc     #指定前面创建的PVC

通过kubectl部署jenkins-deployment.yaml

kubectl create -f jenkins-deployment.yaml -n jenkins

7、授权对Jenkins服务的访问权限

主要目的暴露外部访问Jenkins的8080端口,我将31400定义为8080的映射端口。

jenkins-service.yaml

apiVersion: v1kind: Servicemetadata:  name: jenkins  namespace: jenkinsspec:  type: NodePort  ports:  - name: http    port: 8080    targetPort: 8080    nodePort: 31400  - name: agent    port: 50000    targetPort: 50000    nodePort: 31401  selector:    app: jenkins

通过kubectl部署服务

kubectl create -f jenkins-service.yaml -n jenkins

8、打开浏览器IP:31400/

查看密码

kubectl get pod -n jenkins  //查询podnamekubectl logs podname -n jenkins ************************************************************* Jenkins initial setup is required. An admin user has been created and a password generated.Please use the following password to proceed to installation: cf8d9da9de0346fd90461be366915d76 This may also be found at: /var/jenkins_home/secrets/initialAdminPassword *************************************************************

选择推荐插件安装,创建管理员~完成!


下载地址:
关于CVE-2020-1983:Tomcat
Ubuntu下搭建与配置Nginx服务
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1