How to prevent replication of certain records with mysql
I have master-master 开发者_开发技巧replication working successfully, it works fine and all changes I make will reflect to slave also.
But I don't want that slave to reflect all changes - only such records that I want should reflect on slave. How can can do this?
You can do
SET sql_log_bin=0;
before the statement(s) you DO NOT want replicated. They will not be sent on to the slave.
Alternatively, you could configure on the application-side each connection to set that value, then do
SET sql_log_bin=1;
when you do want it. More of the same can be found on MySQL replication: temporarily prevent specific SQL statements replicating to the slaves?.
You can prevent the slave from processing updates for particular databases, and individual tables, either as a whitelist or a blacklist - see the slave configuration options for details.
If your criteria are more complex than that, you might need to rethink.
The only way I can think of is to create a VIEW on the master that filters out the records you don't want to replicate, then replicate that VIEW. On the slave the "VIEW" table would be MYISAM/InnoDB instead of a VIEW. I know you can replicate to different table types (i.e. InnoDB->MyISAM), but I never tried doing it with a View.
Without knowing what you're trying to achieve, it is hard to say.
You can prevent changes to individual tables, or whole databases from being made through replication (for instance its recommended that you don't replicate the mysql.* tables as you might not want GRANTs getting replicated) (Paul Dixon's answer provides some more info about this)
If you want to prevent certain types of statements from being replicated (for instance DELETE queries) then you might be able to use MySQL proxy to rewrite those queries before replicating them.
If you're intending to shard the database on the slaves (eg: records starting A-M on one server and N-Z on another) then again MySQL proxy might be able to help you.
精彩评论