zoukankan      html  css  js  c++  java
  • 第十五章 kubernetes 部署有状态应用

    一、概念

    有状态:db 如果mysql的主从,必须是远程的存储,在任意节点都可以挂载恢复之前的状态,而且还有网络ID唯一,从得知道主的地址,pod是短暂的,新的就会换IP,得保证这个IP能一直在使用
    
    无状态:web 比如部署2个副本,跟其他没啥直接的关系,本地也没有需要持久化的数据,其中有一个副本挂了,其他节点起来仍然可以提供服务没有影响
    
    K8S适合访问波动大、版本迭代快的、弹性伸缩的
    

    二、特点

    #1.无状态应用(Deployment)
    1)认为Pod都是一样的
    2)没有顺序要求
    3)不用考虑在那个node运行
    4)随意进行伸缩和扩展
    
    #2.有状态应用
    1)上面因素都需要考虑到
    2)让每个Pod独立的,保持Pod启动顺序和唯一性
    3)唯一的网络标识符,持久存储
    4)有序性,比如mysql主从
    

    三、Headless Service

    kubernates中还有一种service类型:headless serivces功能,字面意思无头service其实就是该service对外无提供IP,即ClusterIP: none。一般用于对外提供域名服务的时候。
    
    [root@kubernetes-master-001 ~]# vim headless-service.yaml 
    kind: Service
    apiVersion: v1
    metadata:
      name: nginx
      labels:
        app: nginx
    spec:
      clusterIP: None
      selector:
        app: nginx
      ports:
        - port: 80
          targetPort: 80
          name: web
    ---
    
    apiVersion: apps/v1
    kind: StatefulSet
    metadata:
      name: nginx-statefulset
      namespace: default
    spec:
      serviceName: nginx
      replicas: 3
      selector:
        matchLabels:
          app: nginx
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
          - name: nginx
            image: nginx:latest
            ports:
            - containerPort: 80
            
    [root@kubernetes-master-001 ~]# kubectl apply -f headless-service.yaml
    service/nginx created
    statefulset.apps/nginx-statefulset created
    
    [root@kubernetes-master-001 ~]# kubectl  get  svc,pods
    NAME                 TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
    service/kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP        3d2h
    service/nginx        ClusterIP   None             <none>        80/TCP         3m3s
    service/web          ClusterIP   10.100.37.233    <none>        80/TCP         47h
    service/web1         NodePort    10.103.214.171   <none>        80:32023/TCP   47h
    
    NAME                       READY   STATUS    RESTARTS   AGE
    pod/nginx-statefulset-0    1/1     Running   0          2m36s
    pod/nginx-statefulset-1    1/1     Running   0          119s
    pod/nginx-statefulset-2    1/1     Running   0          97s
    pod/web-5bb6fd4c98-54ll2   1/1     Running   0          47h
    pod/web-5bb6fd4c98-585rn   1/1     Running   0          47h
    

    四、statefulset(简称sts)

    官方文档:https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/
    StatefulSet与Deployment区别:statefulset是有身份的(唯一标识的)
    
    身份三要素: • 域名 • 主机名 • 存储(PVC)
    
    #1.主机名 + 按照一定规则生成域名
    每个pod有唯一主机名
    唯一域名:
    格式: 主机名称.service.名称空间.svc.cluster.local
    
    ClusterIP A记录格式: ..svc.cluster.local
    ClusterIP=None A记录格式: .
    ..svc.cluster.local
    举例:nginx-statefulset-0.nginx.default.svc.cluster.local
    
  • 相关阅读:
    Jquery超简单遮罩层实现代码
    java中Token验证
    基于Token的WEB后台认证机制
    jsp页面数据回显(select下拉选择框)
    ckeditor 绑定事件
    ckeditor 触发事件(案例)
    Linux sed命令学习
    字符串 全排列生成问题
    算法导论第九章 第K顺序统计量
    字符串相似度算法 递归与动态规划求解分析
  • 原文地址:https://www.cnblogs.com/jhno1/p/15607481.html
Copyright © 2011-2022 走看看