k8s搭建MySQL主从同步

env

k8s: v1.28.2
mysql: v8.0.34
  1. 搭建nfs服务器
1. 分别在3台机器上执行安装命令
yum install -y nfs-utils

2. 在主节点创建3个目录,并写入/etc/exports中
mkdir -p /data/nfs/{mysql-master,mysql-slaver-01,mysql-slaver-01}
cat >> /etc/exports << EOF
/data/nfs/mysql-master *(rw,sync,no_root_squash)
/data/nfs/mysql-slaver-01 *(rw,sync,no_root_squash)
/data/nfs/mysql-slaver-02 *(rw,sync,no_root_squash)

3. 开启nfs server服务器
systemctl enable --now nfs-server  // 启动命令,在主节点执行
showmount -e 192.168.10.200  // 检查目录是否暴漏成功,在3台服务器上都可以执行
  1. 创建命名空间
- 命令创建
  kubectl create namespace deploy-test
- yaml文件创建(推荐)
  cat > ./namespace.yaml << EOF
  apiVersion: v1
  kind: Namespace
  metadata:
   name: deploy-test
  spec: {}
  status: {}
  EOF
  1. 创建MySQL密码的secret
kubectl create secret generic mysql-password \
    --namespace=deploy-test \
    --from-literal=mysql_root_password=root \
    --dyr-run=client \
    -o yaml \
    > mysql_root_password_secret.yaml
kubectl apply -f mysql_root_password_secret.yaml  // 执行yaml文件
kubectl get secret -n deploy-test  // 查看创建的secret
  1. 创建master结点的pv和pvc
1. 创建yaml文件
cat > ./master/pv-pvc.yaml << EOF
apiVersion: v1
kind: PersistentVolume
metadata:
  name: deploy-mysql-master-nfs-pv
  namespace: deploy-test
spec:
  capacity: 
    storage: 1Gi
  accessModes:
    - ReadWriteMany
  nfs:
    server: 192.168.10.200
    path: /data/nfs/mysql-master
  storageClassName: nfs
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: deploy-mysql-master-nfs-pvc
  namespace: deploy-test
spec:
  accessModes: 
    - ReadWriteMany
  storageClassName: nfs
  resources:
    requests:
      storage: 1Gi
  volumeName: deploy-mysql-master-nfs-pv
EOF

2. 应用yaml文件
kubectl apply -f ./master/pv-pvc.yaml

3. 查看pv, pvc
kubectl get pv,pvc -n deploy-test
  1. 为主节点准备一个配置文件
cat > ./master/my.cnf << EOF
[mysqld]
skip-host-cache
skip-name-resolve
datadir = /var/lib/mysql
socket = /var/run/mysqld/mysqld.sock
secure-file-priv = /var/lib/mysql-files
pid-file = /var/run/mysqld/mysqld.pid
user = mysql
secure-file-priv = NULL
server-id = 1
log-bin = master-bin
log_bin_index = master-bin.index
binlog_do_db = xiaohh_user
binlog_ignore_db = information_schema
binlog_ignore_db = mysql
binlog_ignore_db = performance_schema
binlog_ignore_db = sys
binlog-format = ROW

[client]
socket = /var/run/mysqld/mysqld.sock

!include /etc/mysql/conf.d/
EOF
  1. 根据第5步的配置文件,创建一个ConfigMap存储这个配置文件
1. 使用kubectl生成yaml配置文件
kubectl create configmap mysql-master-cm \
    -n deploy-test \
    --from-file=./master/my.cnf \
    --dry-run=client \
    -o yaml \
    > ./master/mysql-master.yaml
    
2. 继续补充这个yaml文件
cat >> ./master/mysql-master.yaml << EOF
---
apiVersion: v1
kind: Service
metadata:
  name: deploy-mysql-master-svc
  namespace: deploy-test
  labels: 
    app: mysql-master
spec:
  ports:
  - port: 3306
    name: mysql
    targetPort: 3306
    nodePort: 30306
  selector:
    app: mysql-master
  type: NodePort
  sessionAffinity: ClientIP
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: deploy-mysql-master
  namespace: deploy-test
spec:
  selector: 
    matchLabels:
      app: mysql-master
  serviceName: "deploy-mysql-master-svc"
  replicas: 1
  template:
    metadata:
      labels:
        app: mysql-master
    spec: 
      terminationGracePeriodSeconds: 10
      containers:
      - args:
        - --character-set-server=utf8mb4
        - --collation-server=utf8mb4_unicode_ci
        - --lower_case_table_names=1
        - --default-time_zone=+8:00
        name: mysql
        image: docker.io/library/mysql:8.0.34
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-data
          mountPath: /var/lib/mysql
        - name: mysql-conf
          mountPath: /etc/my.cnf
          readOnly: true
          subPath: my.cnf
        env: 
        - name: MYSQL_ROOT_PASSWORD
          valueFrom: 
            secretKeyRef:
              key: mysql_root_password
              name: mysql-password
      volumes:
      - name: mysql-data
        persistentVolumeClaim:
          claimName: deploy-mysql-master-nfs-pvc
      - name: mysql-conf
        configMap:
          name: mysql-master-cm
          items: 
          - key: my.cnf
            mode: 0644
            path: my.cnf
EOF
  1. 应用此配置文件
kubectl apply -f ./master/mysql-master.yaml
  1. 查看应用状态
kubectl get all -o wide -n deploy-test
  1. 进入容器查看
kubectl exec -itn deploy-test pod/deploy-mysql-master-0 -- mysql -u root -p 
  1. 在MySQL交互式环境中,验证logbin是否成功
show master status;

在这里插入图片描述
11. 为第一个从节点创建pv,pvc

1. 新建slave-01文件夹
mkdir slave-01

2. 创建pv-pvc.yaml
cat > ./slave-01/pv-pvc.yaml << EOF
apiVersion: v1
kind: PersistentVolume
metadata:
  name: deploy-mysql-slave-01-nfs-pv
  namespace: deploy-test
spec:
  capacity:
    storage: 1Gi
  accessModes:
  - ReadWriteMany
  nfs:
    server: 192.168.10.200
    path: /data/nfs/mysql-slaver-01
  storageClassName: "nfs"
  
---

apiVersion: v1
kind: PersistentVolumeClaim
metadata: 
  name: deploy-mysql-slave-01-nfs-pvc
  namespace: deploy-test
spec:
  accessModes:
  - ReadWriteMany
  storageClassName: "nfs"
  resources:
    requests:
      storage: 1Gi
  volumeName: deploy-mysql-slave-01-nfs-pv
EOF

3. 应用pv-pvc.yaml文件
kubectl apply -f slave-02/pv-pvc.yaml
  1. 创建./slave-01/my.cnf文件
cat > ./slave-01/my.cnf << EOF
[mysqld]
skip-host-cache
skip-name-resolve
datadir = /var/lib/mysql
socket = /var/run/mysqld/mysqld.sock
secure-file-priv = /var/lib/mysql-files
pid-file = /var/run/mysqld/mysqld.pid
user = mysql
secure-file-priv = NULL
server-id = 2
log-bin = slave-bin
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index

[client]
socket = /var/run/mysqld/mysqld.sock

!includedir /etc/mysql/conf.d/
EOF
  1. 根据上一步创建的文件生成configmap的yaml文件
kubectl create configmap mysql-slave-01-cm \
    -n deploy-test \
    --from-file=./slave-01/my.cnf \
    --dry-run=client \
    -o yaml \
    > ./slave-01/mysql-slave-01.yaml
  1. 补充上一步创建的yaml文件
cat >> ./slave-01/mysql-slave-01.yaml << EOF
---
apiVersion: v1
kind: Service
metadata:
  name: deploy-mysql-slave-svc
  namespace: deploy-test
  labels: 
    app: mysql-slave
spec:
  ports:
  - port: 3306
    name: mysql
    targetPort: 3306
    nodePort: 30308
  selector:
    app: mysql-slave
  type: NodePort
  sessionAffinity: ClientIP
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: deploy-mysql-slave-01
  namespace: deploy-test
spec:
  selector:
    matchLabels:
      app: mysql-slave
  serviceName: "deploy-mysql-slave-svc"
  replicas: 1
  template:
    metadata:
      labels:
        app: mysql-slave
    spec:
      terminationGracePeriodSeconds: 10
      containers:
      - args:
        - --character-set-server=utf8mb4
        - --collation-server=utf8mb4_unicode_ci
        - --lower_case_table_names=1
        - --default-time_zone=+8:00
        name: mysql
        image: docker.io/library/mysql:8.0.34
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-data
          mountPath: /var/lib/mysql
        - name: mysql-conf
          mountPath: /etc/my.cnf
          readOnly: true
          subPath: my.cnf
        env:
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              key: mysql_root_password
              name: mysql-password
      volumes:
      - name: mysql-data
        persistentVolumeClaim:
          claimName: deploy-mysql-slave-01-nfs-pvc
      - name: mysql-conf
        configMap:
          name: mysql-slave-01-cm
          items:
          - key: my.cnf
            mode: 0644
            path: my.cnf
EOF
  1. 应用上一步生成的yaml文件
1. 应用yaml文件
kubectl apply -f slave-01/mysql-slave-01.yaml

2. 查看状态
kubectl get all -o wide -n deploy-test
  1. 为第二个从节点创建pv, pvc
1. 创建slave-02文件夹
mkdir slave-02

2. 创建pv-pvc.yaml
cat > ./slave-02/pv-pvc.yaml << EOF
apiVersion: v1
kind: PersistentVolume
metadata:
  name: deploy-mysql-slave-02-nfs-pv
  namespace: deploy-test
spec:
  capacity:
    storage: 1Gi
  accessModes:
  - ReadWriteMany
  nfs:
    server: 192.168.10.200
    path: /data/nfs/mysql-slaver-02
  storageClassName: "nfs"
  
---

apiVersion: v1
kind: PersistentVolumeClaim
metadata: 
  name: deploy-mysql-slave-02-nfs-pvc
  namespace: deploy-test
spec:
  accessModes:
  - ReadWriteMany
  storageClassName: "nfs"
  resources:
    requests:
      storage: 1Gi
  volumeName: deploy-mysql-slave-02-nfs-pv
EOF

3. 应用pv-pvc.yaml文件
kubectl apply -f slave-01/pv-pvc.yaml
  1. 创建./slave-02/my.cnf
cat > ./slave-02/my.cnf << EOF
[mysqld]
skip-host-cache
skip-name-resolve
datadir = /var/lib/mysql
socket = /var/run/mysqld/mysqld.sock
secure-file-priv = /var/lib/mysql-files
pid-file = /var/run/mysqld/mysqld.pid
user = mysql
secure-file-priv = NULL
server-id = 3
log-bin = slave-bin
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index

[client]
socket = /var/run/mysqld/mysqld.sock

!includedir /etc/mysql/conf.d/
EOF
  1. 根据上一步创建的文件生成configmap的yaml文件
kubectl create configmap mysql-slave-02-cm \
    -n deploy-test \
    --from-file=./slave-02/my.cnf \
    --dry-run=client \
    -o yaml \
    > ./slave-02/mysql-slave-02.yaml
  1. 补充上一步创建的yaml文件
cat >> ./slave-02/mysql-slave-02.yaml << EOF
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: deploy-mysql-slave-02
  namespace: deploy-test
spec:
  selector:
    matchLabels:
      app: mysql-slave
  serviceName: "deploy-mysql-slave-svc"
  replicas: 1
  template:
    metadata:
      labels:
        app: mysql-slave
    spec:
      terminationGracePeriodSeconds: 10
      containers:
      - args:
        - --character-set-server=utf8mb4
        - --collation-server=utf8mb4_unicode_ci
        - --lower_case_table_names=1
        - --default-time_zone=+8:00
        name: mysql
        image: docker.io/library/mysql:8.0.34
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-data
          mountPath: /var/lib/mysql
        - name: mysql-conf
          mountPath: /etc/my.cnf
          readOnly: true
          subPath: my.cnf
        env:
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              key: mysql_root_password
              name: mysql-password
      volumes:
      - name: mysql-data
        persistentVolumeClaim:
          claimName: deploy-mysql-slave-02-nfs-pvc
      - name: mysql-conf
        configMap:
          name: mysql-slave-02-cm
          items:
          - key: my.cnf
            mode: 0644
            path: my.cnf
EOF
  1. 应用slave-02/mysql-slave-02.yaml
kubectl apply -f slave-02/mysql-slave-02.yaml
  1. 登录到两个从节点的MySQL
kubectl exec -itn deploy-test pod/pod/deploy-mysql-slave-01-0 -- mysql -uroot -p
kubectl exec -itn deploy-test pod/pod/deploy-mysql-slave-02-0 -- mysql -uroot -p
  1. 在两个从节点分别执行主从同步的命令
1. 设置主从同步的参数
// master_host = pod name + service name + namespace + '.svc.cluster.local'
change master to \
    master_host='deploy-mysql-master-0.deploy-mysql-master-svc.deploy-test.svc.cluster.local', \
    master_port=3306, \
    master_user='root', \
    master_password='root', \
    master_log_file='master-bin.000003', \
    master_log_pos=157, \
    master_connect_retry=30, \
    get_master_public_key=1;
   
2. 开启主从同步 
start slave;

3.查看节点状态
show master status; // 主节点
show slave status\G; // 从节点
  1. 验证主从同步
在主节点创建数据库xiaohh_user;
创建数据表
插入数据
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值