-
Notifications
You must be signed in to change notification settings - Fork 0
Page class that emphasizes performance #590
Comments
This is super impressive! The inventory part has always been tricky in order to get all the functionality built in without messing up the performance too much. Your performance optimizations clearly show how many trade-offs are still made in order to get the correct template or keep the constructor easy to extend. I would love to have a way to improve this. Maybe even on config settings. |
I wonder if we could do something like this: /notes/index.php return [
'model' => 'NotesPage',
'template' => 'notes',
'children' => [
'template' => 'note',
'model' => 'NotePage',
]
]; I'm not entirely sure about the naming of that file yet, but if Kirby finds such a file it would automatically load that and optimize the Page class according to those settings. |
@bastianallgeier where would that Also, using a different |
In the panel, even with the optimizations from my first comment, the pages section for the
...takes |
My guess is that effect is only noteworthy for large collections? So usually the developers know when they handle that kind of large content. So why not have an extra param for the page method? E. g. |
You are probably right that models are a better place for that. I know why that loop is slow. It's all about the |
@nilshoerrmann the developers know it, yes, but Kirby doesn't. Therefore, the panel will still be slower. By using a page model, everything is faster. I actually prefer it because all logic is self-contained. If I decide that I don't need this performance boost at some point or it causes a huge issue, I can simply delete the page model. No refactors needed. |
@bastianallgeier continuing with the panel, the other slow request I found out was with the single-page view, i.e. the
...takes I'm very excited because with this, the huge amount of data makes no difference to the user experience. It feels as if I'm navigating a site with 10 pages, not 10000. It's unbelievable... |
@bastianallgeier further digging in the It seems that allowing Kirby to assume the template of a page can bring tremendous performance boosts. Edit: Come to think of it... you can extend the class NotePage extends Page
{
public function intendedTemplate()
{
if ($this->intendedTemplate !== null) {
return $this->intendedTemplate;
}
return $this->setTemplate('note')->intendedTemplate();
}
} And it's also kind of a no-brainer. If a page uses the |
I added some more pages and I'm testing with exactly 100,000 now.
|
Holy shit! Your research is pure gold! I wonder if it makes sense to start thinking about cashing those bottlenecks for pages where models don't work/exist. |
There might be a clever way to cache, but I'm pretty sure that models will be needed to provide the best possible result. For example, indexing 10,000 pages without any optimizations takes However, sorting the files is a feature that users will want in 90% of the cases. But for the other 10% where performance is more important - that'll be a problem. I believe the solution isn't to pick one or the other, but to give developers the option pick the one they need. Maybe we can "toggle" features like that with static properties. For example: class NotesPage extends Page
{
public static $natsort = false;
} |
Couldn't these toggles be set inside the blueprints? |
@nilshoerrmann it would erase all performance benefits if we need to parse the blueprint first. |
Right. I was just asking because it's getting hard to keep track of all settings if they spread across so many places in a project (blueprint, core, model). This is especially true when you're getting back to a project after a few months. And blueprints are usually the place where sorts, templates and such a set up. So this needs to be documented carefully. |
I agree with @nilshoerrmann and @hdodov that introducing more and more concepts (like a special performance optimization config file) would make it all a lot more confusing. From all the variants discussed in this issue, my favorite is putting the options into the model. Advantages: Kirby wouldn't need to load extra files and as this is an advanced feature, it fits quite well into the model. What about an array for all such options: <?php
class NotesPage extends Page
{
protected static $performanceOptions = [
...
];
} Our core |
@lukasbestle: In order to make it easier to understand what's happening in an install, it would be great if such performance options were printed (if set) when using the |
That's doable! 👍 |
I'm testing the performance of Kirby with large volumes of content. I have a page with 13,000 children and running:
...takes
1.14289
seconds on average. However, running:...takes just
0.01498
seconds. That's a lot quicker and it got me thinking... if the file system is so fast, perhaps there's a way to cut some corners and preserve that speed?I managed to get a huge performance boost by simplifying the internal
inventory()
method via a custom page model:Now, running:
...takes just
0.17732
seconds. That's already 644% faster, while you don't lose much functionality. A simpleis_dir()
call increases that time to0.44538
...To save even more time, I can change
'model' => null
to'model' => 'note'
and assume that all child pages have thenote
template. Then, in that model, I greatly simplify the constructor:...and this brings the time down to
0.03485
seconds!I'm sure we could save a lot of time by skipping or hardcoding parts of the logic. Kirby could provide a
QuickPage
class that functions the same way as thePage
class, but takes a lot more shortcuts to improve performance. Then, you can extend that class in your custom page models to get the benefit. Static properties could be used for configuration. For example:Then, since child pages are assumed to be of template
note
, you can useQuickPage
for them as well:The text was updated successfully, but these errors were encountered: