[MDEV-12953] Inconsistent mysqldump with --single-transaction using TokuDB Created: 2017-05-30 Updated: 2017-06-05 Resolved: 2017-06-05 |
|
| Status: | Closed |
| Project: | MariaDB Server |
| Component/s: | Backup, Documentation, Replication, Storage Engine - TokuDB |
| Affects Version/s: | 10.1.23 |
| Fix Version/s: | N/A |
| Type: | Bug | Priority: | Major |
| Reporter: | Aljaž Mežnarič | Assignee: | Ian Gilfillan |
| Resolution: | Fixed | Votes: | 0 |
| Labels: | replication, tokudb | ||
| Environment: |
Linux 3.16.0-4-amd64 (CentOS 7) |
||
| Attachments: |
|
| Description |
|
Words in bold should be replaced with values from your environment. Can't create a replication slave using "single-transaction": After dump/import is finished, replication will be broken (err.: HA_ERR_FOUND_DUPP_KEY). It looks like later transaction are visible to mysqldump. Steps to reproduce:
You will end up with a broken replication. A work-around is to use --lock-all-tables instead of --single-transaction. This will block all writes to the MASTER.HOST until the dump/import is complete. |
| Comments |
| Comment by Elena Stepanova [ 2017-06-02 ] |
|
Thanks for the test case, it was easy to reproduce. It is not a bug though, just lack of functionality in TokUDB. single-transaction feature depends not only on engine being transactional and capable of REPEATABLE-READ, but also on START TRANSACTION WITH CONSISTENT SNAPSHOT being supported. It is not the case with TokuDB, that's why it doesn't work. Same happens with upstream (TokuDB on Percona server 5.7). I suppose you could file a feature request for them to implement WITH CONSISTENT SNAPSHOT. Meanwhile, I think it deserves mentioning in documentation for mysqldump. Even though technically it indicates only InnoDB being supported for single-transaction, the focus is on the engine being transactional, so it's reasonable to assume that for TokuDB it should also work, which is not true. |
| Comment by Ian Gilfillan [ 2017-06-05 ] |
|
Added specific mention of tokudb not working in the mysqldump docs |