首页 > 其他分享 >03 K8S API资源对象介绍02(Deployment Service DaemonSet StatefulSet)

03 K8S API资源对象介绍02(Deployment Service DaemonSet StatefulSet)

时间:2023-10-16 20:35:20浏览次数:37  
标签:02 03 StatefulSet name kubectl redis nfs provisioner ds

一、API 资源对象Deployment

Deployment YANL示例

vim nginx-deploy.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: myng
  name: ng-deploy
spec:
  replicas: 2 ##副本数
  selector:
    matchLabels:
      app: myng
  template:
    metadata:
      labels:
        app: myng
    spec:
      containers:
        - name: myng
          image: nginx:1.25.2
          ports:
          - name: myng-port
            containerPort: 80

使用YAML创建deploy:

# kubectl  apply -f nginx-deploy.yaml 
deployment.apps/ng-deploy created

查看:

# kubectl  get deploy |grep  ng
ng-deploy   2/2     2            2           72s
nginxdp     1/1     1            1           36h
#  kubectl  get pod |grep deploy
ng-deploy-7b7ff4f9bc-d2g65   1/1     Running   0              103s
ng-deploy-7b7ff4f9bc-s27c9   1/1     Running   0              103s

查看pod分配到哪个节点

# kubectl  get po -o wide |grep deploy
ng-deploy-7b7ff4f9bc-d2g65   1/1     Running   0                 2m59s   10.244.154.21    node-1-233   <none>           <none>
ng-deploy-7b7ff4f9bc-s27c9   1/1     Running   0                 2m59s   10.244.167.155   node-1-231   <none>           <none>

二、API资源对象Service

Service检查(svc)YAML示例:

vim ng-svc.yaml

apiVersion: v1
kind: Service
metadata:
  name: ngx-svc
spec:
  selector:
    app: myng
  ports:
  - protocol: TCP
    port: 8080  ##service的port
    targetPort: 80  ##pod的port

使用YAML创建service:

# kubectl  apply -f ng-svc.yaml 
service/ngx-svc created

查看:

# kubectl  get svc |grep ngx
ngx-svc      ClusterIP   10.97.206.107   <none>        8080/TCP       20s

三种Service类型

1)ClusterIP

该方式为默认类型,默认不用定义type字段。

spec:
  selector:
    app: myng
  type: ClusterIP
  ports:
  - protocol: TCP
    port: 8080  #service的port
    targetPort: 80  #pod的port

2)NodePort

如果想直接通过k8s节点的IP访问service对应的资源,可使用NodePort,NodePort对应的端口范围:30000-32767

spec:
  selector:
    app: myng
  type: NodePort
  ports:
  - protocol: TCP
    port: 8080  #service的port
    targetPort: 80  #pod的port
    nodePort: 30009  #可以自定义,也可以不定义,它会自动获取一个端口

3)LoadBlancer

该方式需要配合公有云资源实现(比如:阿里云、腾讯云),需要一个公网IP作为入口,然后来负载均衡所有Pod

spec:
  selector:
    app: myng
  type: LoadBlancer
  ports:
  - protocol: TCP
    port: 8080  #service的port
    targetPort: 80  #pod的port

三、API资源对象DaemonSet

有些场景需要在每个Node上运行Pod(比如flannel插件、calico日志搜集程序),Deployment无法做到,而Daemonet(简称ds)可以。Daemonset目标是在集群的每一个节点只运行Pod。

Daemonset不支持使用kubectl create获取YAML模板,其实Daemonset和Deployment的差异很小,除了kind不一样,还需要去掉replica配置

vi  ds-demo.yaml

apiVersion: apps/v1
kind: DaemonSet
metadata:
  labels:
    app: ds-demo
  name: ds-demo
spec:
  selector:
    matchLabels:
      app: ds-demo
  template:
    metadata:
      labels:
        app: ds-demo
    spec:
      containers:
        - name: ds-demo
          image: nginx:1.23.2
          ports:
          - name: mysql-port
            containerPort: 80

使用YAML创建ds

# kubectl apply -f ds-demon.yaml 
daemonset.apps/ds-demo created

 查看

# kubectl  get ds
NAME      DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR   AGE
ds-demo   3         3         3       3            3           <none>          77s
# kubectl  get po
NAME                         READY   STATUS    RESTARTS      AGE
ds-demo-6vt22                1/1     Running   0             80s
ds-demo-tl86h                1/1     Running   0             80s
ds-demo-vmsr9                1/1     Running   0             80s
ng-deploy-7b7ff4f9bc-d2g65   1/1     Running   0             22m
ng-deploy-7b7ff4f9bc-s27c9   1/1     Running   0             22m
nginxdp-7cf46d7445-8x6gs     1/1     Running   1 (12h ago)   36h
testpod                      1/1     Running   1 (12h ago)   25h

 但是没有在master上启动,默认master 有限制

# kubectl get node
NAME           STATUS   ROLES           AGE   VERSION
master-1-230   Ready    control-plane   18d   v1.27.6
node-1-231     Ready    <none>          18d   v1.27.6
node-1-232     Ready    <none>          18d   v1.27.6
node-1-233     Ready    <none>          11d   v1.27.6
# kubectl  describe node master-1-230 |grep -i "taint"
Taints:             node-role.kubernetes.io/control-plane:NoSchedule

说明:Taints叫污点,如果一个节点上有污点,则不会被调度运行pod。

但是这取决于Pod的一个属性:yoleration(容忍),即这个Pod是否能容忍目标节点是否有污点。

为解决此问题,可以在Pod上增加toleration属性。修改YAML配置如下:

# cat -n ds-demon.yaml 
     1	apiVersion: apps/v1
     2	kind: DaemonSet
     3	metadata:
     4	  labels:
     5	    app: ds-demo
     6	  name: ds-demo
     7	spec:
     8	  selector:
     9	    matchLabels:
    10	      app: ds-demo
    11	  template:
    12	    metadata:
    13	      labels:
    14	        app: ds-demo
    15	    spec:
    16	      tolerations:
    17	        - key: node-role.kubernetes.io/control-plane
    18	          effect: NoSchedule
    19	      containers:
    20	        - name: ds-demo
    21	          image: nginx:1.23.2
    22	          ports:
    23	          - name: mysql-port
    24	            containerPort: 80

再次运行YAML

# kubectl  apply -f ds-demon.yaml 
daemonset.apps/ds-demo configured

验证

# kubectl get ds
NAME      DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR   AGE
ds-demo   4         4         3       1            3           <none>          9m13s
# kubectl  get po  -o wide
NAME                         READY   STATUS    RESTARTS      AGE    IP               NODE           NOMINATED NODE   READINESS GATES
ds-demo-57qcd                1/1     Running   0             86s    10.244.167.157   node-1-231     <none>           <none>
ds-demo-jzlpn                1/1     Running   0             87s    10.244.154.23    node-1-233     <none>           <none>
ds-demo-m8cmz                1/1     Running   0             84s    10.244.29.38     node-1-232     <none>           <none>
ds-demo-sfqnt                1/1     Running   0             112s   10.244.183.193   master-1-230   <none>           <none>
ng-deploy-7b7ff4f9bc-d2g65   1/1     Running   0             31m    10.244.154.21    node-1-233     <none>           <none>
ng-deploy-7b7ff4f9bc-s27c9   1/1     Running   0             31m    10.244.167.155   node-1-231     <none>           <none>
nginxdp-7cf46d7445-8x6gs     1/1     Running   1 (12h ago)   36h    10.244.154.20    node-1-233     <none>           <none>
testpod                      1/1     Running   1 (12h ago)   25h    10.244.167.153   node-1-231     <none>           <none>

四、API资源对象StatefulSet

Pod根据是否有数据存储分为有状态和无状态:

  • 无状态:指Pod运行期间会不会产生重要数据,即使有数据产生,这些数据丢失也不影响整个应用。比如Nginx,Tomcat等应用适合无状态。
  • 有状态:指Pod运行期间会产生重要数据,这些数据必须持久化,比如MySql、RedisRabbitMQ

Deployment和Daemonset适合做无状态,而有状态就是Statefulset(简称sts)

说明StatefulSet涉及数据持久化,用的StorageClass。需要先创建一个基于NFS的StorageClass

4.1 在master节点搭建NFS

NFS服务器IP地址为192.168.1.230,共享目录为/data/nfs

安装nfs

yum install -y nfs-utils nfs-server rpcbind

创建共享目录,启动nfs服务

#mkdir -p /data/nfs
#echo "/data/nfs/ *(insecure,rw,sync,no_root_squash)" >> /etc/exports
# echo "/data/nfs/ *(insecure,rw,sync,no_root_squash)" >> /etc/exports
# cat /etc/exports
/data/nfs/ *(insecure,rw,sync,no_root_squash)

#systemctl enable rpcbind
#systemctl enable nfs-server
#systemctl start rpcbind
#systemctl start nfs-server

 nfs 配置生效命令:exportfs -r

4.2 安装SC

使用NFS的sc需要安装NFS provisioner,可以自动创建NFS的pv。使用gitee 导入 https://github.com/kubernetes-sigs/nfs-subdir-external-provisioner

下载源代码

# git clone https://gitee.com/ikubernetesi/nfs-subdir-external-provisioner.git
正克隆到 'nfs-subdir-external-provisioner'...
remote: Enumerating objects: 7784, done.
remote: Counting objects: 100% (7784/7784), done.
remote: Compressing objects: 100% (3052/3052), done.
remote: Total 7784 (delta 4443), reused 7784 (delta 4443), pack-reused 0
接收对象中: 100% (7784/7784), 8.44 MiB | 1.57 MiB/s, done.
处理 delta 中: 100% (4443/4443), done.
# cd nfs-subdir-external-provisioner/deploy/
# sed -i 's/namespace: default/namespace: kube-system/' rbac.yaml
# kubectl  apply  -f rbac.yaml 
serviceaccount/nfs-client-provisioner created
clusterrole.rbac.authorization.k8s.io/nfs-client-provisioner-runner created
clusterrolebinding.rbac.authorization.k8s.io/run-nfs-client-provisioner created
role.rbac.authorization.k8s.io/leader-locking-nfs-client-provisioner created
rolebinding.rbac.authorization.k8s.io/leader-locking-nfs-client-provisioner created

 修改deployment.yaml

sed -i 's/namespace: default/namespace: kube-system/' deployment.yaml ##修改命名空间为kube-system

 修改nfs-subdir-external-provisioner镜像仓库和nfs地址

cat deployment.yaml
 # cat deployment.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nfs-client-provisioner
  labels:
    app: nfs-client-provisioner
  # replace with namespace where provisioner is deployed
  namespace: default
spec:
  replicas: 1
  strategy:
    type: Recreate
  selector:
    matchLabels:
      app: nfs-client-provisioner
  template:
    metadata:
      labels:
        app: nfs-client-provisioner
    spec:
      serviceAccountName: nfs-client-provisioner
      containers:
        - name: nfs-client-provisioner
          image: registry.cn-hangzhou.aliyuncs.com/kavin1028/nfs-subdir-external-provisioner:v4.0.2
          #image: registry.k8s.io/sig-storage/nfs-subdir-external-provisioner:v4.0.2
          volumeMounts:
            - name: nfs-client-root
              mountPath: /persistentvolumes
          env:
            - name: PROVISIONER_NAME
              value: k8s-sigs.io/nfs-subdir-external-provisioner
            - name: NFS_SERVER
              value: 192.168.1.230
            - name: NFS_PATH
              value: /data/nfs
      volumes:
        - name: nfs-client-root
          nfs:
            server: 192.168.1.230
            path: /data/nfs

 应用YAML

# kubectl  apply -f deployment.yaml 
deployment.apps/nfs-client-provisioner created
# kubectl  apply -f class.yaml 
storageclass.storage.k8s.io/nfs-client created

 SC YAML示例

# cat class.yaml 
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: nfs-client
provisioner: k8s-sigs.io/nfs-subdir-external-provisioner # or choose another name, must match deployment's env PROVISIONER_NAME'
parameters:
  archiveOnDelete: "false"

 sts 示例

vim redis-sts.yaml

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: redis-sts

spec:
  serviceName: redis-svc ##这里要有一个serviceName,Sts必须和service关联

  volumeClaimTemplates:
  - metadata:
      name: redis-pvc
    spec:
      storageClassName: nfs-client
      accessModes:
        - ReadWriteMany
      resources:
        requests:
          storage: 500Mi

  replicas: 2
  selector:
    matchLabels:
      app: redis-sts

  template:
    metadata:
      labels:
        app: redis-sts
    spec:
      containers:
      - image: redis:6.2
        name: redis
        ports:
        - containerPort: 6379

        volumeMounts:
        - name: redis-pvc
          mountPath: /data

vi  redis-svc.yaml

apiVersion: v1
kind: Service
metadata:
  name: redis-svc

spec:
  selector:
    app: redis-sts

  ports:
  - port: 6379
    protocol: TCP
    targetPort: 6379

 应用YAML 文件

# kubectl apply -f redis-sts.yaml -f redis-svc.yaml
statefulset.apps/redis-sts created
service/redis-svc created

 对于Sts的Pod,有如下特点:

  1. Pod名固定有序,后缀从0开始
  2. 域名固定,格式为:Pod名.Svc名,例如 redis-sts-0.redis-svc
  3. 每个Pod对应的PVC也是固定

验证:

ping 域名

#kubectl exec -it redis-sts-0 -- bash   ##进去可以ping redis-sts-0.redis-svc 和  redis-sts-1.redis-svc
## apt-get update
# apt-get install iputils-ping  -y

 

 

创建key

kubectl exec -it redis-sts-0 -- redis-cli
127.0.0.1:6379> set name 'zhang san'
OK
127.0.0.1:6379> set age '18'
OK

 

模拟故障

删除后,它会自动重新创建同名Pod,再次进入查看redis key

kubectl exec -it redis-sts-0 -- redis-cli
127.0.0.1:6379> get name
"zhangsan"
127.0.0.1:6379> get age
"18"

 数据没有丢失

标签:02,03,StatefulSet,name,kubectl,redis,nfs,provisioner,ds
From: https://www.cnblogs.com/pythonlx/p/17766242.html

相关文章

  • 20231016-日记
    距离CSP还有5天上午-模拟赛总结T1-魔力子串考虑对于每个右端点找到它能匹配的状态,使用前缀和思想以方便统计.这里我们定义"状态"为前缀的各个字母的数量,减去最少得字母数量,经过化简,我们一定可以从前面相同的状态直接转移过来.因此可以开一个巨大的map,里面存的结......
  • 2023跟我一起学docker-swarm 教程:部署篇「上」
    2023跟我一起学docker-swarm教程:部署篇「上」Swarm模式是用于管理一组Docker守护程序的高级功能。ip规划:Manager:Manager:172.16.95.137Node1:172.16.95.138Node2:172.16.95.1391、manager节点初始化swarmdockerswarminit--advertise-addr172.16.95.137输出:dockerswar......
  • 2023跟我一起学docker-swarm 教程:部署篇「下」
    2023跟我一起学docker-swarm教程:部署篇「下」停止Swarm集群上的一个节点目前我们所有的节点都ACTIVE的状态运行的,master可以将任务分配给任何节点,所以所有的节点都可以接收到任务。很多时候我们需要维护应用的时候,您需要将节点设置为DRAIN可用性。DRAIN状态的节点Maser阻止此类......
  • 2023/10/16 学习笔记
    网络层协议与解析网络层的功能: 定义了基于IP协议的逻辑地址  连接不同的媒介类型 选择数据通过网络的最佳路径IP数据包格式: 注解:版本(4) 指IP协议版本。并且通过双方使用的版本必须一致,目前我们使用的是ipv4,表示为0100十进制是4首部长度(4) IP数据包的包头长......
  • 20231016打卡
    上午的课程是铁道技术认知。在这门课上,我们学习了铁道的基础知识,包括受电弓、道岔变道器等。通过老师的讲解和课堂讨论,我们对铁道的运行和设备有了更深入的了解。在课程中,我们还通过虚拟仿真系统在计算机上学习了如何具体进行变轨操作和模拟动车组的运行。此外,通过沙盘的实际操作,......
  • 设计模式02 —— UML
    设计模式02——UML本教程参考:菜鸟教程-学的不仅是技术,更是梦想!(runoob.com)参考书:《图解设计模式》本系列为本人学习笔记,和课程学习笔记,资料和参考均源自互联网,希望各位大佬多多指点!UML的概念UML的全称是UndefinedModelingLanguage(统一建模语言)是让系统可视化,让规格......
  • 从嘉手札<2023-10-16>
    一、商君书1)更法商鞅和甘龙、杜挚同秦孝公商量变法。后两者认为变法会动移已有的社会结构,“圣人不易民而教,知者不变法而治”“法古无过,循礼无邪”但商鞅(公孙鞅)认为,三代不同礼而亡,五霸不同法而霸,知者作法,愚者制焉。“夫常人安于故习,学者溺于所闻”“反古者未必可非,循礼者未足......
  • 云原生周刊:CNCF 宣布 Cilium 毕业 | 2023.10.16
    开源项目推荐ReloaderReloader是一个Kubernetes控制器,用于监控ConfigMap和Secrets中的变化,并对Pod及其相关部署、StatefulSet、DaemonSet和DeploymentConfig进行滚动升级!SpegelSpegel在瑞典语中意为镜像,是一种无状态集群本地OCI注册镜像。Spegel使Kubernete......
  • 2023年第四季数据治理认证DAMA-CDGA/CDGP认证开始备考
    DAMA认证为数据管理专业人士提供职业目标晋升规划,彰显了职业发展里程碑及发展阶梯定义,帮助数据管理从业人士获得企业数字化转型战略下的必备职业能力,促进开展工作实践应用及实际问题解决,形成企业所需的新数字经济下的核心职业竞争能力。DAMA是数据管理方面的认证,帮助数据从业者提升......
  • 2023年10月NPDP产品经理国际认证开始备考啦
    产品经理国际资格认证NPDP是新产品开发方面的认证,集理论、方法与实践为一体的全方位的知识体系,为公司组织层级进行规划、决策、执行提供良好的方法体系支撑。 【认证机构】 产品开发与管理协会(PDMA)成立于1979年,是全球范围内产品开发与管理专业人士最杰出的倡导者,协助个人、企业或......