登录主服务器mysql
进入mysql,建立一个mysql用户,用来做为从服务器链接使用sql
mysql>GRANT REPLICATION SLAVE ON *.* TO ‘test’@’192.168.1.101‘ IDENTIFIED BY ‘123456’;
数据库
修改my.ini文件(windows server 中修改mydefault.ini ,修改完成后更名成为my.ini)windows
server-id = 1
log-bin = mysql-bin 服务器
进入从服务器修改my.ini文件函数
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语句选择日志保存方式。