-
-
Notifications
You must be signed in to change notification settings - Fork 117
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
Add a covering index on tracks (album_id, length) #508
Conversation
use subqueries instead of a left join
thanks! @cascooscuro can you confirm if the issue is solved when checking out this branch? with read timeouts removed |
Sometimes I still get a timeout, but only have seen it when connecting to jamstash the first time:
For the rest of the operations like search, play I see it responds much quicker and have not timeouts. Maybe having the config option to modify the http timeout is good enough. Thanks both for your help. |
hmm maybe I'll just bump the timeout to 10 secs globally |
I'm assuming these calls come from here, and the timeout happens in I noticed that gonic reads entire Also, the join with albums for checking the directory is quite expensive, so if you have just one music folder, it's best to avoid sending the |
@lomereiter thanks very much for the work here 👌👌 going to test and ship this shortly also I think it makes sense to update the http logging middleware to print the response times for each request - making it easy for someone like @cascooscuro to identify endpoints which could be optimised for big libraries |
an update after the latest commit (1c7cb8f):
|
In my opinion, Jamstash is badly designed for big libraries, and there's only so much we can do on gonic side: right at the start Jamstash is simultaneously doing multiple heavy API calls. Compare to Supersonic behavior, for example:
|
I had yet another look at it, and added an index for the |
0c48a4f
to
cea3882
Compare
closes #508 Co-authored-by: Artem Tarasov <[email protected]>
thanks for the work here. i think the preload optimisations are a little brittle (manally selecting some fields, and hoping the spec.From functions will have everything the query returned) i think effort would be better spent upgrading to Gorm v2 which has preload via join like you mentioned. created an issue here #561 |
The covering index also includes length, so that SQLite can avoid reading the rows.
In my experiments with the DB provided by @cascooscuro (see #478), adding this index already helps to cut the query time from 2.8s to 1.0s. Replacing the join with subqueries cuts down the time further to 0.3s.
Query plan for the original query:
When using subqueries:
fixes #478