k8s部署mysql主从复制
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是否同步
k8s部署mysql主从复制的更多相关文章
- 2.快速部署MySQL主从复制
1.快速部署MySQL主从复制 [root@mysql ~]# mysql -uroot -p123456 -S /data/3307/mysql.sock -e "show slave ...
- k8s部署mysql数据持久化
在这里我部署mysql的目的是为了后面将上一篇博客docker打包的el-admin镜像部署到k8s上,所以本文主要是部署mysql并实现持久化. 1.将我们的应用都部署到 el-admin 这个命名 ...
- centos7下部署mysql主从复制
首先大致看一下这个图 环境说明: 系统:centos7 IP:master:192.168.7.235 slave:192.168.7.226 mysql版本MySQL-5.7 1.Master 下载 ...
- 安装部署MySQL主从复制
Environment:{ CentOS 7 两台 安装MySQL(mariadb mariadb-server) } !!!关闭防火墙SELinux 1.查看版本信息 2.启动mysql服务,查 ...
- docker 容器模式下部署mysql 主从复制
1.计划用两台host来部署,分别部署一台 mysql,一主一从,2.配置好主从mysql配置文件,更改文件名即可[client]port = 3306socket = /var/run/mysqld ...
- 使用docker部署mysql主从复制集群
一.环境搭建 虚拟机环境:centos7 IP: 启动3个容器,一个是master,端口是3307,另外两个是slaver,端口是3308和3309 docker pull mysql:5.7 doc ...
- Kubernetes 部署Mysql 主从复制集群
Mysql主从参考文章: https://www.jianshu.com/p/509b65e9a4f5 http://blog.51cto.com/ylw6006/2071864 Statefulse ...
- Ubuntu 16.04下使用docker部署MySQL主从复制
(以下docker相关的命令,需要在root用户环境下或通过sudo提升权限来进行操作.) 首先更新 软件源 https://mirrors.tuna.tsinghua.edu.cn/help/ubu ...
- MySQL主从复制原理及配置详细过程以及主从复制集群自动化部署的实现
一.复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重 ...
随机推荐
- P2569 [SCOI2010]股票交易 dp 单调队列优化
LINK:股票交易 题目确实不算难 但是坑点挺多 关于初值的处理问题我就wa了两次. 所以来谢罪. 由于在手中的邮票的数量存在限制 且每次买入卖出也有限制. 必然要多开一维来存每天的邮票数量. 那么容 ...
- Android JNI之数据类型
JNI中数据类型的意义在于桥接Java数据类型与C数据类型. 简单数据类型: Java Type Native Type Description boolean jboolean unsigned 8 ...
- 【02python基础-函数,类】
1.函数中的全局变量与局部变量全局变量:在函数和类定义之外声明的变量.作用域为定义的模块,从定义位置开始到模块结束.全局变量降低了函数的通用性和可读性,要尽量避免全局变量的使用.全局边个两一般作为常量 ...
- Android menu菜单的深入了解。。。
今天补充刚开始的菜单控件,这是基于: https://www.cnblogs.com/aolong/p/12868015.html 里面的菜单写的. 今天学的后面部分是结合昨天的Fragment一起的 ...
- 操作属性、操作样式 - DOM编程
1. 操作属性 1.1 HTML 属性与 DOM 属性的对应 <div> <label for="username">User Name: </lab ...
- Eclipse变得很卡
半个月前,发现Eclipse很卡很卡,尤其在按住Ctrl选择方法的实现类的时候,电脑的反应速度让开发者无法忍受. Eclipse还经常未响应状态. 开始以为Eclipse的运行内存设置小了,把ecli ...
- sftp与ftp的区别
SFTP和FTP非常相似,都支持批量传输(一次传输多个文件),文件夹/目录导航,文件移动,文件夹/目录创建,文件删除等.但还是存在着差异,下面我们来看看SFTP和FTP之间的区别. 1. 安全通道FT ...
- 2020-07-26:如何用 socket 编程实现 ftp 协议?
福哥答案2020-07-26: 功能用户输入user username.pass password注册,注册后输入dir查看服务器文件列表,输入get filename path下载文件到指定路径. ...
- C#LeetCode刷题之#40-组合总和 II(Combination Sum II)
目录 问题 示例 分析 问题 该文章已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3666 访问. 给定一个数组 candidates ...
- 使用 VMware Workstation Pro 让 PC 提供云桌面服务——学习笔记(一)
最终效果: 能够通过xshell等终端设备, 远程访问虚拟机 操作步骤 1. 安装VMware 网上自行下载VMware 软件,这里不给出详细操作 2. 下载安装系统 这里使用 Centos 的lin ...