-
Notifications
You must be signed in to change notification settings - Fork 506
Startup SQL interactions with replication. #1576
Comments
It would be interesting/useful to know what the weird things that happen are and why they happen. This is also probably loosely related to the discussion at #1536. It might make sense to have recovery and replication be consistent with how they treat startup SQL, whether to read it from WAL/primary or just redo it themselves. |
I'm not sure I agree with the ordering assertion in A. Any replica will need access to all logs since the last checkpoint (or database init) as part of coming online. I think the larger question of "startup SQL commands" are what functionality they are doing. If these are things like bootstrapping the catalog on creating a database, then I think B sets us up for more pain whenever we incorporate checkpointing (since we need to avoid bootstrapping there as well). |
@jkosh44 Here's an example of how you can get weird things to happen:
In general right now, it will appear to work, in what I would argue is mostly a happy accident / bugprone overall. |
@jrolli Good point. Right now, all the startup SQL is for bootstrapping internal tables for self-driving stuff. By the above example, IMO we want to replicate these so that the replica has a true sense of "yup this is definitely the table I want to apply the insert or whatever to". We don't have a "give me all my missing logs" functionality right now; you're right that this would remove the ordering constraint. Updated to note that this is an implementation issue and not a design issue. |
@lmwnshn, looking at the code, the current Those concerns aside, though, I'm not convinced we want to replicate these tables since they appear to be tracking instance-specific information which may vary substantially between the primary and replicas (particularly if we allow replicas to answer read-only queries). |
Another good point (on whether internal tables should be replicated). Hmm. I'll poke people on Slack. |
Should startup SQL commands be replicated or not?
Currently, some SQL commands are just run on startup no matter what node you're on. Suppose the startup SQL included
create table foo (a int)
, for example.A. If the startup SQL is replicated, then the current implementation forces the following constraint: every replica must be brought up and ready before the primary is brought up. But this can be fixed (thanks @jrolli) if we take the time to implement a "give me my missing logs, my last log was X" feature.
B. If the startup SQL is not replicated, then weird things may happen if you refer to tables created by the startup process since the replica's RecoveryManager may be missing the oid mapping (haven't checked this).
I am inclined to say that we should go with A. But it is something to watch out for.
The text was updated successfully, but these errors were encountered: