以下是一个示例的Kubernetes部署MySQL集群的YAML文件:

apiVersion: v1
kind: Service
metadata:
  name: mysql-service
spec:
  ports:
    - port: 3306
  selector:
    app: mysql
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: mysql
spec:
  serviceName: mysql-service
  replicas: 3
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
        - name: mysql
          image: mysql:5.7
          env:
            - name: MYSQL_ROOT_PASSWORD
              value: password
          ports:
            - containerPort: 3306
              name: mysql-port
          volumeMounts:
            - name: mysql-data
              mountPath: /var/lib/mysql
      volumes:
        - name: mysql-data
          emptyDir: {}

在上述示例中,我们定义了一个Service和一个StatefulSet。Service用于将流量路由到MySQL集群中的任何一个Pod,而StatefulSet则用于部署和管理MySQL的Pod。

在StatefulSet的定义中,我们指定了服务名称、副本数、选择器和模板。模板中定义了一个MySQL容器,使用了官方的MySQL 5.7镜像,并设置了MySQL的root密码。我们还将MySQL数据目录挂载到了一个空目录卷上,以确保数据持久化。

请注意,这只是一个示例,实际的部署可能需要根据你的需求进行调整

k8s部署mysql集群 yaml

原文地址: https://www.cveoy.top/t/topic/hYhT 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录