美文网首页
使用Deployment运行单实例有状态应用

使用Deployment运行单实例有状态应用

作者: AEGQ | 来源:发表于2018-04-17 15:24 被阅读19次

    第一步: 创建 service、pvc、deployment

    # cat mysql-deployment.yml
    
    apiVersion: v1
    kind: Service
    metadata:
      name: mysql
    spec:
      ports:
      - port: 3306
      selector:
        app: mysql
      clusterIP: None  # 创建Headless services,DNS直接解析service的name为POD的IP, 当service只有一个pod时,这种方式最简单。
    
    ---
    apiVersion: v1
    kind: PersistentVolumeClaim # 创建的前提是有可用的PV。
    metadata:
      name: mysql-pv-claim
    spec:
      accessModes:
        - ReadWriteOnce   # 申请能在一个节点上进行读写的数据卷
      resources:
        requests:
          storage: 20Gi
    ---
    apiVersion: apps/v1 # for versions before 1.9.0 use apps/v1beta2
    kind: Deployment
    metadata:
      name: mysql
    spec:
      selector:
        matchLabels:
          app: mysql
      strategy:
        type: Recreate # 因为底层数据卷不支持多pod同时读写,所以先stop第一个pod,才创建新的。
      template:
        metadata:
          labels:
            app: mysql
        spec:
          containers:
          - image: mysql:5.6
            name: mysql
            env:
              # Use secret in real usage
            - name: MYSQL_ROOT_PASSWORD
              value: password
            ports:
            - containerPort: 3306
              name: mysql
            volumeMounts:
            - name: mysql-persistent-storage
              mountPath: /var/lib/mysql
          volumes:
          - name: mysql-persistent-storage
            persistentVolumeClaim:
              claimName: mysql-pv-claim
    
    $ kubectl create -f ./mysql-deployment.yml
    

    第二步: 测试部署成功

    # 这里可以直接通过service的name访问POD
    $ kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -h mysql -ppassword
    

    相关文章

      网友评论

          本文标题:使用Deployment运行单实例有状态应用

          本文链接:https://www.haomeiwen.com/subject/mxtpkftx.html