mysql怎么实现的主从复制_详解MySQL实现主从复制(一主一从)
mysql怎么实现的主从复制_详解MySQL实现主从复制(⼀主
⼀从)
MySQL实现主从复制
前⾔
windows 下的mysql主从复制
⼀、什么是主从复制?
将主数据库中的DDL和DML操作通过⼆进制⽇志(BINLOG)传输到从数据库上,然后将这些⽇志重新执⾏(重做);从⽽使得从数据库的数据与主数据库保持⼀致。
⼆、主从复制的作⽤
1、主数据库出现问题,可以切换到从数据库。
2、可以进⾏数据库层⾯的读写分离,
3、可以在从数据库上进⾏⽇常备份
三、复制过程
第⼀步:master在每个事务更新数据完成之前,将该操作记录串⾏地写⼊到binlog⽂件中。
第⼆步:salve开启⼀个I/O Thread,该线程在master打开⼀个普通连接,主要⼯作是binlog dump process。如果读取的进度已经跟上了master,就进⼊睡眠状态并等待master产⽣新的事件。I/O线程最终的⽬的是将这些事件写⼊到中继⽇志中。
第三步:SQL Thread会读取中继⽇志,并顺序执⾏该⽇志中的SQL事件,从⽽与主数据库中的数据保持⼀致。
四、主机操作
⾸先按照常规⽅式按照⼀个mysql实例:
将下载后的mysql压缩包解压如下图:
在根⽬录下创建my_3306.ini配置⽂件,配置内容如下:
#设置3306端⼝
port=3306
#设置mysql的安装⽬录
basedir=D:\\dev\\mysql-8.0.20-winx64
#设置mysql数据库的数据的存放⽬录
datadir=D:\\dev\\mysql-8.0.20-winx64\\Data_3306
#允许最⼤连接数
max_connections=200
#允许连接失败的次数。济南旅游景点介绍
max_connect_errors=10
#服务端使⽤的字符集默认为utf8mb4
character-set-server=utf8mb4
#创建新表时将使⽤的默认存储引擎
default-storage-engine=INNODB
#默认使⽤“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password电脑模糊
#服务器 id
server-id=3306
#⼆进制⽂件存放路径log_3306⽂件夹需要⼿动创建
log-bin=D:\\dev\\mysql-8.0.20-winx64\\log_3306\\mysql-bin #待同步的数据库(根据需要修改)
binlog-do-db=testdb
#不需要备份的数据库 (根据需要修改)
#binlog-ignore-db=mysql
binlog-ignore-db = information_schema
#⼆进制⽂件记录格式
电脑连接电视
binlog_format = STATEMENT
[mysql]
#设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
#设置mysql客户端连接服务端时默认使⽤的端⼝
port=3306
default-character-set=utf8mb4
在根⽬录下创建install_3306.bat⾃动安装执⾏脚本,配置内容如下
cd /d %~dp0\bin
mysqld --defaults-file="D:\dev\mysql-8.0.20-winx64\my_3306.ini" --initialize-insecure --user=mysql --console
mysqld install mysql_3306 --defaults-file="D:\dev\mysql-8.0.20-winx64\my_3306.ini"
net start mysql_3306
pause
在根⽬录下创建remove_3306.bat⾃动卸载执⾏脚本,配置内容如下:
cd /d %~dp0\bin
net stop mysql_3306
mysqld -remove mysql_3306
pause
执⾏安装操作:
配置mysql环境变量,右键以管理员⾝份运⾏install_3306.bat,如需卸载请执⾏remove_3306.bat
如上图显⽰安装成功并启动成功,默认密码为空执⾏以下操作
-
- 切换到mysql数据库
use mysql;
-- 修改root⽤户的可连接的host %代表所有
UPDATE USER SET HOST='%' WHERE USER='root'; -h IP地址缅怀袁隆平的句子
-- 查看是否修改成功
SELECT HOST,USER FROM USER;
-- 刷新MySQL的系统权限相关表
FLUSH PRIVILEGES;
-- 修改root⽤户密码
ALTER USER 'root'@'%' IDENTIFIED BY 'root';
-- 在主机创建⼀个⽤户
鬼片排行榜
create user 'slave'@'%' identified by 'slave';
-- 给创建的⽽⽤户赋予复制的权限
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%';
-- 展⽰主机状态
show master status;
执⾏完查看主机状态之后不要再操作以免数据变动
五、从机的具体操作
安装第⼆个mysql实例:
复制install_3306.bat,my_3306.ini,remove_3306.bat三个⽂件在同⼀⽬录,并分别改名为
install_3307.bat,my_3307.ini,remove_3307.bat,并将三个3307⽂件中的所有3306改为3307,修改完成后按照上⾯的执⾏安装操作
my_3307.ini配置
[mysqld]
#设置3307端⼝
port=3307
#设置mysql的安装⽬录
basedir=D:\\dev\\mysql-8.0.20-winx64足球场地尺寸
#设置mysql数据库的数据的存放⽬录
datadir=D:\\dev\\mysql-8.0.20-winx64\\Data_3307
#允许最⼤连接数
max_connections=200
#允许连接失败的次数。
max_connect_errors=10
#服务端使⽤的字符集默认为utf8mb4
character-set-server=utf8mb4
#创建新表时将使⽤的默认存储引擎
default-storage-engine=INNODB
#默认使⽤“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
#服务器 id
server-id=3307
#开启⼆进制⽇志(从服务器不是必须要开启⼆进制⽇志log_3307⽂件夹需⼿动创建)
log-bin=D:\\dev\\mysql-8.0.20-winx64\\log_3307\\mysql-bin
#执⾏同步操作的数据库(根据需要修改)需要和master数据库要同步的数据库名称保持⼀致replicate-do-db=testdb
#复制的数据库
binlog-ignore-db=information_schema
[mysql]
#设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
#设置mysql客户端连接服务端时默认使⽤的端⼝
port=3307
default-character-set=utf8mb4
执⾏安装.bat
安装成功并启动成功,默认密码为空
执⾏以下操作
-- 切换到mysql数据库
use mysql;
-- 修改root⽤户的可连接的host %代表所有
UPDATE USER SET HOST='%' WHERE USER='root'; -h IP地址
-- 查看是否修改成功
SELECT HOST,USER FROM USER;
-- 刷新MySQL的系统权限相关表
FLUSH PRIVILEGES;
-- 修改root⽤户密码
ALTER USER 'root'@'%' IDENTIFIED BY 'root';
-- 与主机连接
change master to master_host='主机ip地址',
master_port=主机数据库端⼝号,
master_user='主机分配的复制⽤户',
master_password='主机分配的复制⽤户的密码',
master_log_file='主机执⾏show master status 之后得到的值',

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。