MySQL-master1:192.168.72.128
 
MySQL-master2:192.168.72.129
 
OS版本:CentOS 5.4
MySQL版本:5.5.9(主从复制的master和slave服务器中的mysql版本相同或者master版本高于slave版本)
 
一、MySQL master-master配置
 
1、修改MySQL配置文件
 
两台MySQL均如要开启binlog日志功能,开启方法:在MySQL-master1  配置文件/etc/my.cnf
 
 [MySQLd]段中加上
 
user = mysql
log-bin=mysql-bin
server-id = 1
binlog-do-db=test
binlog-ignore-db=mysql
replicate-do-db=test
replicate-ignore-db=mysql
log-slave-updates
slave-skip-errors=all
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1
 
    在MySQL-master2  配置文件/etc/my.cnf
 
 [MySQLd]段中加上
 
user = mysql
log-bin=mysql-bin
server-id= 2
binlog-do-db=test
binlog-ignore-db=mysql
replicate-do-db=test
replicate-ignore-db=mysql
log-slave-updates
slave-skip-errors=all
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=2
 
将两个配置文件保存,分别重启mysql服务器
 
server_id值必须为2到232–1之间的一个正整数值。ID值唯一的标识了复制群集中的主从服务器,因此它们必须各不相同。
 
binlog-do-db=database 是要记录日志的数据库;
 
同步多个数据库重复设置选项binlog-do-db=test   和replicate-do-db=test
 
例如
 
 binlog-do-db=test1
 
 replicate-do-db=test1
 
 binlog-do-db=test2
 
 replicate-do-db=test2
 
binlog-ignore-db 是不要记录日志的数据库名,多个数据库中间用逗号(,)隔开;
 
mysql配置文件my.cnf中    log-slave-updates表示 如果一个MASTER 挂掉的话,另外一个马上接管。
 
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1   指的是服务器频繁的刷新日志。这个保证了在其中一台挂掉的话,日志刷新到另外一台。从而保证了数据的同步 。
 
auto_increment_offset = 1
auto_increment_increment = 2
这样A的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID了
 
auto_increment_offset = 2
auto_increment_increment = 2
这样B的auto_increment字段产生的数值是:2, 4, 6, 8, …等偶数ID了
 
你的auto_increment字段在不同的服务器之间绝对不会重复,所以Master-Master结构就没有任何问题了。当然,你还可以使用3 台,4台,或者N台服务器,只要保证auto_increment_increment = N 再设置一下auto_increment_offset为适当的初始值就可以了,那样,我们的MySQL可以同时有几十台主服务器,而不会出现自增长ID 重复。
 
2、将192.168.72.128设为192.168.72.129的主服务器
 
在192.168.72.128上新建授权用户
 
MySQL> grant replication slave on *.* to 'replication'@'%' identified by 'replication';
Query OK, 0 rows affected (0.00 sec) 
 
 MySQL>flush privileges;
Query OK, 0 rows affected (0.00 sec)
 
MySQL> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| MySQL-bin.000003 |      374 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
 
    ------------------------------------------------------------------------------
在192.168.72.129将192.168.72.128为自己的主服务器
 
MySQL> change master to master_host='192.168.72.128',master_user='replication',master_password='replication',master_log_file='MySQL-bin.000003',master_log_pos=374;
Query OK, 0 rows affected (0.05 sec)  
 
MySQL> start slave;
Query OK, 0 rows affected (0.00 sec)  
 
MySQL> show slave status/G
*************************** 1. row ***************************
             Slave_IO_State: Waiting for master to send event
                Master_Host: 192.168.72.128
                Master_User: replication
                Master_Port: 3306
              Connect_Retry: 60
            Master_Log_File: MySQL-bin.000003
        Read_Master_Log_Pos: 374
             Relay_Log_File: MySQL-master2-relay-bin.000002
              Relay_Log_Pos: 235
      Relay_Master_Log_File: MySQL-bin.000003
           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: 374
            Relay_Log_Space: 235
            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
1 row in set (0.00 sec)
 
红色标注部分为192.168.72.128主机中show master status命令结果中的file postion两个值
 
 
 
3、将192.168.72.129设为192.168.72.128的主服务器
 
在192.168.72.129上新建授权用户
 
MySQL> grant replication slave on *.* to 'replication'@'%' identified by 'replication';
Query OK, 0 rows affected (0.00 sec)  
 
 MySQL>flush privileges;
Query OK, 0 rows affected (0.00 sec)
 
MySQL> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| MySQL-bin.000003 |      374 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
 
----------------------------------------------------------------------------------
在192.168.72.128将192.168.72.129为自己的主服务器
 
MySQL> change master to master_host='192.168.72.129',master_user='replication',master_password='replication',master_log_file='MySQL-bin.000003',master_log_pos=374;
Query OK, 0 rows affected (0.05 sec)  
 
MySQL> start slave;
Query OK, 0 rows affected (0.00 sec)  
 
MySQL> show slave status/G
*************************** 1. row ***************************
             Slave_IO_State: Waiting for master to send event
                Master_Host: 192.168.72.129
                Master_User: replication
                Master_Port: 3306
              Connect_Retry: 60
            Master_Log_File: MySQL-bin.000003
        Read_Master_Log_Pos: 374
             Relay_Log_File: MySQL-master2-relay-bin.000002
              Relay_Log_Pos: 235
      Relay_Master_Log_File: MySQL-bin.000003
           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: 374
            Relay_Log_Space: 235
            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
1 row in set (0.00 sec)
 
如果主数据库有数据的话
 
数据库锁表操作,不让数据再进行写入动作。mysql> FLUSH TABLES WITH READ LOCK ;
 
用命令mysqldump
 
备份数据库。
 
在master服务器执行
 
shell> mysqldump -uroot -p123456 --master-data  --opt test1 > backup-file.sql
 
看主数据库的状态mysql> show master status;
 
记录File 和Position 项的值
 
注:由于没有锁定主服务器,这里记录的主服务器二进制日志position值可能会大于做mysqldump时的值,这将导致从服务器丢失在此期间的更新。如果可以保证在此期间主服务器不会出现创建新表的更新,那么丢失的影响不大;否则,将导致从服务器复制线程失败,这时必须在做mysqldump时锁定主服务器。
 
-----------------------------------------------
 
从服务器中my.cnf文件中加入选项
skip-slave-start
skip-slave-start 表示从mysql服务器启动时不启动同步线程,这就要在启动从服务器之后,手工启动同步线程,在mysql> 提示符下面运行“start slave”就可以
 
保存my.cnf后
 
执行
 
shell> mysqladmin -uroot -p123456 create test1
 
shell> mysql -uroot -p123456 test1 < backup-file.sql
 
启动从服务器线程
 
mysql>start slave;
 
取消主数据库锁定mysql>UNLOCK TABLES;
 
4、其他命令
 
1、查看复制进度
需要在主库上运行
mysql>show processlist \G;
 
2、主服务器上的相关命令:
show processlist;
show master status
show slave hosts
show {master|binary} logs
show binlog events
purge {master|binary} logs to 'log_name'
purge {master|binary} logs before 'date'
reset master(老版本flush master)
set sql_log_bin={0|1}
 
3、从服务器上的相关命令:
slave start
slave stop
slave stop IO_THREAD //此线程把master段的日志写到本地
slave start IO_THREAD
slave stop SQL_THREAD //此线程把写到本地的日志应用于数据库
slave start SQL_THREAD
reset slave
set global sql_slave_skip_counter
load data from master
show slave status(SUPER,REPLICATION CLIENT)
CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= //动态改变master信息
 
PURGE MASTER [before 'date'] 删除master端已同步过的日志
 
=========================================================================
skip-slave-start
server-id = 1
 
log-bin=C:/Program Files/MySQL/MySQL Server 5.0/00/repbinlog
log-error=C:/Program Files/MySQL/MySQL Server 5.0/rep/rep.err
relay-log=C:/Program Files/MySQL/MySQL Server 5.0/rep/beltal_relay_log
sync_binlog=1
log-slave-updates
innodb_flush_log_at_trx_commit=1
binlog-do-db=sync
 
#slave
master-host     =   192.168.1.144
master-user     =   replicate
master-password =   replicate
master-port     =  3306
master-connect-retry=60
replicate-do-db = sync
report-host=192.168.1.80

摘自 roockee的博客

转载于:https://www.cnblogs.com/thrillerz/p/3997430.html

mysql互为主从复制配置笔记--未读,稍后学习相关推荐

  1. Mysql 8主从复制配置图解

    Mysql 8主从复制配置图解 声明 本文的数据来自网络,部分代码也有所参照,这里做了注释和延伸,旨在技术交流,如有冒犯之处请联系博主及时处理.本文主要介绍mysql的主从的配置. 注:1 当前主服务 ...

  2. mysql复制--主从复制配置

    当单台 MYSQL 服务器无法满足当前网站流量时的优化方案.需要搭建 mysql 集群技术. 复制功能: 数据分布 负载均衡(读) 备份 高可用和故障切换 MySQL升级测试 复制方式: 主–从复制 ...

  3. linux下mysql单机主从配置,Linux下MySQL互为主从配置

    Linux系统环境:CentOS 6.5 master1:192.168.100.204 master2:192.168.100.205 mysql版本:mysql-5.6.19 注:mysql的5. ...

  4. mysql 转pxc_PXC 配置笔记-从MySQL直接转成PXC集群

    英文别人github的配置流程 PXC 能提供高可用,高读,多写支持 最重要的优点就是高可能,在3个及以上节点时,其中一个挂了,完全不影响业务. 最大的缺点是多写问题,最短板性能上限问题. 在我们硬件 ...

  5. mysql做主从复制配置案例

    2019独角兽企业重金招聘Python工程师标准>>> 之前遇到很多问题,幸亏有大家帮忙,都一一解决了,现在记录如下: 1.准备工作 mysql版本使用的是 mysql-5.5.30 ...

  6. mysql数据库主从复制部署笔记

    数据库主从复制原理: 数据库的主从复制就是从master数据库复制到slave数据库,在master与slave之间实现整个复制需要三个线程来完成,其中两个在slave端一个在master端. 在ma ...

  7. mysql 互为主从复制常见问题

    报错: 1) change master导致的:               Last_IO_Error: error connecting to master - retry-time: 60  r ...

  8. Mysql系列(三)—— Mysql主从复制配置

    一.前言 主从复制是Mysql知识体系中非常重的要一个模块.学习主从复制和后续的读写分离是完善只是知识体系的重要环节.且主从复制读写分离的思想并不仅仅局限于Mysql,在很多存储系统中都有该方案,如: ...

  9. 基于mysql的主从复制之Mycat简单配置和高可用

    what-mycat 1.Mycat就是MySQL Server,而Mycat后面连接的MySQL Server,就好象是MySQL的存储引擎,如InnoDB,MyISAM等. 因此,Mycat本身并 ...

最新文章

  1. POJ 2456 Aggressive cows(二分答案)
  2. SAP SD基础知识之交货中的控制元素
  3. [文档].Altera - 可选择的Nios II的Boot方法
  4. termux python 打开摄像头_【图片】将termux打造成合格的python环境(假装是教程贴)_termux吧_百度贴吧...
  5. android添加常驻图标到状态栏
  6. 14种冷热源及空调系统特点介绍
  7. 数据结构线性表博客作业总结
  8. UIApplication,UIWindow,UIViewController,UIView(layer)
  9. 判断字符串是否为JSON
  10. vmware安装centos8步骤
  11. 【Python】Python中常用的字符串处理函数
  12. xml 和android脚本之家,Android开发之XML文件解析的使用
  13. TCP/PI参考模型(应用层、传输层、网际层、网络接口层)、五层参考模型(应用层、传输层、网络层、数据链路层、物理层)、OSI与TCP/IP参考模型比较...
  14. Atitit.实现反向代理(1)----url rewrite 配置and内容改写 and -绝对路径链接改写 java php...
  15. 移动端高保真动态交互元件库+移动端通用元件库+app通用元件库+rpllib元件库+rp源文件+Axure移动端常用组件+数据展示+操作反馈+数据录入+列表页+表单页+通用版布局+业务组件+反馈组件
  16. 32位汇编第三讲,RadAsm,IDE的配置和使用,以及汇编代码注入方式
  17. 51单片机DS1302时钟
  18. 计算机原理作文,海口经济技术学院微型计算机原理作业第三章 习题与思考题:自述作文...
  19. Quoted-Printable编码原理及代码实现
  20. 华为数通HCIE实验考试LAB-C2全记录

热门文章

  1. 全网最具深度的三次握手、四次挥手讲解,深夜思考
  2. CUDA、CUDA toolkit、CUDNN、NVCC关系
  3. python【蓝桥杯vip练习题库】ALGO-234第五次作业:字符串排序
  4. Tensorflow【实战Google深度学习框架】使用 HDF5 处理大型数据集with TFLearn
  5. 参数构造错误 微信_快速掌握前端开发中的常见错误
  6. 在计算机上格式u盘启动,四大步,轻松让U盘启动电脑
  7. 进阶学习(4.1) JVM结构和原理
  8. 企业网络推广专员浅析企业网络推广中网站关键词排名优化有何技巧?
  9. 中小型企业开展网站关键词优化,怎样才能达到理想优化效果?
  10. body添加代码 js_hexo 博客添加评论和阅读量