Forums / Install & configuration / Static Cache configuration

Static Cache configuration

Author Message

Fabio Carissimi

Thursday 01 February 2007 12:29:45 am

Hi,

I have set up the static cache for my website like described in Bård Farstad's article.
(cf http://ez.no/community/articles/ez_publish_performance_optimization_part_3_of_3_practical_cache_and_template_solutions/static_cache ).

The sites is very fast now but there is something I still don't understand.
When an object is published the static cache file is not replaced.

I have many sites and siteaccesses on my server and what I want is to have only one site to be cached.
assuming I want the siteaccess 'mysite' to be cached and having 'myadminsite' for the admin interface.

I have settings like that :

in settings/ovverride/site.ini.append.php:
[ContentSettings]
StaticCache=enabled

in settings/ovverride/staticcache.ini.append.php:
[CacheSettings]
# A list of site accesses to generate static content for
CachedSiteAccesses[]
CachedSiteAccesses[]=mysite

CachedURLArray[]=/

in settings/siteaccess/myadminsite/site.ini.append.php:
[ContentSettings]
StaticCache=enabled

in settings/siteaccess/mysite/staticcache.ini.append.php:
[CacheSettings]
HostName=myhost.com
StaticStorageDir=static/mysite
MaxCacheDepth=5

# A list of url's to cache. You can use the * wildcard to include a whole
# subtree.
CachedURLArray[]=/
CachedURLArray[]=/mysubtree*

# A list of locations that will be updated whenever an object is published. You
# can NOT use a wildcard here.
AlwaysUpdateArray[]
AlwaysUpdateArray[]=/

What is missing or wrong ? What can I do to have the static cache files replaced when an object is published ?

Thanks for help

Fabio Carissimi

Fabio Carissimi

Friday 09 February 2007 9:48:56 am

Hello,
I have still the same configuration and I made the corrections suggested
in this issue http://issues.ez.no/9126 in the file kernel/classes/ezstaticcache.php.

But it is still not working,
Can somebody tell me what can I do to make it work ?

thanks

Fabio Carissimi

Wednesday 14 February 2007 9:05:52 am

there is still nobody who can help ???

Kristof Coomans

Wednesday 14 February 2007 11:06:53 pm

Hi Fabio

Which eZ publish version are you using?

Are you using URL based site accesses? If yes, good. If no, bad for the static caching system, it only works with URL based site accesses.

I'd try another approach with the settings. Place every setting related to static cache configuration in settings/override/staticcache.ini.append.php:

[CacheSettings]
HostName=myhost.com
StaticStorageDir=static
MaxCacheDepth=5

# A list of site accesses to generate static content for
CachedSiteAccesses[]
CachedSiteAccesses[]=mysite

CachedURLArray[]=/
CachedURLArray[]=/mysubtree*

AlwaysUpdateArray[]
AlwaysUpdateArray[]=/

Now the static cache will be created in the static folder. Right under the folder there are folders for each site access you are statically caching ( CachedSiteAccesses[] setting ). There's no need to append your site access name to the value of the StaticStorageDir setting.

independent eZ Publish developer and service provider | http://blog.coomanskristof.be | http://ezpedia.org

Łukasz Serwatka

Thursday 15 February 2007 12:18:15 am

Are you using URL based site accesses? If yes, good. If no, bad for the static caching system, it only works with URL based site accesses.

Acually this is not entirely true. Static caching works with HOST access type, in this case you need 2 virtual hosts setup, one for public site and one for admin site to avoid problems with admin interface. I tested it with HOST and works as expected.

Personal website -> http://serwatka.net
Blog (about eZ Publish) -> http://serwatka.net/blog

Kristof Coomans

Thursday 15 February 2007 12:36:43 am

I probably should have said: <i>does not seem to work very well</i>: http://issues.ez.no/7982

independent eZ Publish developer and service provider | http://blog.coomanskristof.be | http://ezpedia.org

Fabio Carissimi

Thursday 15 February 2007 3:19:35 am

Hello,

first of all, thanks for your help Kristof and Lukasz,

let me do a brief summary :
I am using <b>ezp 3.9</b> (php 4.3.9-cgi, mysql 4.1.20, Apache 2.0.52) and I am using host access type with a virtual host for each public site and for each admin site and I have still the same settings and <b>static cache is generated without any problem.</b>

The problem is when I try to update an object, static cache should be replaced but it is not always working.
I just tried it now :
the first time, I modify an object and publish it and static cache of this object is replaced.
But if I try it again a second time with an other modification, it is not working.
I tried again 10 mn later and it works.
Is it normal ? should I wait to do another publication ?
That's my problem. but maybe it isn't ...
can you tell me if this waiting time is normal ?
I just want to understand it better to avoid future problems ...

Thanks for help

PS :
Kristof, your different approach can't be applied to my server, because we have many sites which won't have same cache strategy.
If I put CachedURLArray[]=/news in override/staticcache.ini.append.php and site1 wants /news to be cached and site don't want it is not working. But I think you suggested it to
solve missing cache generation, and it is not the problem here

Fabio Carissimi

Thursday 22 February 2007 8:21:35 am

Hello,
I still have problems with static cache, it is not working very well,

now I have also a content/view/full directory tree created with a folder for
each node that contains index.html static cache,

I have both this folders and the folders I want to be created (mysubtree, mysubtree2, etc ...)

why is this created ?

thanks for help

Fabio Carissimi

Wednesday 07 March 2007 1:10:46 am

Hello,

I have still big problems with static cache,
when I update a page in the administration interface, the static cache is not replaced
for pages in AlwaysUpdateArray[].

There is also a problem because I setup to have CachedURLArray[]=/mysubtree*
and in static cache directory, I have a mysubtree directory but I also have a directory
content with content/viwe/full/NODE_ID/index.html ...

Result of all: when I want a page to be updated, i have to remove manually the static Cache AND empty cache in the administration.

I really don't know what to do

thanks for help ...

eZ debug

Timing: Jan 18 2025 15:09:49
Script start
Timing: Jan 18 2025 15:09:49
Module start 'content'
Timing: Jan 18 2025 15:09:50
Module end 'content'
Timing: Jan 18 2025 15:09:50
Script end

Main resources:

Total runtime0.9219 sec
Peak memory usage4,096.0000 KB
Database Queries214

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0053 588.9453180.8281
Module start 'content' 0.00530.7550 769.7734686.0625
Module end 'content' 0.76030.1615 1,455.8359344.4609
Script end 0.9218  1,800.2969 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00390.4280210.0002
Check MTime0.00150.1616210.0001
Mysql Total
Database connection0.00080.084010.0008
Mysqli_queries0.833390.38922140.0039
Looping result0.00200.22142120.0000
Template Total0.897697.420.4488
Template load0.00200.216720.0010
Template processing0.895697.154920.4478
Template load and register function0.00010.013010.0001
states
state_id_array0.00060.068010.0006
state_identifier_array0.00080.082020.0004
Override
Cache load0.00180.19511010.0000
Sytem overhead
Fetch class attribute can translate value0.00120.133940.0003
Fetch class attribute name0.00110.1220110.0001
XML
Image XML parsing0.00210.223640.0005
class_abstraction
Instantiating content class attribute0.00000.0022120.0000
General
dbfile0.00410.4464350.0001
String conversion0.00000.000530.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
26content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
18content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 60
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs