Closed
Bug 553266
Opened 15 years ago
Closed 14 years ago
config.cgi?ctype=rdf spends most of its time loading flagtypes from the database
Categories
(Bugzilla :: Bugzilla-General, defect)
Tracking
()
RESOLVED
FIXED
Bugzilla 3.6
People
(Reporter: mkanat, Assigned: LpSolit)
References
Details
Attachments
(1 file, 2 obsolete files)
10.16 KB,
patch
|
LpSolit
:
review+
|
Details | Diff | Splinter Review |
On a copy of the bmo database on my local machine, the RDF format of config.cgi takes 9 seconds to process data. A DBI profile shows that it's spending most of its time loading flag types from the database with SQL statements like this:
SELECT flagtypes.id,flagtypes.name,flagtypes.description,flagtypes.cc_list,flagtypes.target_type,flagtypes.sortkey,flagtypes.is_active,flagtypes.is_requestable,flagtypes.is_requesteeble,flagtypes.is_multiplicable,flagtypes.grant_group_id,flagtypes.request_group_id FROM flagtypes WHERE id IN (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) ORDER BY flagtypes.sortkey, flagtypes.name
And then probably a fair bit of time is spent creating the flagtype objects, as well.
Perhaps adding a parameter to Bugzilla::Product::preload() to load all the flagtypes at once would be a good idea?
Assignee | ||
Comment 1•15 years ago
|
||
(In reply to comment #0)
> And then probably a fair bit of time is spent creating the flagtype objects,
> as well.
This SQL query is called by FlagType->new_from_list(), so we don't waste additional time creating objects.
It's being called once per component because the inclusion/exclusion lists make it pretty difficult to load all flagtypes objects at once and then triage them per component.
Reporter | ||
Comment 2•15 years ago
|
||
(In reply to comment #1)
> It's being called once per component because the inclusion/exclusion lists make
> it pretty difficult to load all flagtypes objects at once and then triage them
> per component.
Yeah, difficult, but not impossible. You could create a data structure that mapped the *clusions to components.
Assignee | ||
Comment 3•14 years ago
|
||
$product->flag_types now gets all flag types at once, and then triages them per component, rather than collecting each component's flag types one by one. I also cache flag types to be used across products, as I did with bug flags in bug 552167. This highly decreases the number of SQL queries, see the next paragraph. I also did another nice optimization in $component->flag_types where I collect bug flag types and attachment flag types at once, and triage them from here. This single optimization decreases the number of SQL queries by a factor 2.
On my test installation, with 17 products, 2025 components and 11 flag types, the time spent to display config.cgi in RDF format goes from 6.7s down to 3.4s. Also, the number of SQL queries goes from 4050 (twice per component) down to 39 (once per product + twice per flag type)! 1% only! :)
mkanat, could you test this patch on your local copy of bmo and tell me how big is the improvement? I'm confident about the code itself (it is in code I own).
Assignee | ||
Comment 4•14 years ago
|
||
For 3.6.3, we should only backport the trivial and safe optimization in Bugzilla::Component, so that we decrease the number of SQL queries by a factor 2.
Target Milestone: Bugzilla 4.0 → Bugzilla 3.6
Reporter | ||
Comment 5•14 years ago
|
||
Comment on attachment 484304 [details] [diff] [review]
patch, v1
Okay, this takes the time on my local copy of bmo from 13 seconds to 6.5 seconds. That's pretty good, considering that with "flags=0" it's 4 seconds. So now it only takes 2.5 seconds to generate and output the flags data. (And my local copy is considerably slower than the real bmo.)
I'll let you r+ this since you're the module owner.
Attachment #484304 -
Flags: review?(mkanat)
Assignee | ||
Comment 6•14 years ago
|
||
OK, thanks for the test. It's a nice improvement. :) As I said in comment 4, I will only take the change in Bugzilla::Component for 3.6, which is safe and not invasive.
Flags: approval4.0+
Flags: approval3.6+
Flags: approval+
Assignee | ||
Comment 7•14 years ago
|
||
Comment on attachment 484304 [details] [diff] [review]
patch, v1
r=me as module owner.
Attachment #484304 -
Flags: review+
Assignee | ||
Comment 8•14 years ago
|
||
Optimized patch, which uses hashes instead of grep'ing through strings. mkanat, what's the improvement now?
Attachment #484304 -
Attachment is obsolete: true
Attachment #484537 -
Flags: review+
Reporter | ||
Comment 9•14 years ago
|
||
Looks like it's a full second faster--I'm getting 5.5 seconds now. I'm going to check the NYTProf of it too, just to make sure there's nothing else important that could get better.
Reporter | ||
Comment 10•14 years ago
|
||
So just FYI, if you cache the inclusions_as_hash and exclusions_as_hash instead, you might get a faster patch. Looks like most of the time now is spent calling those:
spent 764ms making 103930 calls to Bugzilla::FlagType::inclusions_as_hash, avg 7µs/call
spent 697ms making 103930 calls to Bugzilla::FlagType::exclusions_as_hash, avg 7µs/call
Assignee | ||
Comment 11•14 years ago
|
||
I'm surprised this makes a difference. Bugzilla::FlagType->inclusions already caches the data, so Bugzilla::FlagType->inclusions_as_hash is supposed to directly get the data being in the cache from inclusions(). But avoiding a useless call to inclusions() indeed saves some extra 0.1s (looks like calling a method is slow, independently of what it does).
Attachment #484537 -
Attachment is obsolete: true
Attachment #484556 -
Flags: review+
Assignee | ||
Comment 12•14 years ago
|
||
Committing to: bzr+ssh://lpsolit%40gmail.com@bzr.mozilla.org/bugzilla/trunk/
modified config.cgi
modified Bugzilla/Component.pm
modified Bugzilla/FlagType.pm
modified Bugzilla/Product.pm
Committed revision 7550.
Committing to: bzr+ssh://lpsolit%40gmail.com@bzr.mozilla.org/bugzilla/4.0/
modified config.cgi
modified Bugzilla/Component.pm
modified Bugzilla/FlagType.pm
modified Bugzilla/Product.pm
Committed revision 7446.
Committing to: bzr+ssh://lpsolit%40gmail.com@bzr.mozilla.org/bugzilla/3.6/
modified Bugzilla/Component.pm
Committed revision 7191.
Status: ASSIGNED → RESOLVED
Closed: 14 years ago
Resolution: --- → FIXED
You need to log in
before you can comment on or make changes to this bug.
Description
•