Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migration on multiple node #72

Open
AndreiCrimezniuc opened this issue Oct 2, 2023 · 5 comments
Open

Migration on multiple node #72

AndreiCrimezniuc opened this issue Oct 2, 2023 · 5 comments

Comments

@AndreiCrimezniuc
Copy link

Is there way to run migrations on multiple nodes? If not it would be nice to see this feature.
My situation. 2 servers with two nodes in cluster. When I run all migrations to one node and then all migrations to another I face conflict like "ch is claiming " ERROR DB::Exception: Table columns structure in ZooKeeper is different from local table structure. Local columns:" because I had 10 column in tables, then added two more and all this in one node. But when I'm trying to do the same on second node it shows that Zookeeper already 'booked' this tables as 12-columns. So it needs something like - run one sql on frist node and then on second one, and then all query the same way

@vmihailenco
Copy link
Member

You are probably looking for ON CLUSTER mycluster:

ALTER TABLE mytable ON CLUSTER mycluster
ADD COLUMN ...

@AndreiCrimezniuc
Copy link
Author

This not gonna work. It really add alter table on all cluster, but when it runs old migrations for second nodes it shows error like "Dude, you trying to run sql for this table on second node, but you trying select field that doesn't exist because you deleted it in migrations on first node"

@AndreiCrimezniuc
Copy link
Author

So for consistency it needs to make in step by step for every node

@vmihailenco
Copy link
Member

You only need to run the migration once on a random node in the cluster.

@AndreiCrimezniuc
Copy link
Author

AndreiCrimezniuc commented Oct 6, 2023

I can't run migrations like INSERT ON CLUSTER. So the only one way is to be able run migrations one by one, not all. Trying to do it with you lib. It's good that most of you methods are public. We it would be nice not to invent wheel

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants