msyql 24day 数据库主从 主从复制 读写分离 master slave 有数据如何增加

目录

  • 环境介绍
    • 读写分离
    • 纵向扩展
    • 横向扩展
  • 数据库主从
    • 准备环境
    • 主库环境(master)
    • 从库配置(slave)
    • 状态分析
    • 重新配置
    • 问题分析 报错解决
    • 从库验证
  • 有数据的情况下 去做主从
    • 清理环境
    • 环境准备
    • 数据库中的锁的机制
    • 主库配置
    • 从库配置
    • 最后给主库解锁
    • 常见错误

环境介绍

将一个数据库的数据 复制到另外一个 或者多个

master 主库

slave 从库
在这里插入图片描述
在这里插入图片描述

主库开了一个二进制日志

从库开了两个线程

LO可以是多线程(快) 请求二进制文件

SQL 线程 执行sql 语句

读写分离

所有写入的数据 在主库上写 所有读取在从库上读取

纵向扩展

一台不行 用两台

横向扩展

提升一台服务器的配置

数据库主从

准备环境

  • 关闭防火墙
  • 关闭selinx
  • 固定IP
  • 配置dns 在目录 /etc/hosts 文件中
  • 开启 bin_log 咱文件 /etc/my.cnf
  • 在主库中授权用户
# 防火墙
systemctl stop firewalld# 关闭selinx
getenforce
setenforce 0# 固定IP
vim /etc/sysconfig/network-scripts/ifcfg-ens33 rm -rf /etc/sysconfig/network-scripts/.cfg-ens33.swp
修改参数
BOOTPROTO=static
----------------------------------------------------------------
IPADDR={ip}
PREFIX=24
GATEWAY={网关地址}
DSN1={dns地址}
DSN1={dns地址}
----------------------------------------------------------------
参考
IPADDR=10.12.155.146
PREFIX=24
GATEWAY=10.12.155.254
DNS1=223.5.5.5
DNS2=223.6.6.6----------------------------------------------------------------
# 参考实例
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=static
DEFROUTE=yes
NAME=ens33
DEVICE=ens33
ONBOOT=yes
IPADDR=192.168.100.203
PREFIX=24
GATEWAY=192.168.100.2
DNS1=223.5.5.5
DNS2=223.6.6.6
----------------------------------------------------------------# 重启
systemctl restart network# 修改主机名
hostnamectl set-hostname  master# 主机名解析
涉及到几个ip  就要写多少个
实例
vim  /etc/host
192.168.100.203 master
192.168.100.203 slave10.12.155.146 master
10.12.155.120 slave# 清理环境
# 卸载包
yum -y erase `rpm -qa | egrep "mysql|mariadb"`# 删除配置文件
rm -rf /etc/my* && rm -rf /var/lib/mysql && rm -rf /usr/bin/mysql# 检查
[[ ! -f /etc/my.cnf ]] && [[ ! -d /var/lib/mysql ]] && [[ ! -f /usr/bin/mysql ]] && echo "环境已经清理完成" || echo "环境未清理"# 安装mysql
yum -y install mysql-server...
## 本地安装
cd  解压包路径 
yum -y localinstall  *# 修改密码
## 查看密码
awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log
## 修改密码为@Baipiao123
mysqladmin -uroot -p"`awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log`" password '@Baipiao123'

主库环境(master)

## 创建二进制文件目录
mkdir /data
chown mysql.mysql /data# 开启二进制日志
vim /etc/my.cnf
写在[mysqld] 标识下边 写道其他表示下边 就不生效了
server-id=203
log-bin=/data/mysql-binsystemctl restart mysqld# 授权一个账号(开启一个复制权限)msyql> grant replication slave on *.* to 'master'@'%' identified by '{密码}'
msyql> grant replication slave on *.* to 'master'@'%' identified by '@Baipiao123';
mysql> flush privileges;
# 查看当前binlog 日志文件用的哪个 以及post 
msyql> show master status\G## 重新设置 设置轮转日志
mysql> reset master;

在这里插入图片描述

从库配置(slave)

# 从库配置
vim /etc/my.cnf
server-id=204
# 重启数据
systemctl restart mysqld# 主机名解析
10.12.155.146 master
10.12.155.120 slave可以使用 ? change master to  来查看语法
# 配置信息
change master to
master_host ={解析的dns名},
master_port=3306,   // 这里是端口号
master_user='{刚刚授权的用户名}', 
master_password='{刚刚授权的密码}',
master_log_file=mysql-bin.000001,  //bin_log 文件名字 不懂请看下图
master_pos=154;   //二进制日志 开始位置
master_connect_retry=10;  //十秒刷新## 实例
CHANGE MASTER TOMASTER_HOST='master',MASTER_USER='king',MASTER_PASSWORD='@Baipiao123',MASTER_PORT=3306,MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=145,MASTER_CONNECT_RETRY=10;# 启动slave
msyql> start slave;# 产看状态
msyql>show slave status\GLO 和 SQL 都是yes  则说明配置成功# 如果uuid 一样的话
cat /var/lib/mysql/auto.cnf

在这里插入图片描述

状态分析

## 14 15行。两个YES表示主从成功
## 关注39-42的信息
## 38行表示主从复制延迟时间
## 46 行UUID要不一致mysql> show slave status\G 
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: masterMaster_User: relicationMaster_Port: 3306Connect_Retry: 10Master_Log_File: mysql-bin.000001Read_Master_Log_Pos: 154Relay_Log_File: slave-relay-bin.000002Relay_Log_Pos: 320Relay_Master_Log_File: mysql-bin.000001Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0Last_Error: Skip_Counter: 0Exec_Master_Log_Pos: 154Relay_Log_Space: 527Until_Condition: NoneUntil_Log_File: Until_Log_Pos: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 203Master_UUID: 6f6d0551-a073-11ee-9f28-000c298a6e96Master_Info_File: /var/lib/mysql/master.infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Slave has read all relay log; waiting for more updatesMaster_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: 
1 row in set (0.00 sec)

重新配置

如果配置出错了 才需要从这里开始 重新配置

mysql>stop slave;
mysql> reset slave;
mysql>CHANGE MASTER TOMASTER_HOST='master',MASTER_USER='master',MASTER_PASSWORD='@Baipiao123',MASTER_PORT=3306,MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=154,MASTER_CONNECT_RETRY=10;
## 启动slave
mysql>start slave;
# 产看状态
msyql>show slave status\G;

在这里插入图片描述

问题分析 报错解决

  • ip 地址 错误
  • dns 没有配置
  • ip配置
  • 用户名密码
  • 二进制文件配置
  • UUID 一样 也会导致 失败

从库验证

最好在主库中写一下 再去 从库中看一下

# master_sql 在主库中写入如下内容
create database king;
create table king.t1(id int,myname varchar(40));
insert into king.t1 values (1,"king");# clave_sql 在从库中查看写入的内容
show databases;use king;select * from king.t1;要往主库(master)里边写,如果写在从库,则会导致主键冲突

有数据的情况下 去做主从

清理环境

此步骤是测试步骤 实战请跳过此处

yum -y erase `rpm -qa | egrep "mysql|mariadb"`# 删除配置文件
rm -rf /etc/my* && rm -rf /var/lib/mysql && rm -rf /usr/bin/mysqlrm -rf /data/*# 检查
[[ ! -f /etc/my.cnf ]] && [[ ! -d /var/lib/mysql ]] && [[ ! -f /usr/bin/mysql ]] && echo "环境已经清理完成" || echo "环境未清理"# 安装mysql
yum -y install mysql-server...
## 本地安装
cd  解压包路径 
yum -y localinstall  *## 启动数据库
systemctl start mysqld# 修改密码
## 查询密码
awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log## 修改密码
mysqladmin -uroot -p"`awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log`" password '@Baipiao123'## 登录数据库
mysql -p"@Baipiao123"

环境准备

这里是模拟数据库中原有的数据

create database king;create table king.t1(id int, myname varchar(40));insert into king.t1 values (1,"aaa"),(2,"bbb"),(3,"cccc"),(4,"dddd"),(5,"eee");select * from king.t1;

数据库中的锁的机制

读锁

​ 可以查询。

写锁

​ 读写都不能执行。

主库配置

# 锁表备份## 备份文件为 all.sql
mysqldump -uroot -p{密码} -A > all.sql
mysqldump -uroot -p"@Baipiao123" -A > all.sql## 配置主从
### 创建必要目录
mkdir /data
chown mysql.mysql /data### 修改配置文件
vim /etc/my.cnf
server-id = 203
log-bin= /data/mysql-bin### 重启数据库
systemctl restart mysqld### 授权slave 用户
mysql> grant replication slave on {}.{} to "{用户名}"@"%" identified by "{密码}"
#### 实例
mysql> grant replication slave on *.* to "king"@"%" identified by "@Baipiao123";## 上一个读锁 ()  到这里之后就不要动了  把这个窗口挂在这里mysql> flush tables with read lock;-----------------------------------------------------------------------------------------------
# 再重新开一个窗口进行如下操作### 重置bin_log
mysql> flush  privileges;
### 查看主库 信息 已经bin_log 位置
mysql> show master status\G;

在这里插入图片描述
在这里插入图片描述

从库配置

## 传输数据
scp  {备份文件.sql} {从库服务器}## 导入数据
mysql -uroot -p{密码} < {备份文件}mysql -uroot -p"@Baipiao123" < all.sql#配置从
vim /etc/my.cnf
在文件中写入下方内容 号码随意 不是1 就行
server-id = 204# 重启数据库
systemctl restart mysqld# 主机名解析
vim  /etc/host
{主库服务器ip} master
{从库服务器ip} slave##实例
192.168.100.203 master
192.168.100.203 slave# 进入数据库 配置从库
mysql -uroot -p"@Baipiao123"## 查看格式 (show master to;)CHANGE MASTER TOMASTER_HOST='master',MASTER_USER='king',MASTER_PASSWORD='@Baipiao123',MASTER_PORT=3306,MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=720,MASTER_CONNECT_RETRY=10;## 启动从库
mysql> start slave; 
## 查看主从信息
mysql>  show slave status\G;

最后给主库解锁

配置完成之后 我们的主数据库 还是锁着的
这个时候就需要 给主数据库解锁了 (就是哪个 刚开始 主服务器 挂在哪里的窗口)

可以直接退出数据库

也可以使用命令来解锁

unlock tables;

在这里插入图片描述

常见错误

如果出现这些错误编号则可能是如下错误

1062 主从重复, 也就是说 从库插入了重复的数据 则可以跳过 具体还是需要做好分析 
vim /etc/my.cnf
slave-skip-errors=10621053  主服务器宕机1045  账号密码错误 导致的链接错误

完结撒花
🌸🌸🌸 自强不息,不忘初心🌸🌸🌸
🌸🌸🌸 承蒙厚爱,不负佳人🌸🌸🌸

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/239708.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器raid中磁盘损坏或下线造成阵列降级更换新硬盘重建方法

可能引起磁盘阵列硬盘下线或故障的情况&#xff1a; 硬件故障&#xff1a; 硬盘物理损坏&#xff1a;包括但不限于坏道、电路板故障、磁头损坏、盘片划伤、电机故障等。连接问题&#xff1a;如接口损坏、数据线或电源线故障、SATA/SAS控制器问题等。热插拔错误&#xff1a;在不…

****Linux下Mysql的安装和配置

1、安装mysql 1.1、安装mysql sudo aptitude search mysql sudo apt-get install mysql-server mysql-client1.2、启动停止mysql: service mysql stop service mysql restart mysql -u debian-sys-maint -p mysql命令详细解释如下: 一、 启动方式 1、使用 service 启动…

20Exchange第一轮空投延续铭文热-Meme热潮褪去后的选择

“凌晨1点打iotx铭文&#xff0c;凌晨2点打Tia铭文&#xff0c;凌晨3点打inj铭文&#xff0c;凌晨4点 打op铭文……”这个在社交网络上广为转发的贴文&#xff0c;浓缩了Web3用户对铭文市场的狂热。 从12月开始&#xff0c;铭文这种比特币等区块链网络铸造加密资产&#xff08…

从0到1部署gitlab自动打包部署项目

本文重点在于配置ci/cd打包 使用的是docker desktop 第一步安装docker desktop Docker简介 Docker 就像一个盒子&#xff0c;里面可以装很多物件&#xff0c;如果需要某些物件&#xff0c;可以直接将该盒子拿走&#xff0c;而不需要从该盒子中一件一件的取。Docker中文社区、…

npm run dev 与npm run serve的区别

npm run serve 和 npm run dev 是在开发阶段使用 npm 运行脚本的两种常见命令&#xff0c;它们的区别主要在于脚本的配置和执行方式。 npm run serve&#xff1a;通常与 Vue.js 相关的项目中使用。这个命令是在 package.json 文件中定义的一个脚本命令&#xff0c;用来启动开发…

零基础制作宠物用品小程序

随着人们对宠物用品的需求不断增长&#xff0c;越来越多的人开始探索如何制作一个专业的宠物用品小程序。而乔拓云作为一款功能强大的在线商城制作工具&#xff0c;成为了许多商家的首选。本文将详细介绍如何使用乔拓云制作宠物用品小程序&#xff0c;让你轻松上手&#xff0c;…

集合论:二元关系(1)

集合论这一章内容很多&#xff0c;重点是二元关系中关系矩阵&#xff0c;关系图和关系性质:自反、反自反、对称、反对称、传递以及关系闭包的运算&#xff0c;等价关系&#xff0c;偏序关系&#xff0c;哈斯图&#xff0c;真吓人&#xff01; 1.笛卡儿积 由两个元素x和y按照一…

MongoDB聚合管道的限制

MongoDB聚合管道功能非常丰富且强大&#xff0c;能够实现各种复杂的聚合查询和数据处理&#xff0c;我们在利用强大功能的同时&#xff0c;也需要了解其限制和约束&#xff0c;这样才能在系统设计时做到用其长避其短。聚合管道的限制主要有几个方面&#xff0c;分别是结果结果、…

伽马校正:FPGA

参考资料&#xff1a; Tone Mapping 与 Gamma Correction - 知乎 (zhihu.com) Book_VIP: 《基于MATLAB与FPGA的图像处理教程》此书是业内第一本基于MATLAB与FPGA的图像处理教程&#xff0c;第一本真正结合理论及算法加速方案&#xff0c;在Matlab验证&#xff0c;以及在FPGA上…

Debezium发布历史21

原文地址&#xff1a; https://debezium.io/blog/2017/10/26/debezium-0-6-1-released/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Debezium 0.6.1 发布 2017 年 10 月 26 日 作者&#xff1a; Gunnar Morl…

为实例方法创建错误的引用(js的问题)

考虑下面代码&#xff1a; var MyObject function() {}MyObject.prototype.whoAmI function() {console.log(this window ? "window" : "MyObj"); };var obj new MyObject(); 现在&#xff0c;为了操作方便&#xff0c;我们创建一个对whoAmI方法的引…

【开源工程及源码】超级经典开源项目实景三维数字孪生智慧机场

智慧机场可视化平台通过可视化手段&#xff0c;将复杂的机场运营数据以图形、图表等形式展现&#xff0c;使管理者能够更直观、实时地了解机场的各个方面。飞渡科技通过整合物联网IOT、人工智能、大数据分析等技术&#xff0c;围绕机场管理、运控、安防、服务、监测等业务领域&…

Java设计模式-原型模式

目录 一、克隆羊问题 二、传统方式解决 三、基本介绍 四、浅拷贝和深拷贝 &#xff08;一&#xff09;浅拷贝介绍 &#xff08;二&#xff09;深拷贝 五、原型模式深拷贝 &#xff08;一&#xff09;重写clone方法 &#xff08;二&#xff09;对象序列化 六、注意事项…

理解计算机中的中断与中断处理

计算机系统是一个高度并发的环境&#xff0c;处理各种任务和事件。为了有效地响应硬件和软件引起的特殊事件&#xff0c;计算机引入了一种叫做中断的机制。 什么是中断&#xff1f; 中断是一种通知机制&#xff0c;用于向计算机处理器表示发生了特殊事件&#xff0c;需要处理器…

扩展检测和响应:零信任安全的核心要素

面对不断增长的攻击面&#xff0c;扩展和增强威胁检测和响应能力是XDR在安全功效方面的主要结果。这一成果不仅有助于全面保护&#xff0c;而且有助于更好地实施零信任安全。 默认情况下&#xff0c;这种方法不信任任何用户或任何设备&#xff0c;只允许访问需要的资源。为了更…

【OCR识别】PaddleHub实现验证码识别

文章目录 前言无脑安装使用PaddleHub寻找预训练模型库完整代码效果图 前言 前面有篇文章介绍了 【网站验证码识别】 &#xff0c;但是其是利用 tesseract 工具的命令行来实现图片内容的识别。 这几天我突然想起&#xff0c;大学时参加百度 AI 比赛用过其 PaddleHub 框架&…

软考高级难度排行榜,哪个科目相对较容易呢?

面对软考的5大高级科目&#xff0c;你是不是也想知道哪个科目相对较“容易”一些呢&#xff1f;今天&#xff0c;让我们一起来看看吧 软考高级科目岗位描述 首先&#xff0c;大家可以看一下官方发布的《计算机技术与软件专业技术资格(水平)考试岗位设置与岗位描述》中有关软考…

Kubectl 部署无状态应用

基本概念 无状态服务 无状态服务不会在本地存储持久化数据。多个服务实例对于同一个用户请求的响应结果是完全一致的。这种多服务实例之间是没有依赖关系&#xff0c;比如web应用&#xff0c;在k8s控制器中动态启停无状态服务的pod并不会对其它的pod产生影响。 有状态服务 有状…

Web自动化测试工具的优势分析

Web自动化测试工具在现代软件开发中扮演着关键的角色&#xff0c;帮助团队确保Web应用程序的质量和稳定性。然而&#xff0c;选择合适的Web自动化测试工具对项目的成功至关重要。本文将介绍Web自动化测试工具优势是什么! 1. 自动化执行 Web自动化测试工具能够模拟用户的行为&am…

基于博弈树的开源五子棋AI教程[4 静态棋盘评估]

引子 静态棋盘的评估是棋力的一个很重要的体现&#xff0c;一个优秀的基于博弈树搜索的AI往往有上千行工作量&#xff0c;本文没有做深入讨论&#xff0c;仅仅写了个引子用来抛砖引玉。 评估一般从两个角度入手&#xff0c;一个是子力&#xff0c;另一个是局势。 1 评估维度 …