Cronjobs and multiple siteaccesses

Author Message

Piotrek Karaś

Sunday 15 April 2007 12:02:44 am

Hello,

Few questions about cronjobs execution in a multiple siteaccess eZ publish installation:
a) Do I have to execute cronjobs for each and every siteaccess? Why?
b) Is there a way/a reason to execute cronjobs for all siteaccesses at once or should I execute them separately?
c) Do I need to run cronjobs for the admin interface? Why or why not?
d) If I run cronjobs for all the siteaccesses, wouldn't at least some of the actions be redundant?

It doesn't seem to be covered by the documentation. Similar topic has already been posted, but it was three years ago, and the problem wasn't really solved.

Thank you for any help.

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Felix Woldt

Sunday 15 April 2007 4:10:26 am

Hello,

> a) Do I have to execute cronjobs for each and every siteaccess? Why?

Yes you have! Because every siteaccess have different ini settings, which are used by processing the cronjob.

> b) Is there a way/a reason to execute cronjobs for all siteaccesses at once or should I execute them separately?

A way to execute a cronjob for all siteaccess could be, write a new shell or php script which execute all runcronjobs.php -s siteaccess .

> c) Do I need to run cronjobs for the admin interface? Why or why not?

Yes i think so, if you use workflows / notifications / link checking ...

> d) If I run cronjobs for all the siteaccesses, wouldn't at least some of the actions be redundant?

Why redundant? If you only process cronjobs you are needed, then you have no redundance. Which cronjobs should be run you can set in cronjob.ini.append.php of every siteaccess. If you want to split the cronjobs you can use new blocks in cronjob.ini.append.php maybe a block [daily] , [weekly] =>

runcronjobs.php daily -s siteaccess1 
runcronjobs.php weekly -s siteaccess1 

See documentation. So you can process large scripts like link checkung once a week and notifications.php for example every 15 minutes.

Take care. Only run needed cronjobs! Otherwise the server have to work to much ;-)

Greetings
Felix Woldt

http://www.jac-systeme.de - Developers united in eZ Publish: http://www.cjw-network.com

CJW Newsletter 1.0.0 released: http://projects.ez.no/cjw_newsletter

Heath

Sunday 15 April 2007 4:17:45 am

These are fair references, <i>http://ezpedia.org/wiki/en/ez/cronjob
http://ez.no/doc/ez_publish/technical_manual/3_8/features/cronjobs
http://ez.no/doc/ez_publish/technical_manual/3_8/features/cronjobs/configuring_cronjobs</i>

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Piotrek Karaś

Sunday 15 April 2007 5:16:19 am

@Heath: I'm really convinced that answers to at least some of my questions aren't covered in the docs (or maybe I just don't see them yet - I keep reading the entire documentation every few weeks to discover new useful facts, that I hadn't been able to understand or attach before :))) Thanks anyway!

@Felix:
<i>>> b) Is there a way/a reason to execute cronjobs for all siteaccesses at once or should I execute them separately?
>A way to execute a cronjob for all siteaccess could be, write a new shell or php script which execute all runcronjobs.php -s siteaccess .</i>

I was rather thinking of a build-in capability, but of course a group of executions should do it as well.

<i>>> c) Do I need to run cronjobs for the admin interface? Why or why not?
>Yes i think so, if you use workflows / notifications / link checking ...</i>
<i>>> d) If I run cronjobs for all the siteaccesses, wouldn't at least some of the actions be redundant?
>Why redundant? If you only process cronjobs you are needed, then you have no redundance.</i>

So how do I know which cronjobs to choose for particular siteaccess?

I just ran default cronjobs on a default installation for both admin and user sites. I read a message that in both cases all of the links were checked. Conclusion: I probably only need to check the links for admin interface, two would be redundant. Is that correct?

Things get more complicated when it comes to content, for example. Let's take indexcontent.php script, which, according to the manual, performs delayed search indexing of newly added content objects. Let's say we have two user sites: user1 (English) and user2 (German), same structure, but different languages (using content translations). At some point we create new nodes with some content that should be indexed, and that includes translations. What happens if we only run content indexing for user1, but not user2? How would the situation be affected by default object availability option? Would the situation be the same or different if we had two separate structures for both sites? It's possible that I shouldn't worry about those things, but then would I be able to tell which cronjob scripts are required for which siteaccess? :)

<i>> Only run needed cronjobs! Otherwise the server have to work to much ;-)</i>

This is one of the reasons why I need to have good control over cronjobs - my hosting solution has a number of 'mean' limitations, while most of my eZ publish installations are multi-site.

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Heath

Sunday 15 April 2007 5:46:28 am

Take a look at the stock cronjob.ini settings file, <i>http://pubsvn.ez.no/nextgen/trunk/settings/cronjob.ini</i>

You could simple create an override of this settings file in your siteaccess, <i>settings/siteaccess/ezwebin_user_site/cronjob.ini.append.php</i>

You can then customize these settings to meet your own needs, here is an example of most of the available cronjobs separated into two groups, frequent (run very regularly, say hourly) and infrequent (run once a week).

[CronjobPart-infrequent]
Scripts[]=basket_cleanup.php
Scripts[]=linkcheck.php
Scripts[]=rssimport.php
Scripts[]=indexcontent.php
Scripts[]=subtreeexpirycleanup.php
Scripts[]=internal_drafts_cleanup.php

[CronjobPart-frequent]
Scripts[]=notification.php
Scripts[]=workflow.php
Scripts[]=unpublish.php
Scripts[]=hide.php
#Scripts[]=updateviewcount.php

Then you should be able to run each of these cronjob 'parts' or groups of cronjobs individually from crontab. Here is an example

52 3,23 * * * cd /web/pro/doc/; ./runcronjobs.php frequent

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Piotrek Karaś

Sunday 15 April 2007 12:40:54 pm

Thanks for the technical details, I think I have now the <b>how</b> part pretty much covered and clear. Just waiting for someone to shed some light on the <b>why</b> part :)
Greetings!

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 19 2025 07:23:22
Script start
Timing: Jan 19 2025 07:23:22
Module start 'layout'
Timing: Jan 19 2025 07:23:22
Module start 'content'
Timing: Jan 19 2025 07:23:24
Module end 'content'
Timing: Jan 19 2025 07:23:24
Script end

Main resources:

Total runtime1.2463 sec
Peak memory usage4,096.0000 KB
Database Queries68

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 590.3750152.6250
Module start 'layout' 0.00580.0030 743.000039.4453
Module start 'content' 0.00871.2359 782.4453646.9609
Module end 'content' 1.24460.0016 1,429.406324.1563
Script end 1.2462  1,453.5625 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00320.2534160.0002
Check MTime0.00140.1087160.0001
Mysql Total
Database connection0.00050.038710.0005
Mysqli_queries1.174294.2179680.0173
Looping result0.00060.0495660.0000
Template Total1.209997.120.6050
Template load0.00230.183120.0011
Template processing1.207696.897420.6038
Template load and register function0.00010.007810.0001
states
state_id_array0.00120.097410.0012
state_identifier_array0.00270.213220.0013
Override
Cache load0.00180.1472610.0000
Sytem overhead
Fetch class attribute can translate value0.00090.075930.0003
Fetch class attribute name0.00100.079590.0001
XML
Image XML parsing0.00280.221130.0009
class_abstraction
Instantiating content class attribute0.00000.0019120.0000
General
dbfile0.00320.2542300.0001
String conversion0.00000.000840.0000
Note: percentages do not add up to 100% because some accumulators overlap

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
6content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
6content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
12content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
6content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 35
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs