Mysql 主从配置


  1. 登录主服务器mysql

  2. 进入mysql,建立一个mysql用户,用来做为从服务器链接使用sql

    mysql>GRANT REPLICATION SLAVE ON *.* TO ‘test’@’192.168.1.101‘ IDENTIFIED BY ‘123456’;
    数据库

  3. 修改my.ini文件(windows server 中修改mydefault.ini ,修改完成后更名成为my.ini)windows

    server-id       = 1
    log-bin          = mysql-bin 服务器

  4. 进入从服务器修改my.ini文件函数

  5. server-id               = 2
    log_bin                 = /var/log/mysql/mysql-bin.log
    master-host     =192.168.1.100
    master-user     =test
    master-pass     =123456
    master-port     =3306
    master-connect-retry=60 
    replicate-do-db =test

    5.  重启主服务器数据库及从服务器数据库性能

    6.  查看从服务器同步状态
spa

        show slave status\G;日志

正常状态orm

        slave_io_running : yes

        slave_sql_running: yes

注意:主服务器的binlog-format模式我用的是STATEMENT,从服务器的binlog-format模式我用的是ROW。

① STATEMENT模式(SBR)

每一条会修改数据的sql语句会记录到binlog中。优势是并不须要记录每一条sql语句和每一行的数据变化,减小了binlog日志量,节约IO,提升性能。缺点是在某些状况下会致使master-slave中的数据不一致(如sleep()函数, last_insert_id(),以及user-defined functions(udf)等会出现问题)

② ROW模式(RBR)

不记录每条sql语句的上下文信息,仅需记录哪条数据被修改了,修改为什么样了。并且不会出现某些特定状况下的存储过程、或function、或trigger的调用和触发没法被正确复制的问题。缺点是会产生大量的日志,尤为是alter table的时候会让日志暴涨。

③ MIXED模式(MBR)

以上两种模式的混合使用,通常的复制使用STATEMENT模式保存binlog,对于STATEMENT模式没法复制的操做使用ROW模式保存binlog,MySQL会根据执行的SQL语句选择日志保存方式。

相关文章
相关标签/搜索