百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Linux,CentOS环境,MySQL8实现主从复制配置

bigegpt 2024-08-12 14:11 2 浏览

MySQL主从复制概述:

主从复制时指数据<MySQL>可以从一个服务器主节点复制到另一个或多个从节点<MySQL>。

MySQL默认采用异步复制方式,从节点不用一直访问主服务器来更新自己的数据,数据的更新可以在远程连接上进行,从节点可以复制主数据库中的所有数据库或者特定的数据,或者特定的表。

MySQL主从复制原理:

1、Master服务器,数据改变会记录二进制binlog日志,当master上的数据发生改变时,写入二进制日志中;

2、Slave服务器,在一定时间间隔内对master二进制日志进行探测其是否发生改变,如果发生改变,则开始一个I/O Thread请求master二进制事件;

3、Master服务器(主节点),为每个I/O线程启动一个dump线程,用于向其发送二进制事件,并保存至从节点本地的中继日志中;

4、Slave服务器(从节点),启动SQL线程从中继日志中读取二进制日志,在本地重放,使得其数据和主节点保持一致,最后I/O Thread和SQL Thread将进入睡眠状态,等待下一次同步再次被唤醒。

总结:

1、从库(Slave服务器)会生成两个线程,一个I/O线程,一个SQL线程;I/O线程会去请求主库(Master服务器)的binlog,并将得到的binlog写到本地的relay-log(中继日志)文件中;

2、主库(Master服务器)会生成一个log dump线程,用来给从库(Slave服务器)I/O线程传递binlog;

3、从库(Slave服务器),SQL线程,会读取relay log文件中的日志,并解析成SQL语句逐一执行;

主从安装:

安装环境:

操作系统环境:CentOS Linux release 7.7.1908 (Core),MySQL8

单台安装:Linux,CentOS安装MySQL8、设置密码和远程登录

安装目标:服务器node11(192.168.1.11)为Master服务器,服务器node11(192.168.1.12)为Slave服务器;

MySQL安装完成后,配置文件(/etc/my.cnf)的默认内容为:

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

此时,先做备份:

cp /etc/my.cnf /etc/my.init.cnf

Master服务器,配置(/etc/my.cnf):

[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

[mysql]
default-character-set=utf8
protocol=tcp

[mysqld]
# 设置3306端口
port=3306
# 允许最大连接数
max_connections=10000
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password

server-id = 11
log-bin=mysql-bin
max_binlog_size=1024M
auto_increment_offset=1
auto_increment_increment=4
log-slave-updates=true
secure_file_priv=/tmp/
replicate-do-db=share

重启服务器:systemctl restart mysqld

Slave服务器,配置(/etc/my.cnf):

[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

[mysql]
default-character-set=utf8
protocol=tcp

[mysqld]
# 设置3306端口
port=3306
# 允许最大连接数
max_connections=10000
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password

server-id = 12
log-bin=mysql-bin
max_binlog_size=1024M
auto_increment_offset=2
auto_increment_increment=4
log-slave-updates=true
secure_file_priv=/tmp/
replicate-do-db=share

重启服务器:systemctl restart mysqld

Master服务器,创建同步用户并分配权限:

#创建用户
mysql> set global validate_password.policy=0;
mysql> set global validate_password.length=6;
mysql> create user 'repl'@'192.168.1.12' identified with mysql_native_password by 'repl1234';      

#分配权限
mysql> grant replication slave on *.* to 'repl'@'192.168.1.12'; 
mysql> grant replication client on *.* to 'repl'@'192.168.1.12';                         
mysql> flush privileges; 

#查看分配权限:
mysql> show grants for 'repl'@'192.168.1.12';

#查看主机MySQL状态:
mysql> show master status;  

Slave服务器,启动主从复制:

mysql> change master to
    master_host='192.168.1.11',
    master_user='repl',
    master_password='repl1234',
    master_log_file='mysql-bin.000001',
    master_log_pos=1508;

mysql> start slave;

注意参数:master_host、master_user、master_password、master_log_file、master_log_pos;

Master服务器(show processlist\G):

Slave服务器(show processlist\G):

Slave服务器(show slave status\G):

相关推荐

ActiveAndroid使用(对象化数据库)

配置模块的build.gradlerepositories{mavenCentral()mavenLocal()maven{url"https://oss.sonatype.org/conte...

AndroidStudio下的依赖管理(android app依赖外部jar包)

在开发中用第三方库是很常见的事,如何在AndroidStudio下管理这些依赖呢?这就是这篇文章的目的。目录Maven/Ivy仓库依赖Module依赖aar文件依赖jar文件依赖例子完整代码一、Mav...

Android Studio之gradle的配置与介绍

1、gradle的简单介绍Gradle是可以用于Android开发的新一代的BuildSystem,也是AndroidStudio默认的build工具。其实Gradle脚本是基于一种JVM语言—...

Android中的run-as命令带来的安全问题

一、前言最近一周比较忙,没时间写东西了,今天继续开始我们今天的话题:run-as命令,在上周的开发中,遇到一个问题,就是在使用run-as命令的时候出现了一个错误,不过当时因为工作进度的问题,这问题就...

Android系统级深入开发——input驱动程序

1、Input驱动程序是Linux输入设备的驱动程序,分成游戏杆(joystick)、鼠标(mouse和mice)和事件设备(Eventqueue)3种驱动程序。其中事件驱动程序是目前通用的驱动程序...

Android项目中如何用好构建神器Gradle?

CSDN移动将持续为您优选移动开发的精华内容,共同探讨移动开发的技术热点话题,涵盖移动应用、开发工具、移动游戏及引擎、智能硬件、物联网等方方面面。如果您想投稿、参与内容翻译工作,或寻求近匠报道,请发送...

Android Studio自定义文件类头(android studio自定义标题栏)

--简书作者谢恩铭转载请注明出处今天给大家介绍一个很简单的"小"技巧。平时,我们在AndroidStudio中开发Android时,总免不了要创建新的文件,也许是Java文件,也许是C...

C语言#include头文件真的是插入代码吗?

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!编译器理论和实作既是又不是。从编译器理论理解,#include头文件"相当于"插入了头文件的代码,以供源代码引用(宏定...

Android 系统核心机制binder(03)binder C++层实现

本章关键点总结&说明:这里主要关注BinderC++部分即可,看到,也是本章节的核心内容,主要就是以C++封装的框架为主来解读binder。之前主要针对于底层驱动binder的数据交互以及...

Java对象序列化与反序列化的那些事

Java对象序列化与反序列化的那些事在Java的世界里,对象序列化和反序列化就像一对孪生兄弟,它们共同构成了Java对象存储和传输的基础。如果你曾经尝试将对象保存到文件中,或者在网络中传输对象,那么你...

Java对象序列化剖析(java 对象序列化)

对象序列化的目的1)希望将Java对象持久化在文件中2)将Java对象用于网络传输实现方式如果希望一个类的对象可以被序列化/反序列化,那该类必须实现java.io.Serializable接口或jav...

C++模板 - 16(SFINAE)(c++模板编程)

C++支持函数重载,同一个函数名,只要它的签名不一样,可以声明若干个版本(这个特性也是必须的,不然构造函数就只能有一个了)。现在函数的重载集合中又加入了新的成员-函数模板,事情就变得越发有趣起来,...

NewtoSoft.Json相关使用技巧(newtosoft.json相关使用技巧有哪些)

  本篇将为大家介绍Newtonsoft.Json的一些高级用法,可以修改很少的代码解决上述问题。Newtonsoft.Json介绍  在做开发的时候,很多数据交换都是以json格式传输的。而使用Js...

C#调用DeepSeek API(c#调用deepseek api 流式输出)

一、官方网站二、DeepSeek测试DeepSeek三大适用模式:基础模型(V3)、深度思考(R1)、联网搜索。基础模型(V3)深度思考(R1)联网搜索三、C#调用DeepSeekAPI核心代码//...

.NET性能系列文章二:Newtonsoft.Json vs System.Text.Json

微软终于追上了?图片来自GlennCarstens-Peters[1]Unsplash[2]欢迎来到.NET性能系列的另一章。这个系列的特点是对.NET世界中许多不同的主题进行研究、基准和比较...