-
Notifications
You must be signed in to change notification settings - Fork 40
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
Speed issues in CMS #40
Comments
Hi remy,
Thanks for reporting,
I'll check this out and fix it.
Whats the number of blocks? Maybe i can repoduce problem by creating blocks
Best regards,
Bart
…________________________________
Van: Remy Vaartjes <notifications@github.com>
Verstuurd: donderdag 12 november 2020 09:25
Aan: hubertusanton/silverstripe-seo
Cc: Subscribed
Onderwerp: [hubertusanton/silverstripe-seo] Speed issues in CMS (#40)
We used this module in a lot of our sites and noticed a major decrease in speed of the CMS. Especially if used in combination with more complex pages with many elemental blocks, the CMS can become unusable. Each time a page is opened in the CMS, the frontend is completely rendered (templates and image resizing). This takes up a lot of resources and slows everything down. Removing the module increased CMS speeds from 20 seconds to 2 seconds loading time on heavy pages.
It would be better if the module only calculates the scores on request and not always.
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub<#40>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AAEOELHMFGWZNHUGRN7AQZTSPOLYRANCNFSM4TS7BFRA>.
|
Hi Bart, if you create a page with 10 blocks and another with only one block. You notice the speed difference between the two. Probably the larger the HTML source, the larger the images, the slower it gets. Of course one could argue, to make the frontend faster, but this is not always easy. Each time a user loads the page in the CMS the function getPageContent is called to render the entire HTML content and parse the DOM, but most of the time the module results are not needed, because user is only editing basic content:
The server I use has 4 cores and 8GB memory. PHP memory_limit set to 512MB. Regards, |
Hi remy, What about creating a setting to let a page type not reindex score always but do this reindexing score with a button/action in the cms? |
In my testing, I've worked out that loading the edit page in the cms CMS causes the frontend page to render 7 times. This is likely causing huge slowdowns considering that each call to getPageContent will also run any database queries invoked by the templates. Caching the return value of that function should speed up the score calculation. I'll make a PR for this, but I'm going to target v2.2.1 first as that's what we're currently using and upgrading isn't an option for us at the moment. |
In my tests just now, for a page with 2 blocks, caching the page content took load times from 23s to 5s. |
I can't create a PR for 2.2.1 since there's no branch pointing to that version 😢. Here's the code that I would have put in a PR public function getPageContent() {
static $cache = [];
if (!isset($cache[$this->owner->ID])) {
Config::inst()->update('SSViewer', 'theme_enabled', true);
$rendered_layout = $this->RenderLayout();
Config::inst()->update('SSViewer', 'theme_enabled', false);
$cache[$this->owner->ID] = $rendered_layout;
}
return $cache[$this->owner->ID];
} |
hi @OldStarchy That's a great load time improvement! Why are you using 2.2.1? |
Unfortunately upgrading to SS4 isn't an option for this project at the moment. If you could create a
So long as it makes sense, its probably good enough
I'll make 2 PRs, one for the |
@OldStarchy Thanks a lot, i created the 2 branch! Hope this helps |
During my testing on SS4 I've encountered an issue: silverstripe/silverstripe-framework#10106 |
We used this module in a lot of our sites and noticed a major decrease in speed of the CMS. Especially if used in combination with more complex pages with many elemental blocks, the CMS can become unusable. Each time a page is opened in the CMS, the frontend is completely rendered (templates and image resizing). This takes up a lot of resources and slows everything down. Removing the module increased CMS speeds from 20 seconds to 2 seconds loading time on heavy pages.
It would be better if the module only calculates the scores on request and not always.
The text was updated successfully, but these errors were encountered: