• MySQL主主数据同步


    环境

    操作系统版本:CentOS 6.5 64位
    MySQL版本:mysql5.6
    节点1IP:192.168.0.235 主机名:taojiang1-mysql-01
    节点2IP:192.168.0.236 主机名:taojiang2-mysql-02

    注意:
    1、主从服务器操作系统版本和位数要保持一致
    2、Master和Slave数据库的版本要一致
    3、Master和Slave数据库中的数据要一致

    一、2台服务器关闭SELinux(安全强化,如果你感兴趣)“是linux中支持安全访问控制策略机制的一种特性”

    vi /etc/selinux/config

    SELINUX=disabled

    reboot 重启服务器

    二、配置235服务器

    1、配置my.cnf

    vim /etc/my.cnf

    # 服务器的ID,必须唯一,一般设置自己的IP
    server_id=235
    # 复制过滤:不需要备份的数据库(MySQL库一般不同步)
    binlog-ignore-db=mysql
    # 开启二进制日志功能,名字可以随便取,最好有含义(比如项目名)
    log-bin=edu-mysql-bin
    # 为每个 session 分配的内存,在事务过程中用来存储二进制日志的缓存
    binlog_cache_size=1M
    # 主从复制的格式(mixed,statement,row,默认格式是 statement)
    binlog_format=mixed
    # 二进制日志自动删除/过期的天数。默认值为 0,表示不自动删除。
    expire_logs_days=7
    ## 跳过主从复制中遇到的所有错误或指定类型的错误,避免 slave 端复制中断。
    ## 如:1062 错误是指一些主键重复,1032 错误是因为主从数据库数据不一致,all所有错误
    slave_skip_errors=all
    # 作为从服务器时的中继日志
    relay_log=taojiang1-mysql-relay-bin
    # log_slave_updates 表示 slave 将复制事件写进自己的二进制日志
    log_slave_updates=1
    # 主键自增规则,避免主从同步ID重复的问题
    auto_increment_increment=2 # 自增因子(每次加2)
    auto_increment_offset=1 # 自增偏移(从1开始),单数

    2 、192.168.0.235配置

    # 先重启一下服务
     service mysql restart
    # 登录到mysql
    shell> mysql -uroot -p
    # 创建数据库同步用户,并授予相应的权限
    mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.0.236' identified by 'repl123';
    # 刷新授权表信息
    mysql> flush privileges;
    # 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到
    mysql> show master status;
    +----------------------+----------+--------------+------------------+-------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------------+----------+--------------+------------------+-------------------+
    | taojiag1-mysql-bin.000001 | 001 | | mysql | |
    +----------------------+----------+--------------+------------------+-------------------+

    3 、192.168.0.236配置

    配置之前需要在236上能通过添加的用户repl能访问235上的数据库

    mysql -h 192.168.0.235 -u repl -p repl123

    change master to master_host='192.168.0.235',

                                                      master_user='repl',

                                                      master_password='repl123',

                                                      master_port=3306,

                                                      master_log_file='taojiang1-mysql-bin.000001',

                                                     master_log_pos=0,

                                                      master_connect_retry=30;

    如果master_log_pos=0;系统会自动匹配的.

    4、查看192.168.0.235节点状态

    mysql> show slave statusG;

    Slave_IO_Running: No

    Slave_SQL_Running: No

    表示为启用

    三、配置192.168.0.236

    1、vim /etc/my.cnf

    server_id=236
    binlog-ignore-db=mysql
    log-bin=edu-mysql-bin
    binlog_cache_size=1M
    binlog_format=mixed
    expire_logs_days=0
    slave_skip_errors=all
    relay_log=edu-mysql-relay-bin
    log_slave_updates=1
    #ID自增从2开始,双数
    auto_increment_increment=2
    auto_increment_offset=2
    ————————————————

    配置好保存重启数据库
    service mysql restart

    2、创建数据库同步用户,并授予相应的权限

    mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.0.235' identified by 'repl123';
    # 刷新授权表信息
    mysql> flush privileges;
    # 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到

    mysql> show master status;
    +----------------------+----------+--------------+------------------+-------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------------+----------+--------------+------------------+-------------------+
    | taojiang2-mysql-bin.000001 | 439 | | mysql | |
    +----------------------+----------+--------------+------------------+-------------------+

    3 、192.168.0.235配置

    配置之前需要在235上能通过添加的用户repl能访问236上的数据库

    mysql -h 192.168.0.236 -u repl -p repl123

    change master to master_host='192.168.0.236',

                                                      master_user='repl',

                                                      master_password='repl123',

                                                      master_port=3306,

                                                      master_log_file='taojiang2-mysql-bin.000001',

                                                     master_log_pos=0,

                                                      master_connect_retry=30;

    Query OK, 0 rows affected, 2 warnings (0.00 sec)

    四 、全部配置好后启动slave;

    start slave 启动;

    stop slave 停止;

    reset slave 重置;

    1、验证;

    show slave statusG;

    Slave_IO_Running: Yes

    Slave_SQL_Running: Yes

    全部YES即配置成功

    2、测试

    在两台服务器上新建删除数据库是否成功

     



  • 相关阅读:
    [bbk5177]第62集第6章 用scheduler自动化 10(章节标题内容调整)
    [bbk4956]第65集 第7章 数据库的维护 02
    [bbk4940]第61集第6章 用scheduler自动化 09
    [bbk5179]第66集 第7章 数据库的维护 03
    ORA01031: insufficient privileges(有待于二次解决)
    Google Analytics功能篇 如何跟踪邮件打开率与点击率
    小资之豆浆篇 (IS2120@BG57IV3)
    wix custom action 之 vbscript 简明步骤(IS2120@BG57IV3)
    c++ faq (15)
    linux 下面字符串处理函数实现 抄来看一下 抄自[http://blog.csdn.net/BeWithLei/article/details/1719242]
  • 原文地址:https://www.cnblogs.com/shigfdengys/p/13220126.html
Copyright © 2020-2023  润新知