Hi Kristian, Thanks for kicking this thread off. I have had a bit of a busy week so it has taken a while to get around summarizing Continuent thoughts on improvements. First of all, we Continuent Tungsten folk have a certain set of problems we solve with replication. Here are the key use cases: 1. Making full DBMS copies for high availability and to scale reads (traditional MySQL use pattern). For this we need simple, fast replication of all databases as well as the ability to provision efficiently from full database copies. 2. Supporting scalable data topologies for SaaS and other complex database architectures that have multiple services generating and receiving data. This can include patterns like: * Mastering data in two locations and replicating into a single server * Multi-master replication across sites * Replicating different sets of data from one master to different slaves 3. Replicating heterogeneously between MySQL and other database like Oracle. This requires the ability to filter and transform data easily. Another use case of heterogeneous replication is copying across databases of the same for application upgrades and migration between database versions. 4. Ensuring full data protection such that data, once committed, are not lost or corrupted. This includes replicating [semi-]synchronously to slaves, performing consistency checks on data, performing point-in-time restoration of data (e.g., using backups + a change log), etc. We can do these things for the most part with MySQL replication as it currently stands by reading binlogs and taking things from there. (That's how Tungsten works). Here are some features that would make it easier to work with the existing replication implementation: 1.) Synchronous replication. It's enough if replication slaves can hold up commit notices on the master. The MySQL 5.5 features look like a good start but I have not started the implementation and have therefore not hit the sharp corners. 2.) CRCs. CRCs and other built-in features like native consistency checks seem like the most glaring omission in the current binlog implementation. It's difficult to ensure correct operation without them, and indeed I'm confident many MySQL bugs can be traced back to the lack of features to make data corruption more easily visible. 3.) Self-contained transactions with adequate metadata. Row replication does not supply column names or keys which makes SQL generation difficult especially when there are differences in master and slave schema. Also, session variables like FOREIGN_KEY_CHECKS affect DDL but are not embedded in the transaction where they are used. Finally, character set support is a little scary based on my one experience in that area. You have to read code to get master lists of character sets; semantics are very unclear. 4.) Global transaction IDs. We put can these in ourselves but it would be even better if MySQL generated them in the logs so we can just use the binlog directly. Unlike Galera, we don't require sequence numbers to be without gaps; it's enough if they are comparable and monotonically increasing. (I don't even think forbidding gaps is a good idea but Alexey and I need to discuss that over a beer in Helsinki.) Also, transactions IDs need an unambiguous source ID or epoch number encoded in the ID so that you can detect diverging serialization histories. This nasty little problem that can lead to big accidents in the field. 5.) Simple-to-read formats. The binlog structure has grown pretty hairy over the years. I would love to have protobuf messages like what Drizzle is doing. 6.) Fewer bugs and weirdnesses. Handling of commits in the binlog has switched back and forth over the years. Mark Callaghan has documented some of the strange XA behavior and persistent holes in the protocol in this area. Statement replication support has led to some kludges make you feel faint when looking at them. (Example: temp tables, which basically don't work.) In fact, you could summarize 2-6 as making the binlog (whether written to disk or not) into a consistent "database" that you can move elsewhere and apply without having to add extra metadata, such as global IDs or table column names. Currently we have to regenerate the log which is a huge waste of resources and also have to depend external information to derive schema definitions. Finally, since there is already talk about rewriting replication from scratch, I would like to point out for the sake of discussion a few things that the current MySQL replication in my opinion does well. Any future system must match them. 1.) Serialized transactions. MySQL provides a list of transactions in serial order. All robust replication solutions this, and MySQL essentially gives it to you modulo problems with XA and ill-behaved table types like MyISAM that don't have guaranteed durability. 2.) Fast. MySQL replication really rips as long as you don't have slow statements that block application on slaves or don't hit problems like the infamous InnoDB broken group commit bug (#13669) reported by Peter Zaitsev. 3.) Network protocol. The network protocol for slaves is an excellent feature. It means you can fetch events and build new forms of replication without adding native code, which is a huge productivity boost. 4.) Robust. There is no lack of problems with MySQL replication but realistically any new implementations will have a high bar to function equally well. Plugin approaches like that used by Drizzle are very flexible but they also tend to have a kick-the-can-down-the-road effect in that it's up to plugins to provide a robust implementation. This in turn takes a long time to do well unless plugins cut down the problem size, for example by omitting statement replication. 5.) Works now. Starting from something that already works is sometimes the best approach. Radically new approaches take a long time to pay off and more often than not fail to see the light of day. One final suggestion I would propose is that it might make sense to take a two-pronged approach to replication as follows: * Logical replication based on an enhanced form of today's MySQL replication with substantial clean-up of existing code, simplification/enhancement of binlog event formats, and other features that we can readily agree upon in short order. * Physical replication based on change-sets that can be applied at the level of storage engine recovery logs. (Databases like MyISAM with no logs don't get to play.) PostgreSQL has this now and it's really great. This might be where to fit in the Galera ideas. Since this approach would be completely new it could also take a more radical line without wrecking what is already there. It would also fill a gap in the MySQL architecture--while there has been logical replication for many years, there is no physical replication. Anyway, I look forward to further discussion Cheers, Robert (On behalf of Continuent and Tungsten) On 1/22/10 6:21 AM PST, "Kristian Nielsen" <knielsen@knielsen-hq.org> wrote:
The three companies Continuent, Codership, and Monty Program are planning to start working on some enhancements to the replication system in MariaDB, together with anyone interested in joining in.
At this stage, there are no fixed directions for the project, and to do this in as open a way possible with the maximum community involvement and interest, we agreed to start with an email discussion on the maria-developers@ mailing list. So consider it started!
The plan so far is:
1) The parties taking this initiative, MP, Continuent, and Codership, present their own ideas in this thread on maria-developers@ (and everyone else who wants to chime in at this stage).
2) Once we have some concrete suggestions as a starting point, we use this to reach out in a broader way with some blog posts on planetmysql / planetmariadb to encourage further input and discussions for possible directions of the project. Eventually we want to end up with a list of the most important goals and a possible roadmap for replication enhancements.
(It is best to have something concrete as a basis of a broad community discussion/process).
To start of, here are some points of interest that I collected. Everyone please chime in with your own additional points, as well as comments and further details on these one.
Three areas in particular seem to be of high interest in the community currently (not excluding any other areas):
- High Availability * Most seems to focus on building HA solutions on top of MySQL replication, eg. MMM and Tungsten. * For this project, seems mainly to be to implement improvements to replication that help facilitate improving these on-top HA solutions. * Tools to automate (or help automate) failover from a master. * Better facilities to do initial setup of new slave without downtime, or re-sync of an old master or slave that has been outside of the replication topology for some period of time.
- Performance, especially scalability * Multi-threaded slave SQL thread. * Store the binlog inside a transactional engine (eg. InnoDB) to reduce I/O, solve problems like group commit, and simplify crash recovery.
- More pluggable replication * Make the replication code and APIs be more suitable for people to build extra functionality into or on top of the stock MySQL replication. * Better documentation of C++ APIs and binlog format. * Adding extra information to binlog that can be useful for non-standard replication stuff. For example column names (for RBR), checksums. * Refactoring the server code to be more modular with APIs more suitable for external usage. * Add support for replication plugins, types to be determined. For example binlog filtering plugins?
It is also very important to consider the work that the replication team at MySQL is doing (and has done). I found a good deal of interesting information about this here:
http://forge.mysql.com/wiki/MySQL_Replication:_Walk-through_of_the_new_5.1_a... _6.0_features)
This describes a number of 6.0/5.4 and preview features that we could merge and/or contribute to. Here are the highlights that I found:
- Features included in 6.0/5.4 (which are cancelled I think, but presumably this will go in a milestone release): * CHANGE MASTER ... IGNORE_SERVER_IDS for better support of circular replication. * Replication heartbeat. * sync_relay_log_info, sync_master_info, sync_relay_log, relay_log_recovery for crash recovery on slave. * Binlog Performance Optimization (lock contention improvement). * Semi-synchronous Replication, with Pluggable Replication Architecture. http://forge.mysql.com/wiki/ReplicationFeatures/SemiSyncReplication
- Feature previews: * Parallel slave application: WL#4648 http://forge.mysql.com/wiki/ReplicationFeatures/ParallelSlave * Time-delayed replication: WL#344 http://forge.mysql.com/wiki/ReplicationFeatures/DelayedReplication * Scriptable Replication: WL#4008 http://forge.mysql.com/wiki/ReplicationFeatures/ScriptableReplication * Synchronous Replication.
Drizzle is also doing work on a new replication system. I read through the series of blog posts that Jay Pipes wrote on this subject. They mostly deal with how this is designed in terms of the Drizzle server code, and is low on detail about how the replication will actually work (the only thing I could really extract was that it is a form of row-based replication). If someone has links to information about this that I missed, it could be interesting.
Let the discussion begin!
- Kristian.
_______________________________________________ Mailing list: https://launchpad.net/~maria-developers Post to : maria-developers@lists.launchpad.net Unsubscribe : https://launchpad.net/~maria-developers More help : https://help.launchpad.net/ListHelp