Page MenuHomePhabricator

Provide "bin/storage analyze" and make "bin/storage upgrade" run analysis automatically
ClosedPublic

Authored by epriestley on Sep 7 2017, 8:40 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Mar 23, 5:42 PM
Unknown Object (File)
Sat, Mar 23, 5:42 PM
Unknown Object (File)
Sat, Mar 23, 5:42 PM
Unknown Object (File)
Sat, Mar 23, 5:42 PM
Unknown Object (File)
Sat, Mar 16, 10:04 AM
Unknown Object (File)
Fri, Mar 15, 1:50 PM
Unknown Object (File)
Fri, Mar 1, 3:15 AM
Unknown Object (File)
Feb 25 2024, 4:30 PM
Subscribers
None

Details

Summary

Ref T12819. Normallly "ANALYZE TABLE" is like sprinkling magic pixie dust on the database and hoping it will make "good vibes" that cause it to go faster, but in at least some concrete cases with the ngrams tables there really was a key cardinality issue which ANALYZE TABLE corrected, fixing bogus query plans.

Add bin/storage analyze to analyze all tables, and make bin/storage upgrade run it after adjustment if --no-adjust is not specified, and make bin/storage adjust run it always.

This runs in a couple seconds and should never hurt anything, so it should be fine to sprinkle lots of pixie dust into the bin/storage workflow.

Test Plan

Ran bin/storage analyze. Ran bin/storage upgrade, saw analyze run. Totally felt great vibes and really aligned chakras on the database.

Diff Detail

Repository
rP Phabricator
Branch
analyze1
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 18383
Build 24752: Run Core Tests
Build 24751: arc lint + arc unit