You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Jul 22, 2024. It is now read-only.
Because the headerWritten bool is both read and modified outside of the protection of the mutex multiple calls to writeHeader are needlessly made. I suggest moving the headerWritten bool onto the Header type and then inside writeHeader check if it's been set or exit.
The text was updated successfully, but these errors were encountered:
I haven't looked at this code in awhile, but how is headerWritten racy? I don't think the underlying http.ResponseWriter allows for any sort of concurrency, therefore the httpsnoop callbacks can't race either.
Also our second read of headerWritten is after ServeHTTP returns, and the net/http docs on ResponseWriter explicitly state that ResponseWriter calls must not be called after that point, so we can be safe there in reading the value and knowing we can't get a read/write race.
We have to protect writeHeader with a mutex because the actual go-server-timing metrics may be concurrently accessed. Actually, we expect them to be otherwise your server timing is probably just a waterfall. :)
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Because the
headerWritten
bool is both read and modified outside of the protection of the mutex multiple calls towriteHeader
are needlessly made. I suggest moving theheaderWritten
bool onto theHeader
type and then insidewriteHeader
check if it's been set or exit.The text was updated successfully, but these errors were encountered: