README ¶
Filter
filter provides a library to filter replicate on schema/table by given rules
Rules
rules like replication rules in MySQL, ref document: hhttps://dev.mysql.com/doc/refman/8.0/en/replication-rules-db-options.html https://dev.mysql.com/doc/refman/8.0/en/replication-rules-table-options.html
Priority and Key Points
- DoDBs > IgnoreDBs
- which rules to use?
- If there are some DoDB rules, only use DoDB Rules
- Otherwise if there are some IgnoreDB rules, use IgnoreDB rules
- tables that are not filtered out or there are empty DoDBs/IgnoreDBs rules would go to filter on DoTables/IgnoreTables rules
- which rules to use?
- DoTables > IgnoreTables
- if there are DoTable Rules, but no one is matched, we would ignore corresponding table
Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( // DMHeartbeatSchema is the heartbeat schema name DMHeartbeatSchema = "DM_HEARTBEAT" // DMHeartbeatTable is heartbeat table name DMHeartbeatTable = "HEARTBEAT" // InformationSchemaName is the `INFORMATION_SCHEMA` database name. InformationSchemaName = "INFORMATION_SCHEMA" // PerformanceSchemaName is the `PERFORMANCE_SCHEMA` database name. PerformanceSchemaName = "PERFORMANCE_SCHEMA" // MetricSchemaName is the `METRICS_SCHEMA` database name. MetricSchemaName = "METRICS_SCHEMA" // InspectionSchemaName is the `INSPECTION_SCHEMA` database name InspectionSchemaName = "INSPECTION_SCHEMA" )
Functions ¶
func IsSystemSchema ¶
IsSystemSchema checks whether schema is system schema or not. case insensitive
Types ¶
type ActionType ¶
type ActionType bool
ActionType is do or ignore something
const ( Do ActionType = true Ignore ActionType = false )
builtin actiontype variable
type Filter ¶
Filter implements whitelist and blacklist filters.
func (*Filter) ApplyOn ¶
ApplyOn applies filter rules on tables rules like https://dev.mysql.com/doc/refman/8.0/en/replication-rules-table-options.html https://dev.mysql.com/doc/refman/8.0/en/replication-rules-db-options.html
type Rules ¶
type Rules struct { DoTables []*Table `json:"do-tables" toml:"do-tables" yaml:"do-tables"` DoDBs []string `json:"do-dbs" toml:"do-dbs" yaml:"do-dbs"` IgnoreTables []*Table `json:"ignore-tables" toml:"ignore-tables" yaml:"ignore-tables"` IgnoreDBs []string `json:"ignore-dbs" toml:"ignore-dbs" yaml:"ignore-dbs"` }
Rules contains Filter rules.