On 2020-Nov-24, Tom Lane wrote:
> I'm inclined to go ahead and commit the 0001 patch I posted at [1]
> (ie, change the implementation of GUC_REPORT to avoid intra-query
> reports), since that addresses a performance problem that's
> independent of the goal here. The rest of this seems to still
> be in Greg's court.
Sounded a good idea to me.
> Has anyone got an opinion about the further improvement I suggested:
>
> >> As it stands, 0001 reduces the ParameterStatus message traffic to
> >> at most one per GUC per query, but it doesn't attempt to eliminate
> >> duplicate ParameterStatus messages altogether. We could do that
> >> as a pretty simple adjustment if we're willing to expend the storage
> >> to remember the last value sent to the client. It might be worth
> >> doing, since for example the function-SET-clause case would typically
> >> lead to no net change in the GUC's value by the end of the query.
>
> On reflection this seems worth doing, since excess client traffic
> is far from free.
Agreed. If this is just a few hundred bytes of server-side local memory
per backend, it seems definitely worth it.