
mysql主从复制总结
发布日期:2021-05-09 01:17:15
浏览次数:21
分类:博客文章
本文共 3330 字,大约阅读时间需要 11 分钟。
第一步:开启所有MYSQL服务器的BIN日志,每台服务器设置一个唯一的server-id的值(默认是1,一般取IP最后一段)
修改主服务器(master)的my.cnf
[mysqld]log-bin=mysql-binserver-id=91
修改从服务器(slave)的my.cnf
[mysqld]log-bin=mysql-binserver-id=92
第二步:重启主和从服务器
service mysqld restart
第三步:在主服务器上创建一个用来同步数据的帐号(如下边的test_slave,%表示所有客户端都可能连)
GRANT replication slave ON *.* TO 'test_slave'@'%' IDENTIFIED BY '123456';flush privileges;
第四步:登录主服务器的mysql,查询master的状态
show master status
见到如下所示
+------------------+----------+--------------+------------------+| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |+------------------+----------+--------------+------------------+| mysql-bin.000025 | 700 | | | +------------------+----------+--------------+------------------+
第五步:配置从服务器状态
stop slave;change master tomaster_host='192.168.1.91',master_user='test_slave',master_password='123456',master_log_file='mysql-bin.000025',master_log_pos=700;start slave;
解释:
MASTER_HOST='主服务器的IP地址',MASTER_USER='主服务器上用于同步数据的账号',MASTER_PASSWORD='同步的账号的密码',MASTER_LOG_FILE='bin日志的文件名',MASTER_LOG_POS=bin日志中的position的值;第六步:查看从服务器状态
show slave status\G
出现
*************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.1.91 Master_User: slave Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000025 Read_Master_Log_Pos: 700 Relay_Log_File: bogon-relay-bin.000002 Relay_Log_Pos: 342 Relay_Master_Log_File: mysql-bin.000025 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: 700 Relay_Log_Space: 498 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: 0Master_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: 11 row in set (0.00 sec)
如果Slave_IO_Running: Yes Slave_SQL_Running: Yes代表成功
一般出现这句Slave_IO_State: Waiting for master to send event 也代表成功
附:主主复制即相互设置对方为自己的主服务器和从服务器,有点绕,原理就是反过来设置一遍
ID冲突的解决办法:每台服务器的ID都不同:可以设置ID开始的数字和每次加几让1台服务器的自增ID 1,3,5,7来增长,另1台服务器自增ID 2,4,6,8来增长第一台服务器(192.168.1.91):set global auto_increment_increment = 2;set global auto_increment_offset = 1;set session auto_increment_increment = 2;set session auto_increment_offset = 1;
第二台服务器(192.168.1.92):
set global auto_increment_increment = 2;set global auto_increment_offset = 2;set session auto_increment_increment=2;set session auto_increment_offset = 2;
注意:auto-increment-increment和auto-increment-offset要写到配置文件中,防止下次重启后失效
auto_increment_increment=2; #每次加几auto_increment_offset=1; #第一个数从几开始,如第一台从1开始,第二台从2开始
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年04月29日 06时34分56秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【Bootstrap5】精细学习记录
2019-03-08
Struts2-从值栈获取list集合数据(三种方式)
2019-03-08
推荐几篇近期必看的视觉综述,含GAN、Transformer、人脸超分辨、遥感等
2019-03-09
VTK:可视化之RandomProbe
2019-03-09
block多队列分析 - 2. block多队列的初始化
2019-03-09
Java时间
2019-03-09
不编译只打包system或者vendor image命令
2019-03-09
【编程】C语言入门:1到 100 的所有整数中出现多少个数字9
2019-03-09
flink启动(二)
2019-03-09
pair的用法
2019-03-09
Flex 布局的自适应子项内容过长导致其被撑大问题
2019-03-09
PL/SQL 动态Sql拼接where条件
2019-03-09
Thymeleaf sec:authorize 标签不生效
2019-03-11
Flask--简介
2019-03-11
Frame--Api框架
2019-03-11
Boostrap技能点整理之【网格系统】
2019-03-11
javaWeb服务详解(含源代码,测试通过,注释) ——Emp的Dao层
2019-03-11
Git简单理解与使用
2019-03-11
echarts 基本图表开发小结
2019-03-11