-
Notifications
You must be signed in to change notification settings - Fork 37
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
elaborate on stalled
or blocked
stage in specs
#164
Comments
We don't expose "blocked" time in RT today, why/how would a non-normative section be helpful, if that data is not exposed? For context, some previous discussions on this topic: https://lists.w3.org/Archives/Public/public-web-perf/2015Jan/0000.html |
I believe steve has covered pretty much of the reason why we should do this in his thread. The above breakdown graph of a resource timing is so popular that I've been seeing many engineers (even senior ones without much knowledge of web performance) who actually thinks that loading a resource just consists of the stages illustrated in the graph, and often get confused why If we don't expose btw, I'm new to the Web Performance group and I'm not sure whether the mailing list or Github issue is suitable for discussing this kind of issue. |
Discussing this on the issue is fine. I have no objections for a note (even if, in an H2 world, "stall" time is not necessarily relevant, at least with current implementations). |
If I understand correctly, even with H2 implemented, loading a resource might still get stalled or blocked for reasons other than TCP connection limit, as stated in google chrome's documentation, some sort of vendor-specific resource loading priority mechanism? |
Implementations are free to continue queueing in H2, it's just not as common in current ones. |
@jasonslyvia I agree that the nebulous blocked/queued/stalled period(s) can be confusing when looking at ResourceTiming data, and when seeing how existing timestamps fit into the handy RT diagram. In practice, I think it's not just the TCP connection limit (called Queued/Stalled in Chrome and Blocked in FF), but can be other additional "missing" times between phases due to browser quirks or stalls in processing. When we're gathering RUM data, we're actually making sure to collect all individual phase start/end timestamps (e.g. both Here's the simplistic calculation we're using to calculate some part of "blocking" time:
The above relies on same-origin or TAO-powered resources, and doesn't account for other "stalled" phases. I don't think we can realistically add a Would you be able to share the non-normative text you're thinking about? I agree that highlighting this issue can be useful to new developers that are first looking at bulk ResourceTiming data. |
Marking as L3 as this doesn't seem blocking. |
I've opened #169 and really glad if you can take a look |
Illustrate that timestamps are not necessarily consecutive Closes #164
Devtools of modern browsers all got this handy waterfall graph for each resource timing, although well explained in each vendors' documentation (google, firefox), I think it will help more people to get the gist of how resource is loaded if we add some non-normative section in the spec to elaborate on the
stalled
orqueued
duration.If this seems to be feasible, I'd like to send a pull request regarding this issue.
screenshot of resource timing graph on Google Chrome
screenshot of resource timing graph on Mozilla Firefox
The text was updated successfully, but these errors were encountered: