k8s mysql主从搭建_k8s部署mysql主从复制

本文档详细介绍了如何在Kubernetes(k8s)集群中搭建MySQL主从复制。首先,通过编写Dockerfile创建master和slave的镜像,接着配置主从复制的用户、密码和权限。然后,将镜像导入k8s镜像库,并创建Deployment和Service文件以部署master和slave。最后,验证主从同步效果。
摘要由CSDN通过智能技术生成

Mysql主从

准备环境

一,准备软件

官方docker_image :Mysql5.7.28

Docker Version:        19.03.4

K8s api-version:        apps/v1

二,具体制作流程

1根据docker-image编写Dockerfile制作mysql-master镜像2.1根据docker-image编写Dockerfile制作mysql-salve镜像

From mysql:latest                                                     #基础镜像

ENV MYSQL_ALLOW_EMPTY_PASSWORD yes  #设置无密码登录

COPY conf.sh /mysql/conf.sh                                  #复制配置文件

COPY set.sql /mysql/set.sql                                  #复制配置文件

CMD ["sh", "/mysql/conf.sh"]                                      #容器启动时执行脚本

2.1配置文件conf.sh

#! /bin/bash

set -e

echo "1,设置mysql_server_ID....."

sed -i '/\[mysqld\]/a server-id=1\nlog-bin=/var/lib/mysql/mysql-bin\ngtid-mode=ON\nenforce-gtid-consistency=ON' /etc/mysql/mysql.conf.d/mysqld.cnf

echo "2.启动MySQL 。。。"

service mysql start

echo "3,设置密码。。。"

sed -i 's/MYSQLROOTPASSWOED/'$MYSQL_ROOT_PASSWORD'/' mysql/set.sql

sed -i 's/MYSQLREPLICATIONPASSWORD/'$MYSQL_REPLICATION_PASSWORD'/' mysql/set.sql

sed -i 's/MYSQLREPLICATIONUSER/'$MYSQL_REPLICATION_USER'/' mysql/set.sql

mysql < /mysql/set.sql

echo "4 service mysql status"

tail -f /dev/null

2.2配置文件set.sql 设置mysql——root密码  创建复制用户及密码

use mysql;

set password for root@'localhost' = password("MYSQLROOTPASSWORD");

grant all on *.* to "MYSQLREPLICATIONUSER"@'%' identified by "MYSQLREPLICATIONPASSWORD" with grant option;

grant all on *.* to 'root'@'%' identified by "MYSQLREPLICATIONPASSWORD" with grant option;

flush privileges;

1.3将三个文件放在同级目录构建mysql-master-image

执行命令

#docker build -t mysql5.7-master:001 .

创建完image后在本地docker环境配置容器看是否有无复制用户

#docker run --name mysql-master -e MYSQL_ROOT_PASSWORD="123456" -e MYSQL_REPLICATION_USER="rep1" -e MYSQL_REPLICATION_PASSWORD="123456" -d mysql5.7-master:01

进入容器>进去mysql>查看用户

#docker exec -it mysql-master bash

2.1根据docker-image编写Dockerfile制作mysql-salve镜像

From mysql:latest                                                     #基础镜像

ENV MYSQL_ALLOW_EMPTY_PASSWORD yes  #设置无密码登录

COPY conf.sh /mysql/conf.sh                                  #复制配置文件

COPY set.sql /mysql/set.sql                                  #复制配置文件

CMD ["sh", "/mysql/conf.sh"]                                      #容器启动时执行脚本

2.1配置文件conf.sh

#! /bin/bash

set -e

echo "1,设置mysql_server_ID....."

sed -i '/\[mysqld\]/a server-id=1\nlog-bin=/var/lib/mysql/mysql-bin\ngtid-mode=ON\nenforce-gtid-consistency=ON' /etc/mysql/mysql.conf.d/mysqld.cnf

echo "2.启动MySQL 。。。"

service mysql start

echo "3,设置密码。。。"

sed -i 's/MYSQLROOTPASSWOED/'$MYSQL_ROOT_PASSWORD'/' mysql/set.sql

sed -i 's/MYSQLREPLICATIONPASSWORD/'$MYSQL_REPLICATION_PASSWORD'/' mysql/set.sql

sed -i 's/MYSQLREPLICATIONUSER/'$MYSQL_REPLICATION_USER'/' mysql/set.sql

mysql < /mysql/set.sql

echo "4 service mysql status"

tail -f /dev/null

2.2配置文件set.sql 设置mysql——root密码  创建复制用户及密码

use mysql;

set password for root@'localhost' = password("MYSQLROOTPASSWORD");

grant all on *.* to 'root'@'%' identified by "MYSQLREPLICATIONPASSWORD" with grant option;

flush privileges;

2.3将三个文件放在同级目录构建mysql-slave-image

执行命令

#docker build -t mysql5.7-slave:001 .

2.4创建完image后在配置slave容器

2.4.1先查看master容器IP

# docker inspect mysql-master | grep IPAddr

2.5创建slave容器

docker run --name mysql-slave -e MYSQL_ROOT_PASSWORD="123456" -e MYSQL_MASTER_SERVICE_HOST="172.17.0.10" -e MYSQL_REPLICATION_USER="rep1" -e MYSQL_REPLICATION_PASSWORD="123456" -d mysql5.7-slave:001

2.6进入容器>进去mysql>slave状态

#docker exec -it mysql-slave bash

三,将所创建mysql-images转入k8s镜像库作为底层pod基础

1 在本地环境docker保存刚刚创建的两个mysql镜像

#docker save -o mysql5.7-master.tar mysql5.7-master:001

#docker save -o mysql5.7-slave.tar mysql5.7-slave:001

2导入至k8s环境

# docker load -i mysql5.7-master.tar

# docker load -i mysql5.7-slave.tar

3编写mysql-master-deploy.yaml

apiVersion: apps/v1                            #版本号

kind: Deployment                               #创建的资源类型

metadata:                                      #该资源的元数据,name必选项

name: mysql-master                           #name描述

spec:                                          #deployment的规格说明

replicas: 1                                  #副本数量

selector:

matchLabels:

name: mysql-master

template:                                   #定义pod的模板,配置文件的重要部分

metadata:                                  #定义pod的元数据,至少定义一个label

labels:

name: mysql-master

track: stable

spec:           #描述pod的规格,定义pod中每个容器的属性,name和image必须

containers:                            #容器描述

- image: mysql5.7-master:001          #镜像来源名字

name: mysql-master

imagePullPolicy: IfNotPresent

ports:

- containerPort: 3306

env:

- name: MYSQL_ROOT_PASSWORD

value: "123456"

- name: MYSQL_REPLICATION_USER

value: "rep1"

- name: MYSQL_REPLICATION_PASSWORD

value: "123456"

4编写mysql-mater-svc.yaml  映射端口为集群:31111

apiVersion: v1

kind: Service

metadata:

name: mysql-master

labels:

name: mysql-master

spec:

type: NodePort

ports:

- port: 3306

targetPort: 3306

nodePort: 31111

protocol: TCP

selector:

name: mysql-master

5编写mysql-slave-deploy.yaml

apiVersion: apps/v1

kind: Deployment

metadata:

name: mysql-slave

spec:

replicas: 3

selector:

matchLabels:

name: mysql-slave

template:

metadata:

labels:

name: mysql-slave

spec:

#      hostNetwork: true

#      endpoint-pod-names: mysql-master

containers:

- name: mysql-slave

image: mysql5.7-slave:001

imagePullPolicy: IfNotPresent

env:

-  name: MYSQL_ROOT_PASSWORD

value: "123456"

-  name: MYSQL_REPLICATION_USER

value: "rep1"

-  name: MYSQL_REPLICATION_PASSWORD

value: "123456"

-  name: MYSQL_MASTER_SERVICE_HOST

value: 192.168.226.183

ports:

- name:

containerPort: 3306

查看pods状态

#kubectl  get pods -o wide

验证 再master创建一张表看slave是否同步

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以按照以下步骤使用Kubernetes(k8s部署MySQL主从架构: 1. 创建一个名为`mysql-pvc.yaml`的持久卷声明(PVC)文件,用于存储MySQL数据。示例文件内容如下: ```yaml apiVersion: v1 kind: PersistentVolumeClaim metadata: name: mysql-pvc spec: accessModes: - ReadWriteOnce resources: requests: storage: 10Gi ``` 2. 创建一个名为`mysql-master.yaml`的MySQL主节点部署文件,示例文件内容如下: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: mysql-master spec: replicas: 1 selector: matchLabels: app: mysql-master template: metadata: labels: app: mysql-master spec: containers: - name: mysql-master image: mysql:latest env: - name: MYSQL_ROOT_PASSWORD value: your_password ports: - containerPort: 3306 volumeMounts: - name: mysql-persistent-storage mountPath: /var/lib/mysql volumes: - name: mysql-persistent-storage persistentVolumeClaim: claimName: mysql-pvc ``` 请替换`your_password`为您要设置的MySQL根密码。 3. 创建一个名为`mysql-slave.yaml`的MySQL从节点部署文件,示例文件内容如下: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: mysql-slave spec: replicas: 2 selector: matchLabels: app: mysql-slave template: metadata: labels: app: mysql-slave spec: containers: - name: mysql-slave image: mysql:latest env: - name: MYSQL_ROOT_PASSWORD value: your_password ports: - containerPort: 3306 volumeMounts: - name: mysql-persistent-storage mountPath: /var/lib/mysql volumes: - name: mysql-persistent-storage persistentVolumeClaim: claimName: mysql-pvc ``` 4. 使用以下命令应用和创建主节点和从节点的部署: ``` kubectl apply -f mysql-pvc.yaml kubectl apply -f mysql-master.yaml kubectl apply -f mysql-slave.yaml ``` 这样就完成了MySQL主从架构的部署。请确保您已经正确配置了Kubernetes环境,并且使用了适当的MySQL镜像和密码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值