Open Bug 1673764 Opened 4 years ago Updated 4 years ago

Reduce frequency of all-zones GCs

Categories

(Core :: JavaScript: GC, enhancement, P3)

enhancement

Tracking

()

People

(Reporter: sfink, Unassigned)

References

(Depends on 1 open bug, Blocks 1 open bug)

Details

Right now when we schedule a partial (zonal) GC, we also fire off a 60 second timer to do a full (all zones) GC. If we do another zonal GC while a full GC is pending, we won't queue up another one, but I would expect this to still be a major source of all-zones GCs.

Telemetry on Nightly shows 30% of GCs being all-zones. That seems unnecessarily high to me.

I propose reducing the number of these full GCs. I was thinking of clever heuristics, but honestly all-zones GCs are mostly fallback GCs anyway and it seems like the current setup is pretty reasonable -- if you do a GC, then there's memory activity, so be sure to eventually do a full GC in case there are cycles between zones.

So I'm thinking of increasing the delay from 1 minute to 10 minutes.

Note that I think there are still other reasons why we might choose to do a full GC, so hopefully the timing of this backstop isn't critically important in the cases that need it.

No longer blocks: GCScheduling
Depends on: 1675153
Flags: needinfo?(bugs)

I wonder if 10min full GC causes issues when running tests.
Could we try first something a bit less radical? 5 mins?
Such change should already change telemetry numbers.

Flags: needinfo?(bugs)

(In reply to Olli Pettay [:smaug] from comment #1)

I wonder if 10min full GC causes issues when running tests.

Yes it could. I'd like it if our scheduling handled running tests without resorting to these timed full GCs.

Oh. I hadn't realized that these GCs were used for that purpose. Yeah, resolving that somehow seems like a blocker for this, then.

How well do we know why these are needed? Is it that the zones involved don't get scheduled, or they get scheduled early but then never get scheduled again, or what? I have some ideas, but I'm not sure whether they apply to what's going on here.

Blocks: GCScheduling
You need to log in before you can comment on or make changes to this bug.