mysql8.0.36主从复制(读写分离)配置教程

1、关闭防火墙
 

使用命令行关闭防火墙

在Ubuntu系统中,可以使用以下命令关闭防火墙:

sudo ufw disable

执行该命令后,系统会提示是否要关闭防火墙,确认后即可关闭防火墙。

查看防火墙状态

使用以下命令可以查看防火墙当前的状态:

sudo ufw status

如果防火墙已经关闭,则会显示如下信息:

Status: inactive

如果防火墙处于开启状态,则会显示如下信息:

Status: active

当前演示IP:

主库IP:192.168.91.152

从库IP:192.168.91.153

2、配置主库(192.168.91.152)

修改配置文件

vim /etc/my.cnf

 或

vim /etc/mysql/my.cnf

[mysqld]
#id要确保在局域网环境里是唯一的
server-id=1
#1代表只读,0代表可读写
read-only=0
#忽略的数据,指不需要同步的数据库,如需要请把以下的#注释符号删掉即可
#lbinlog-ignore-db=mysql
#指定同步的数据库,如需要请把以下的#注释符号删掉即可
#binlog-do-db=db_001

修改后,重启mysql服务

service mysqld restart

service mysql restart

进入mysql:

mysql -u root -p

创建用户:

-- 创建用户并设置密码
CREATE USER 'test123'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';-- 赋予用户全部权限
GRANT ALL PRIVILEGES ON *.* TO 'test123'@'%';-- 刷新权限
FLUSH PRIVILEGES;

 显示当前主服务器(Master)二进制日志的状态信息

show master status;

记录一下File值和Position值

File值:binlog.000006

Position值:157

3、配置从库(192.168.91.153)

修改配置文件

vim /etc/my.cnf

 或

vim /etc/mysql/my.cnf
[mysqld]
#id要确保在局域网环境里是唯一的
server-id=2
#1代表只读,0代表可读写
read-only=1
#忽略的数据,指不需要同步的数据库,如需要请把以下的#注释符号删掉即可
#lbinlog-ignore-db=mysql
#指定同步的数据库,如需要请把以下的#注释符号删掉即可
#binlog-do-db=db_001

 修改后,重启mysql服务

service mysqld restart

service mysql restart

 进入mysql:

mysql -u root -p

修改复制源信息,指定新的主服务器

 mysql命令行输入:

CHANGE REPLICATION SOURCE TO SOURCE_HOST='192.168.91.152',SOURCE_USER='test123',SOURCE_PASSWORD='Root@123456',SOURCE_LOG_FILE='binlog.000006',SOURCE_LOG_POS=157;

 

-- 启动主从复制

START REPLICA;

-- 显示从库的状态信息

SHOW SLAVE STATUS \G;

成功了

4、开始测试

分别在主库、从库查看所有数据库列表:

SHOW DATABASES;

主库:

从库:

在主库执行以下SQL语句:

-- 创建数据库 db_001
CREATE DATABASE IF NOT EXISTS db_001 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;-- 切换到数据库 db_001
USE db_001;-- 创建表 example_table
CREATE TABLE IF NOT EXISTS example_table (id INT AUTO_INCREMENT PRIMARY KEY,          -- 主键,自增长整数类型name VARCHAR(50) NOT NULL COMMENT '姓名',    -- 姓名,最大长度为50的字符串,不允许为空age INT COMMENT '年龄',                      -- 年龄,整数类型email VARCHAR(100) COMMENT '电子邮件'       -- 电子邮件,最大长度为100的字符串
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;-- 插入数据
INSERT INTO example_table (name, age, email) VALUES
('张三', 25, 'zhangsan@example.com'),
('李四', 30, 'lisi@example.com'),
('王五', 22, 'wangwu@example.com');

分别在主库、从库查看所有数据库列表:

SHOW DATABASES;

主库:

从库:

可以看到,从库和主库同步了

常见问题:

问题1:Slave_IO_Running: No

我是直接克隆的虚拟机,主库和从库的uuid一致了,所以需要修改一下

搜索auto.cnf文件

find / -iname "auto.cnf"

 找到:/var/lib/mysql/auto.cnf

vim /var/lib/mysql/auto.cnf

 修改UUID,要保证唯一性

  • 将两台机器的UUID改成不一样就行

 修改后,重启mysql服务

service mysqld restart

service mysql restart

进入mysql

mysql -u root -p

-- 启动主从复制

start replica;

 -- 显示从库的状态信息

SHOW SLAVE STATUS \G;

 成功了

问题2:ERROR 3021 (HY000): This operation cannot be performed with a running replica io thread; run STOP REPLICA IO_THREAD FOR CHANNEL '' first.

原因:

从库已经配置过,需要先停止,然后重置一下

停止:

stop replica;

重置:

reset replica;

重新设置:

CHANGE REPLICATION SOURCE TO SOURCE_HOST='192.168.91.152',SOURCE_USER='test123',SOURCE_PASSWORD='Root@123456',SOURCE_LOG_FILE='binlog.000006',SOURCE_LOG_POS=157;

-- 启动

START REPLICA;

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

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

相关文章

敏捷软件开发价值观和原则重温

敏捷软件开发宣言 个体和交互胜过过程和工具可以工作的软件胜过面面俱到的文档客户合作胜过合同谈判响应变化胜过遵循计划 个体和交互胜过过程和工具 软件开发是人的活动,人是软件开发中最重要的因素。如果没有优秀的成员,再好的过程也无法挽救项目。…

OpenVDB Cookbook 笔记

目录 Hello WorldCreating and writing a gridPopulating a grid with valuesReading and modifying a gridStream I/OHandling metadataAdding metadataRetrieving metadataRemoving metadata IterationNode IteratorLeaf Node IteratorValue IteratorIterator Range Interpol…

Vegeta压测工具学习与使用

Vegeta压测工具学习与使用 目标: 能够在命令行下使用Vegeta对指定API进行测试了解如何导出结果,以及能获得什么样的结果(P99,P99.9,QPS)探索能否导出其他结果,是否能够执行复杂命令或简易脚本等 时间比较紧迫,预计两到三个小时内完…

详解tomcat中的jmx监控

目录 1.概述 2.如何开启tomcat的JMX 3.tomcat如何实现JMX的源码分析 1.概述 本文是博主JAVA监控技术系列文章的第二篇,前面一篇文章中我们介绍了JAVA监控技术的基石——jmx: 【JMX】JAVA监控的基石-CSDN博客 本文我们将从使用和源码实现两个方面聊…

BLDC驱动刹车电路、能量泄放电路

不同STM32的性能; APM2.8飞控整合资料: APM2.8飞控说明书 GitBook BLDC的制动首先要考虑MOS的泄放电阻的选择,参考前面博客。 刹车电阻制动: 如图所示就是一种通过功率电阻耗散电机制动过程中产生电能的电路。因为功率电阻在这个电路中起…

【AI视野·今日Robot 机器人论文速览 第七十八期】Wed, 17 Jan 2024

AI视野今日CS.Robotics 机器人学论文速览 Wed, 17 Jan 2024 Totally 49 papers 👉上期速览✈更多精彩请移步主页 Daily Robotics Papers Safe Mission-Level Path Planning for Exploration of Lunar Shadowed Regions by a Solar-Powered Rover Authors Olivier L…

【并发编程】ThreadPoolExecutor类

📝个人主页:五敷有你 🔥系列专栏:并发编程⛺️稳重求进,晒太阳 ThreadPoolExecutor 1) 线程池状态 ThreadPoolExecutor 使用 int 的高 3 位来表示线程池状态,低 29 位表示线程数量 状态名 高三位 …

rtt设备io框架面向对象学习-uart设备

目录 1.uart设备基类2.uart设备基类的子类3.初始化/构造流程3.1设备驱动层3.2 设备驱动框架层3.3 设备io管理层 4.总结5.使用 1.uart设备基类 此层处于设备驱动框架层。也是抽象类。 在/ components / drivers / include / drivers 下的serial.h定义了如下uart设备基类 struc…

Transformer实战-系列教程18:DETR 源码解读5(BackboneBase类/Backbone类)

🚩🚩🚩Transformer实战-系列教程总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 点我下载源码 DETR 算法解读 DETR 源码解读1(项目配置/CocoDetection类) …

我的NPI项目之嵌入式总线系列(一) -- SPI 接口

如我的NPI项目之Android 安全系列 -- 外挂SE集成(SPI)接口-CSDN博客 提到SPI的接口,基本的电气特性已经给出。这边文章就针对协议部分进行详细解析。从协议网找到了原文:SPI protocol 还有wilipedia SPI 主要涉及一下几个方面&a…

bat 定时收缩sqlserver2017

如果你希望使用批处理(.bat)文件来定时收缩SQL Server的数据库,你可以编写一个脚本来执行这个任务。但首先,需要注意的是,定期收缩数据库通常不是一个好的做法,因为它可能会对性能产生负面影响,…

全闭环直播推流桌面分享远控系统

直播推流涉及多协议,多端技术栈和知识点,,想要做好并不容易,经过几年时间的迭代,终于小有成就,聚集了媒体服务器,实时会议sfu,远控kvm等功能。可以做一个音视频应用的瑞士小军刀。主…

详解Vue文件结构+实现一个简单案例

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

测试开发-2-概念篇

文章目录 衡量软件测试结果的依据—需求1.需求的概念2.从软件测试人员角度看需求3.为什么需求对软件测试人员如此重要4.如何才可以深入理解被测试软件的需求5.测试用例的概念6.软件错误(BUG)的概念7.开发模型和测试模型8.软件的生命周期9.瀑布模型&#…

MATLAB知识点:randperm函数(★★★★★)将一个数字序列进行随机打乱

​讲解视频:可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇(数学建模清风主讲,适合零基础同学观看)_哔哩哔哩_bilibili 节选自第3章:课后习题讲解中拓展的函数 在讲解第…

Codeforces Round 923 - A.B.C.D

文章目录 A. Make it WhiteB. Following the StringC.Choose the Different Ones!D. Find the Different Ones! A. Make it White #include<bits/stdc.h>using namespace std;void solve() {int n;cin >> n;string s; cin >> s;int flag 0;int x 0, y -1…

django中admin页面汉化

在Django中&#xff0c;将admin界面汉化为中文需要进行一些配置和翻译文件的添加。下面是一个基本的步骤指南&#xff0c;帮助你实现Django admin的汉化&#xff1a; 一&#xff1a;安装并配置Django: 如果你还没有安装Django&#xff0c;首先通过pip安装它&#xff1a; pip…

【开源训练数据集1】神经语言程式(NLP)项目的15 个开源训练数据集

一个聊天机器人需要大量的训练数据,以便在无需人工干预的情况下快速解决用户的询问。然而,聊天机器人开发的主要瓶颈是获取现实的、面向任务的对话数据来训练这些基于机器学习的系统。 我们整理了训练聊天机器人所需的对话数据集,包括问答数据、客户支持数据、对话数据和多…

ESP32学习(1)——环境搭建

使用的ESP32板子如下图所示 它可以用Arduino 软件&#xff0c;基于C语言开发。但是&#xff0c;在这里&#xff0c;我是用Thonny软件&#xff0c;基于micro_python对其进行开发。 1.安装Thonny Thonny的软件安装包&#xff0c;可以去它官网上下载。Thonny, Python IDE for begi…

【MySQL】学习外键约束处理员工数据

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-g4glZPIY0IKhiTfe {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…