So, if its not a locking scheme, what can block hundreds of transaction to get to the secondary ???
The transactions are present on the secondary. It just realizes that applying them may cause problems (think drop table or truncate) and so it chooses not to until local queries have completed. Since WAL is strictly linear all sessions are affected. There is no locking needed, or IIUC even possible, and MVCC is not applicable as it only concerns itself with the behavior lf the writable primary system.
I suspect there are better attempts at describing this than my half-conscious effort here, though I’ve captured the crux of it - streaming WAL is its own unique thing.
David J.