MySQL Replication/再保险plication Implementation/ How Servers Evaluate Replication Filtering Rules

5.5 How Servers Evaluate Replication Filtering Rules

If a replication source server does not write a statement to its binary log, the statement is not replicated. If the server does log the statement, the statement is sent to all replicas and each replica determines whether to execute it or ignore it.

On the source, you can control which databases to log changes for by using the--binlog-do-dband--binlog-ignore-dboptions to control binary logging. For a description of the rules that servers use in evaluating these options, seeSection 5.5.1, “Evaluation of Database-Level Replication and Binary Logging Options”. You should not use these options to control which databases and tables are replicated. Instead, use filtering on the replica to control the events that are executed on the replica.

On the replica side, decisions about whether to execute or ignore statements received from the source are made according to the--replicate-*options that the replica was started with. (SeeSection 2.6, “Replication and Binary Logging Options and Variables”.) The filters governed by these options can also be set dynamically using theCHANGE REPLICATION FILTERstatement. The rules governing such filters are the same whether they are created on startup using--replicate-*options or while the replica server is running byCHANGE REPLICATION FILTER. Note that replication filters cannot be used on Group Replication-specific channels on a MySQL server instance that is configured for Group Replication, because filtering transactions on some servers would make the group unable to reach agreement on a consistent state.

In the simplest case, when there are no--replicate-*options, the replica executes all statements that it receives from the source. Otherwise, the result depends on the particular options given.

Database-level options (--replicate-do-db,--replicate-ignore-db) are checked first; seeSection 5.5.1, “Evaluation of Database-Level Replication and Binary Logging Options”, for a description of this process. If no database-level options are used, option checking proceeds to any table-level options that may be in use (seeSection 5.5.2, “Evaluation of Table-Level Replication Options”, for a discussion of these). If one or more database-level options are used but none are matched, the statement is not replicated.

For statements affecting databases only (that is,CREATE DATABASE,DROP DATABASE, andALTER DATABASE), database-level options always take precedence over any--replicate-wild-do-tableoptions. In other words, for such statements,--replicate-wild-do-tableoptions are checked if and only if there are no database-level options that apply.

To make it easier to determine what effect a given set of options has, it is recommended that you avoid mixingdo-*andignore-*options, or options containing wildcards with options which do not.

If any--replicate-rewrite-dboptions were specified, they are applied before the--replicate-*filtering rules are tested.

Note

All replication filtering options follow the same rules for case sensitivity that apply to names of databases and tables elsewhere in the MySQL server, including the effects of thelower_case_table_namessystem variable.