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 slave

10.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-bin

systemctl 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 TO
  MASTER_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\G

LO 和 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 event
                  Master_Host: master
                  Master_User: relication
                  Master_Port: 3306
                Connect_Retry: 10
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 154
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 320
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 154
              Relay_Log_Space: 527
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_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: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 203
                  Master_UUID: 6f6d0551-a073-11ee-9f28-000c298a6e96
             Master_Info_File: /var/lib/mysql/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
         Replicate_Rewrite_DB: 
                 Channel_Name: 
           Master_TLS_Version: 
1 row in set (0.00 sec)

重新配置

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

mysql>stop slave;
mysql> reset slave;
mysql>CHANGE MASTER TO
  MASTER_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/mysql

rm -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 TO
  MASTER_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=1062

1053  主服务器宕机

1045  账号密码错误 导致的链接错误

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据库开发之SQL简介以及DDL的详细解析

1.3 SQL简介 SQL&#xff1a;结构化查询语言。一门操作关系型数据库的编程语言&#xff0c;定义操作所有关系型数据库的统一标准。 在学习具体的SQL语句之前&#xff0c;先来了解一下SQL语言的语法。 1.3.1 SQL通用语法 1、SQL语句可以单行或多行书写&#xff0c;以分号结尾…

80x86汇编—指令系统

顺序是按照我们老师教的顺序&#xff0c;仅仅作为复习笔记。 汇编入门真的简单&#xff0c;深入难&#xff0c;毕竟学过计组CPU都只寄组的难处&#xff0c;指令系统不在话下了。 MOV 下图说明了一个MOV指令能够从哪里传到哪里&#xff0c;总结成一句话就是&#xff1a;立即数不…

【贪心算法】之 摆动序列(中等题)

实际操作上&#xff0c;其实连删除的操作都不用做&#xff0c;因为题目要求的是最长摆动子序列的长度&#xff0c;所以只需要统计数组的峰值数量就可以了&#xff08;相当于是删除单一坡度上的节点&#xff0c;然后统计长度&#xff09; 这就是贪心所贪的地方&#xff0c;让峰…

使用StableDiffusion进行图片Inpainting原理

论文链接&#xff1a;RePaint: Inpainting using Denoising Diffusion Probabilistic Models代码链接&#xff1a;RePaint Inpainting任务是指在任意一个二进制的掩码指定的图片区域上重新生成新的内容&#xff0c;且新生成的内容需要和周围内容保持协调。当前SOTA模型用单一类…

as安装后第一次创建项目,出现gradle下载错误,或无法创建run/debug的启动

大概报错Could not resolve com.android.tools.build:gradle:8.0.1 原因两种第一种就是刚创建好后没有等待他自动下载完成就做了其他操作导致异常&#xff0c;第二组就是瞎几把乱改改错了 我就属于第二种 修改回来的方式&#xff1a; 就这个地方我改成了jdk1.8&#xff0c;然…

java智慧工地 人脸识别终端,智慧工地解决方案源码

智慧工地即施工现场全面数字化过程&#xff0c;使用IOT、云、移动、大数据、AI等关键技术,进行生产要素、管理过程、建筑物实体的数据采集、数据治理&#xff0c;最终通过大数据和人工智能帮助项目实现精益管理。 智慧工地围绕工程现场人、机、料、法、环及施工过程中质量、安全…

git分支解析

1、概述和优点 在版本控制过程中&#xff0c;同时会推进多个任务&#xff0c;为此&#xff0c;就可以为每个任务创建单独的分支。开发人员可以把自己的任务和主线任务分离开来&#xff0c;在开发自己的分支的时候不会影响主分支。 分支的好处&#xff1a; 同时推进多个功能开发…

【GitHub精选项目】短信系统测试工具:SMSBoom 操作指南

前言 本文为大家带来的是 OpenEthan 开发的 SMSBoom 项目 —— 一种用于短信服务测试的工具。这个工具能够发送大量短信&#xff0c;通常用于测试短信服务的稳定性和处理能力。在合法和道德的范畴内&#xff0c;SMSBoom 可以作为一种有效的测试工具&#xff0c;帮助开发者和系统…

WebAssembly 的魅力:高效、安全、跨平台(下)

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

项目应用多级缓存示例

前不久做的一个项目&#xff0c;需要在前端实时展示硬件设备的数据。设备很多&#xff0c;并且每个设备的数据也很多&#xff0c;总之就是数据很多。同时&#xff0c;设备的刷新频率很快&#xff0c;需要每2秒读取一遍数据。 问题来了&#xff0c;我们如何读取数据&#xff0c…

一文读懂Java中的设计模式——代理模式,以翻译场景举例,特别通俗易懂!

代理模式概念 在代理模式&#xff08;Proxy Pattern&#xff09;中&#xff0c;一个类代表另一个类的功能。这种类型的设计模式属于结构型模式。在代理模式中&#xff0c;我们创建具有现有对象的对象&#xff0c;以便向外界提供功能接口。目的&#xff1a;为其他对象提供一种代…

浅谈Guava Cache的参数使用

CacheLoader 用于数据加载方式比较固定且统一的场景&#xff0c;在缓存容器创建的时候就需要指定此具体的加载逻辑。通常开发中使用时我们需要继承CacheLoader类或写一个匿名实现类实现其load方法和reload方法 load方法 当执行get操作没有命中缓存或者判断缓存已经超出expir…

论文阅读——llava

Visual Instruction Tuning LLaVA 指令智能体分为两类&#xff1a;端到端的&#xff0c;通过LangChain[1]/LLM[35]协调各种模型的系统。 数据集生成用GPT辅助生成的&#xff0c;具体不写了。 模型结构&#xff1a; input image Xv LLM&#xff1a;Vicuna visual encoder&a…

芯片到底是怎么访问外设

微型计算机的组成&#xff1a;CPURAM硬盘等 什么是FLASH&#xff1f; FLASH存储器又称闪存&#xff0c;它结合了ROM和RAM的长处&#xff0c;不仅具备电子可擦除可编程&#xff08;EEPROM&#xff09;的性能&#xff0c;还不会断电丢失数据同时可以快速读取数据&#xff08;NV…

系列一、GitHub搜索技巧

一、GitHub搜索技巧 1.1、概述 作为程序员&#xff0c;GitHub大家应该都再熟悉不过了&#xff0c;很多时候当我们需要使用某一项技能而又无从下手时&#xff0c;通常会在百度&#xff08;面向百度编程&#xff09;或者在GitHub上通过关键字寻找相关案例&#xff0c;比如我想学…

nodejs+vue+ElementUi医院预约挂号系统3e3g0

本医院预约挂号系统有管理员&#xff0c;医生和用户。该系统将采用B/S结构模式&#xff0c;使用Vue和ElementUI框架搭建前端页面&#xff0c;后端使用Nodejs来搭建服务器&#xff0c;并使用MySQL&#xff0c;通过axios完成前后端的交互 管理员功能有个人中心&#xff0c;用户管…

springMVC-异常处理

一、四种异常形式 在springmvc中&#xff0c;处理异常有四种形式 1&#xff0e;局部异常 2.全局异常 3.自定义异常 4.统一异常(统一提示异常&#xff09; 作用&#xff1a;可以使浏览器不出现丑陋的500错误提示&#xff0c;而跳转到另外的错误提示页面 另外&#xff0c;自定义…

Linux——缓冲区

我在上篇博客留下了一个问题&#xff0c;那个问题就是关于缓冲区的问题&#xff0c;我们发现 文件有缓冲区&#xff0c;语言有用户级缓冲区&#xff0c;那么缓冲区到底是什么&#xff1f;&#xff0c;或者该怎 么认识缓冲区&#xff1f;这篇文章或许会让你有所认识&#xff0c;…

【ONE·MySQL || 基础介绍】

总言 主要内容&#xff1a;MySQL在Centos 7下的安装&#xff08;主要学习相关指令语句&#xff0c;理解安装操作是在做什么&#xff09;、对MySQL数据库有一个基础认识。 文章目录 总言0、MySQL的安装与卸载&#xff08;Centos 7&#xff09;0.1、MySQL的卸载0.1.1、卸载不必要…

MySQL数据库 触发器

目录 触发器概述 语法 案例 触发器概述 触发器是与表有关的数据库对象&#xff0c;指在insert/update/delete之前(BEFORE)或之后(AFTER)&#xff0c;触发并执行触发器中定义的soL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性&#xff0c;日志记录&am…