您好,登录后才能下订单哦!
现在我们来测试下,mysql的主从同步。
先在主库MasterA 上给m_s_rep数据库插入和删除2条数据。如下:
mysql> insert into test(id,content) values(3,’data3’); mysql> insert into test(id,content) values(2,’data2’); mysql> select * from test;
通过上图,我们可以看到从库slave中的m_s_rep数据库和主库master中的m_s_rep数据库,数据是一致。说明主从已经同步复制已经成功。
# mysqlbinlog mysql-bin.000003|tail
# cat master.info |more
通过测试,主库的binlog文件的pos位置节点与master.info对比。我们可以发现master.info文件中确实记录了mysql在同步复制时的binlog文件名以及pos位置节点。
我们来创建一张测试用表,来测试MasterA和MasterB互为主从同步测试。
至此,本方案已经全部部署测试完成,我想:“MasterA和MasterB无论那个节点宕机,仍能保证生产环境中主从的关系”。无论节点状态如何,为确保数据的一致性,MasterA和MasterB当且仅当只能有一个节点可写。其他节点可通过锁表来禁止往里写入数据,以避免出现脑裂。
如果在生产环境中,随着业务的增加,不同业务部门的数据库也在增加。那么怎么同步复制新的数据库呢?步骤如下:
MasterA和MasterB主库锁表à修改所有节点中的my.cnf配置文件,增加需要同步复制的数据库名à重启mysql服务à导出MasterA中主库数据库à仅仅在从库创建数据库名à导入MasterA主库的数据库文件到从库中à MasterA和MasterB主库解锁à自此,主库发生变化的数据也会自动同步复制到从库中。
参考博客:http://www.ilanni.com/?p=7992
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。