在Kubernetes (K8s) 集群中部署一个Mysql一主两从的集群,可以使用StatefulSet来保证每个Mysql实例的状态,并使用ConfigMap来管理Mysql配置文件。以下是一个简化版的部署示例:
- 创建ConfigMap:
apiVersion: v1
kind: ConfigMap
metadata:
name: mysql-config
data:
my.cnf: |
[mysqld]
log-bin
server-id=1
- 创建StatefulSet:
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mysql
spec:
selector:
matchLabels:
app: mysql
serviceName: "mysql"
replicas: 3
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:5.7
env:
- name: MYSQL_ROOT_PASSWORD
value: my-secret-pw
ports:
- containerPort: 3306
name: mysql
volumeMounts:
- name: mysql-persistent-storage
mountPath: /var/lib/mysql
- name: mysql-config
mountPath: /etc/mysql/conf.d
volumeClaimTemplates:
- metadata:
name: mysql-persistent-storage
spec:
accessModes: [ "ReadWriteOnce" ]
resources:
requests:
storage: 10Gi
在这个示例中,我们定义了一个包含三个副本的StatefulSet,每个Mysql实例都使用持久化存储和配置。server-id
将被设置为从1开始的序列号,每个实例的log-bin
都会基于这个序列号配置。
要创建这些资源,只需将它们保存为YAML文件,然后使用kubectl
命令应用到你的K8s集群即可。
kubectl apply -f mysql-config.yaml
kubectl apply -f mysql-statefulset.yaml
在部署之后,你需要配置Mysql从实例以连接到主实例并启动复制过程。这通常涉及到在从实例上执行CHANGE MASTER TO
命令,并启动复制进程。这些步骤可以通过脚本或手动进行。
注意:这个示例是一个简化的部署,并且没有包括任何安全配置,如TLS/SSL加密或网络策略。在生产环境中,你需要添加额外的安全措施。