On Sun, Mar 20, 2022 at 12:03 AM Robert Haas <robertmh...@gmail.com> wrote: > > On Fri, Mar 18, 2022 at 12:39 AM Dilip Kumar <dilipbal...@gmail.com> wrote: > > > One question that occurred to me when looking this over is whether, or > > > why, it's safe against concurrent smgr invalidations. > > > > We are only accessing the smgr of the source database and the > > destination database. And there is no one else that can be connected > > to the source db and the destination db is not visible to anyone. So > > do we really need to worry about the concurrent smgr invalidation? > > What am I missing? > > A sinval reset can occur at any moment due to an overflow of the > queue. That acts as a universal reset of everything. So you can't > reason on the basis of what somebody might be sending.
I thought that way because IIUC, when we are locking the database tuple we are ensuring that we are calling ReceiveSharedInvalidMessages() right? And IIUC ReceiveSharedInvalidMessages(), is designed such a way that it will consume all the outstanding messages and that's the reason it loops multiple times if it identifies that the queue is full. And if my assumption here is correct then I think it is also correct that now we only need to worry about anyone generating new invalidations and that is not possible in this case. -- Regards, Dilip Kumar EnterpriseDB: http://www.enterprisedb.com