Closed
Bug 888666
Opened 11 years ago
Closed 6 years ago
Contacts API: mozContacts.getAll() seems slow
Categories
(Core Graveyard :: DOM: Contacts, defect, P5)
Tracking
(tracking-b2g:backlog)
RESOLVED
WONTFIX
tracking-b2g | backlog |
People
(Reporter: bkelly, Unassigned)
References
(Depends on 1 open bug)
Details
(Keywords: perf, Whiteboard: [c= p=5 s= u=][sprd314613])
Attachments
(1 file)
(deleted),
text/html
|
Details |
Currently mozContacts.getAll() seems abnormally slow. In a stripped down app that does nothing but call getAll() with no sorting or filtering options, it takes ~3.5 seconds to load 1000 contacts on my Buri.
While I know that a lot of good work has already gone into optimizing Contacts API, I can't help feeling that things are still unusually slow.
In an attempt to quantify this feeling I thought perhaps we could look at it in terms of bandwidth. If we call JSON.stringify().length on the 1000 contacts in reference-workload-heavy, we can approximate the amount information to be accessed at 645,628 bytes. This means we are accessing contact data at about 1.4Mbit/s from the app.
For comparison:
mozContacts.getAll(): 1.4 Mbit/s
802.11b: 11 Mbit/s
File system: 50 Mbit/s
Memory copy: 650 Mbit/s
(The file system was estimated using dd on a cold cache right after device boot. Memory bandwidth was estimated from dd on a hot cache.)
I understand this comparison is a bit unfair since contacts has to provide more functionality than simple data access, but I just wanted to show the differences for some rough perspective.
Considering that all of the contacts data is local to the device, the current mozContacts.getAll() numbers look a bit out of whack to me. They might seem reasonable if we were running over the network, but we're not.
This was all on a Buri using mozilla-central at 134166:12cdc8931e48.
In any case, I was not aware of a top level bug discussing this so I thought I would write my thoughts up. I hope this bug is not too controversial. From discussing the topic with various people it seems like its a known issue that we would like to address. It just seemed that it might be helpful to separate it out into its own bug.
Reporter | ||
Comment 1•11 years ago
|
||
The code for the simple test app I used to measure the contacts API on its own can be found here:
https://github.com/wanderview/gaia/tree/contacts-api-bench/test_apps/contacts-bench
Updated•11 years ago
|
Attachment #769421 -
Attachment mime type: text/plain → text/html
Comment 2•11 years ago
|
||
Just making a note that we should never ever use, or encourage people to use, getAll for the contacts API. Perhaps some performance investigation wouldn't hurt if we could speed up cursor methods though :)
Reporter | ||
Comment 3•11 years ago
|
||
(In reply to Kevin Grandon :kgrandon from comment #2)
> Just making a note that we should never ever use, or encourage people to
> use, getAll for the contacts API. Perhaps some performance investigation
> wouldn't hurt if we could speed up cursor methods though :)
mozContacts.getAll() does return a cursor. Are you thinking of IDB's mozGetAll()?
Comment 4•11 years ago
|
||
Ah right, I must be - ignore me. Sorry for the comment spam!
Updated•11 years ago
|
OS: Mac OS X → Gonk (Firefox OS)
Hardware: x86 → ARM
Whiteboard: [c= ]
Reporter | ||
Comment 5•11 years ago
|
||
One current working theory is that the locale based sorting outside of IDB is contributing to the slowdown. To fix that, however, we would need bug 871846.
Depends on: 871846
Reporter | ||
Comment 6•11 years ago
|
||
Bug 872741 would also help with these load times as it helps optimize the loading of the sort cache.
Depends on: 872741
Reporter | ||
Comment 7•11 years ago
|
||
Bug 873873 shows that IPC costs from parent to child process is a non-trivial part of the picture.
Depends on: 873873
Reporter | ||
Comment 8•11 years ago
|
||
I re-ran the benchmark with a recent m-c today:
Rev: 139136:4eeefa65fffa
Results: 3459ms, 3513ms, 3502ms, 3603ms, 3477ms
Content: 1000 contacts (reference-workload-heavy)
Reporter | ||
Comment 9•11 years ago
|
||
I rebased my contacts API bench app here today:
https://github.com/wanderview/gaia/tree/contacts-api-bench/test_apps/contacts-bench
And re-ran the benchmark again m-c:
Rev: 150676:3a486112072b
Results: 3900ms, 3913ms, 3915ms
Content: 1000 contacts (reference-workload-heavy)
It seems we have regressed about 10%.
Reporter | ||
Comment 10•11 years ago
|
||
Gregor, any idea what could have caused mozContacts.getAll() to regress by about 10%? Unfortunately I have quite a wide starting range between comment 8 and comment 9.
Flags: needinfo?(anygregor)
Reporter | ||
Comment 11•11 years ago
|
||
Note, I did change the contacts bench app to wait 15 seconds instead of 5 seconds before starting the test. I wanted to make sure there was no conflict with the pre-allocated process launch (which occurs on a 5 second delay).
Reporter | ||
Comment 12•11 years ago
|
||
I opened bug 927028 track the regression from comment 9.
Flags: needinfo?(anygregor)
Updated•11 years ago
|
Component: DOM: Device Interfaces → DOM: Contacts
Reporter | ||
Comment 13•11 years ago
|
||
We have regressed further due to the webidl change. See bug 931164. Recent numbers:
152235:2f2a45f04e7c + workaround patch from bug 929652: 4056ms, 4014ms, 4061ms
Reporter | ||
Updated•11 years ago
|
Status: NEW → ASSIGNED
QA Contact: bkelly
Reporter | ||
Updated•11 years ago
|
Whiteboard: [c= ] → [c= p=5]
Reporter | ||
Updated•11 years ago
|
Assignee: nobody → bkelly
QA Contact: bkelly
Reporter | ||
Comment 14•11 years ago
|
||
Speculatively setting a dependency on bug 768074 since it seems probably it could help here.
Also, dropping this from my current queue as I need to focus on 1.2 bugs.
Assignee: bkelly → nobody
Depends on: 768074
Reporter | ||
Updated•11 years ago
|
Status: ASSIGNED → NEW
Reporter | ||
Updated•11 years ago
|
Priority: -- → P3
Whiteboard: [c= p=5] → [c= p=5 s= u=]
blocking-b2g: --- → 1.3T?
Whiteboard: [c= p=5 s= u=] → [c= p=5 s= u=][sprd314613]
Comment 15•10 years ago
|
||
Can we improve this API performance for tarako only?
Flags: needinfo?(styang)
Updated•10 years ago
|
Flags: needinfo?(fabrice)
Comment 16•10 years ago
|
||
(In reply to James Zhang from comment #15)
> Can we improve this API performance for tarako only?
What do you want to improve? Whats the STR thats slow? Is it the first contact returned, the time to fetch all contacts? And whats the workload?
Comment 17•10 years ago
|
||
perf improvement. let's not block on this for tarako release unless it is extremely slow
blocking-b2g: 1.3T? → backlog
Updated•10 years ago
|
Flags: needinfo?(styang)
Updated•10 years ago
|
Flags: needinfo?(fabrice)
Assignee | ||
Updated•10 years ago
|
blocking-b2g: backlog → ---
tracking-b2g:
--- → backlog
Comment 19•6 years ago
|
||
DOM: Contacts isn't used anymore.
Closing all remaining bugs.
Status: NEW → RESOLVED
Closed: 6 years ago
Resolution: --- → WONTFIX
Updated•6 years ago
|
Product: Core → Core Graveyard
You need to log in
before you can comment on or make changes to this bug.
Description
•