Images on load balanced servers

Author Message

Dries Samyn

Tuesday 31 May 2005 7:08:09 am

Hi,

eZ publish, by default, resizes images (as specified in the images.ini file) when it is first accessed, but it does not seem to re-create it if the resized image is not there. This leaves a problem when the web server is load balanced because it will create the image on only one server. Is there a way to either force ezPublish to create the image on publish (then it will be rsynched to our web servers, we use a 3rd server as the "master admin" server), or alternatively, is there a way to get eZPublish to generate the image always if it does not exist?

Thanks,

Dries.

kracker (the)

Tuesday 31 May 2005 5:15:51 pm

I think you may wish to use this contribution to more closely track these modified files. <i>http://ez.no/community/contribs/hacks/php_file_logging</i>

Related Articles and Messages:

<i>http://www.ez.no/community/articles/clustering_ez_publish
http://ez.no/community/news/ez_publish_3_enterprise_setup_test
http://www.ez.no/community/forum/install_configuration/load_balanced_configuration</i>
http://www.ez.no/community/forum/install_configuration/new_ez_no_servers

//kracker

<i>Look; I can't change the way I think, And I can't change the way I am ...</i>

eminem : still don't give a ....

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Dries Samyn

Wednesday 01 June 2005 1:20:13 am

Thanks Kracker.
I did read the articles. We're using rsynch to synch the storage folders, and that seems to work all fine, but the problem is specifically to do with the image files, and I don't see how the logging "hack" could solve this.
Does anybody know (or could point me towards) where eZ Publish finds out to either read a file from disk, or transform the needed file and create one. I think the logic there is incorrect, as I think eZPublish should always create an image file if there isn't one available on disk. I'm happy to look into that, and post a hack, but any pointers would be really helpfull.

Cheers,

Dries.

kracker (the)

Wednesday 01 June 2005 1:55:11 am

I guess what I am trying to point out is that the contribution: <i>http://ez.no/community/contribs/hacks/php_file_logging</i>

Provides a patch to the ezimagefile.php file (provided with contribution) that creates a real time log of the files created by eZ publish (ie: image variations). With this contribution you can sync the files listed in the log specifically with the sync.php script (image variations, newly added images, etc) in (close to) real time which can be used to more closely rsync between the different nodes on your server cluster.

I believe this would allow you to reach your goal. I could be wrong, I'm open to this, this is my first impression. I simply suggest testing this contribution for yourself to see if you think or see weather it will meet your own needs.
If I am wrong, you might be able to extend it to then meet your needs.

Here is the part of the code that made me think that this would work for you, the patch adds code to log files created.

Index: kernel/classes/datatypes/ezimage/ezimagefile.php
===================================================================
--- kernel/classes/datatypes/ezimage/ezimagefile.php    (revision 10945)
+++ kernel/classes/datatypes/ezimage/ezimagefile.php    (working copy)
@@ -124,6 +124,16 @@
         if ( $fileObject )
             return false;
         $fileObject =& eZImageFile::create( $contentObjectAttributeID, $filepath );
+        if ( !strpos( $filepath, "/storage/images-versioned/" ) )
+        {
+            $logFile = ini_get( 'file_action_log' );
+            if (!$logFile)
+                $logFile = "/tmp/fileops.log";
+            $fp = fopen( $logFile, "a" );
+            fwrite( $fp, "w\t" . $filepath . "\n" );
+            fclose( $fp );
+        }
+
         $fileObject->store();
         return true;
     }

//kracker
<i>Aesop Rock : Easy</i>

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

kracker (the)

Wednesday 01 June 2005 2:11:30 am

I realize though that you are seeking a solution from a different perspective. Who is to say which is more applicable for you; save you :)

I took a quick look at the related kernel files and thought it might be worth mentioning as you might be able to add a function to test for a image variation and if it does not exist, simple create it. Though if you did so I would strongly advocate the use of an extension to do so.

<i>kernel/classes/datatypes/ezimage/</i>
<i>kernel/classes/datatypes/ezimage/ezimagevariation.php</i>

happy hacking,
//kracker

<i>The Postal Service : Give Up : Sleeping In</i>

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Dries Samyn

Wednesday 01 June 2005 7:52:53 am

Thanks for the reply. The help is much appreciated.

There's 2 things. First, the hack described is not ideal because whatever synch method you use, if it's not realtime it's not perfect (as mentioned in the article: "his cluster setup is not ideal. If a page is visited on server A which causes an image variation to be created, e.g. the first time an article is shown with an embedded image, and server B gets a hit on the same page before the image variation has been synced from server A to B then the image shown on server B will be broken.").

So that's why I'm trying to find a better solution.

Second, I should have described my setup a bit better.
I basically have 3 servers. One is the "admin" server, and this is the only server that is used for admin. There is no user contribution or anything on the frontend, so all the content edited, or files uploaded will be done through this server.
We use rsynch to synch the storage and cache folders from the admin server to 2 "front-end" servers. These means, that when the servers get synched, the cache gets updated from the "admin" server (this usually means cache gets deleted and recreated on the front-end servers), and while this happens, the storage folders get synched to, so in theory the images would be available.
Now. What happens is, that the first hit to an article with an image, will cause something to create the image variant on that server. Then, for some reason I don't understand yet, ezPublish knows this, and when somebody hits the second server, it thinks the image variant is available in the storage folder, but it isn't.
The odd thing is, is that when you "clear all cache" from the admin interface, the image variant DOES get re-created. So clearing the cache on the "broken" server fixes the problem (this is of course not realistic). BUT, when you manually delete all cache files from the file system, the image variant DOES NOT get reacreted. So, I think there must be something set in the database as well, but I can't figure out what or where.

Ideally I would like eZPublish to ALWAYS create an image variant if it is not available in the storage folder, but I don't know where to do that.

A second possible solution would be to create the image variants when the image gets uploaded. This would work because we synch the storage folder together with the cache, so when a new article with image is available after synch, the image should be available as well.

I hope this is a bit clearer? ;)

Cheers,

Dries.

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 18 2025 19:22:40
Script start
Timing: Jan 18 2025 19:22:40
Module start 'layout'
Timing: Jan 18 2025 19:22:40
Module start 'content'
Timing: Jan 18 2025 19:22:41
Module end 'content'
Timing: Jan 18 2025 19:22:41
Script end

Main resources:

Total runtime1.2590 sec
Peak memory usage4,096.0000 KB
Database Queries66

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0118 589.0469152.6250
Module start 'layout' 0.01180.0037 741.671939.4609
Module start 'content' 0.01551.2420 781.1328595.1328
Module end 'content' 1.25740.0015 1,376.265620.1641
Script end 1.2590  1,396.4297 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00350.2812160.0002
Check MTime0.00140.1098160.0001
Mysql Total
Database connection0.00140.114310.0014
Mysqli_queries1.182593.9256660.0179
Looping result0.00060.0483640.0000
Template Total1.214896.520.6074
Template load0.00210.170120.0011
Template processing1.212796.319220.6063
Template load and register function0.00020.019810.0002
states
state_id_array0.00160.126010.0016
state_identifier_array0.00120.095320.0006
Override
Cache load0.00180.1463570.0000
Sytem overhead
Fetch class attribute can translate value0.00070.055420.0003
Fetch class attribute name0.00130.105370.0002
XML
Image XML parsing0.00100.076720.0005
class_abstraction
Instantiating content class attribute0.00000.001790.0000
General
dbfile0.00120.0968180.0001
String conversion0.00000.000640.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/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
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/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: 31
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs