1.6 KiB
How?
How does the cut-over work? Is it really atomic?
The cut-over phase, where the original table is swapped away, and the ghost table takes its place, is an atomic, blocking, controlled operation.
- Atomic: the tables are swapped together. There is no gap where your table does not exist.
- Blocking: all app queries involving the migrated (original) table are either operate on the original table, or are blocked, or proceed to operate on the new table (formerly the ghost table, now swapped in).
- Controlled: the cut-over times out at pre-defined threshold, and is atomically aborted, then re-attempted. Cut-over only takes place when no lags are present, and otherwise no throttling reason is found. Cut-over step itself gets high priority and is never throttled.
Read more on cut-over and on the cut-over design Issue
Is it possible to?
Is it possible to add a UNIQUE KEY?
Adding a UNIQUE KEY
is possible, in the condition that no violation will occur. That is, you must make sure there aren't any violating rows on your table before, and during the migration.
At this time there is no equivalent to ALTER IGNORE
, where duplicates are implicitly and silently thrown away. The MySQL 5.7
docs say:
As of MySQL 5.7.4, the IGNORE clause for ALTER TABLE is removed and its use produces an error.
It is therefore unlikely that gh-ost
will support this behavior.
Run concurrent migrations?
Yes. TL;DR if running all on same replica/master, make sure to provide --replica-server-id
. Read more