官方mysql一个slave只能对应一个master,mariadb 10开始支持多源复制,一个slave能够有多个master,分别从各自的master复制不一样的DB。mysql
这个特性能够用在OLAP环境中,传统电商DB都是拆了再拆,分库分表,sharding,而OLAP环境或者大数据平台环境,一般须要各类数据的聚合,多个平台多个DB数据的复合查询,而这些数据分散在各个库中,怎么办了,固然经过应用程序能够实现聚合,但又没有更简单的方法,好比直接对各个server上的库,进行表字段的关联了。Mysql没有oracle的DBLINk的功能,而mysql虽然有federated引擎,但不太靠谱,并且麻烦,性能怎么样不可预知。sql
这个时候,mariadb的多源复制功能的优点就体现出来了。直接把多个server的db,复制到同一个slave上,全部库都有,想怎么关联就怎么关联。数据库
其余使用场景:api
两个独立的系统,经过接口,好比restful api或者soap,进行接口数据传递,常常有两边通信数据不一致的场景,怎么核查数据了。除了查接口日志,可使用多源复制,直接写sql关联两个库的通信数据,究竟是发送方传递数据仍是接受方接收数据有问题,就很明显了。restful
DBA能够在同一个DB SERVER上查数,不用到各个server分别查数。oracle
备份方便,集中在这台多源复制slave上进行备份,不用到各个server上去复制。性能
大数据抽数,集中在一个DB 平台上抽数,不用分散到各个DB server上抽数,固然抽数多了,IO扛不住,上ssd或者pcie 卡吧。大数据
下面讲讲使用方法,建议看mariadb 10 多源复制官方文档吧,https://mariadb.com/kb/en/mariadb/mariadb-documentation/replication-cluster-multi-master/replication/multi-source-replication/rest
change master 'conn_erp' to master_host='master ip',
MASTER_PORT=3306,master_user='', master_password='',
master_log_file='mysql-bin.000470', master_log_pos=215418341;日志
start slave 'conn_erp';
能够在my.cnf replicate_ignore_db 前添加conn链接串前缀,好比 main_connection.replicate_ignore_db=ignore_database 若不加前缀,就是忽略全部同名的数据库,其余变量类推。