statefulset部署mysql主从

一。主要参考官网任务:

运行一个有状态的应用程序 | Kubernetes

但有一个问题是,无法下载image: gcr.io/google-samples/xtrabackup:1.0

也可以使用 lank8s.cn,他们的对应关系 k8s.gcr.io –> lank8s.cn,gcr.io –> gcr.lank8s.cn

docker pull gcr.lank8s.cn/google-samples/xtrabackup:1.0

二。创建config map、secret

apiVersion: v1
kind: ConfigMap
metadata:
  name: mysql
  namespace: mysql
  labels:
    app: mysql
data:
  master.cnf: |
    [mysqld]
    log-bin=mysqllog
    skip-name-resolve    
  slave.cnf: |
    [mysqld]
    super-read-only
    skip-name-resolve
    log-bin=mysql-bin
    replicate-ignore-db=mysql  

apiVersion: v1
kind: Secret
metadata:
  name: mysql-secret
  namespace: mysql
  labels:
    app: mysql
type: Opaque
data:
  password: MTIzNDU2 # echo -n "123456" | base64

 三。创建pv

使用local-storage本地存储类

kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
  name: local-storage
provisioner: kubernetes.io/no-provisioner
volumeBindingMode: WaitForFirstConsumer

预先在每个节点上创建目录/mnt/statefulset/mysql

创建pv,节点亲和配置为每个节点的名称,pod生成后pv将绑定到每个节点

apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv
spec:
  capacity:
    storage: 5Gi
  volumeMode: Filesystem
  accessModes:
  - ReadWriteOnce
  persistentVolumeReclaimPolicy: Delete
  storageClassName: local
Kubernetes环境下高效部署MySQL主从集群,可参考以下步骤: ### 准备工作 若没有安装Kubernetes集群环境或者不了解Kubernetes容器,可参考【Kubernetes的系列笔记】汇总:https://blog.weiyigeek.top/2018/1-1-1.html#Kubernetes学习之路汇总 [^1]。 ### 部署ConfigMap 创建配置文件 `mysql-configmap.yaml`,内容如下: ```yaml apiVersion: v1 kind: ConfigMap metadata: name: mysql labels: app: mysql data: primary.cnf: | # Apply this config only on the primary. [mysqld] log-bin replica.cnf: | # Apply this config only on replicas. [mysqld] super-read-only ``` 执行以下命令应用配置: ```bash [root@cp mysql]# kubectl apply -f mysql-configmap.yaml ``` 通过以下命令查看ConfigMap: ```bash [root@cp mysql]# kubectl get cm ``` 预期输出结果类似: ``` NAME DATA AGE mysql 2 5s ``` [^2] ### 创建MySQL镜像 使用修改好的Dockerfile创建MySQL master和slave镜像: ```bash # 构建master镜像 cd /root/kubernetes/lnmp/mysql/Dockerfiles/Master docker build -t registry.fjhb.cn/mysql-master:0.1 . # 构建slave镜像 cd /root/kubernetes/lnmp/mysql/Dockerfiles/Slave docker build -t registry.fjhb.cn/mysql-slave:0.1 . # 推送镜像 docker push registry.fjhb.cn/mysql-master:0.1 docker push registry.fjhb.cn/mysql-slave:0.1 ``` [^4] ### 部署主从集群 使用K8s StatefulSet部署MySQL主从集群,利用 `initContainers` 实现主从配置自动切换,`volumeClaimTemplates` 为每个Pod动态创建PVC,建议使用8.0+版本 [^3]。 ### 验证主从同步 ```bash # 进入主节点写数据 kubectl exec -it mysql-0 -n mysql -- mysql -uroot -p123456 mysql> CREATE DATABASE test; mysql> USE test; mysql> CREATE TABLE data (id INT); # 进入从节点查数据 kubectl exec -it mysql-1 -n mysql -- mysql -uroot -p123456 -e "SHOW DATABASES;" ``` [^3]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值