Import script timing out (?) after 100 seconds

Author Message

Eirik Alfstad Johansen

Tuesday 10 October 2006 12:28:23 pm

Me again, :)

I have an import script which constructs content objects and nodes in eZP. After aprox 101 seconds (three tests show between 101.482512951 and 101.839282036 seconds) the script stops and an no result is sent to the browser. This happens somewhere between the 277th and 279th imported product, so it doesn't seem to be related to any input data failure (I know this beause I send data to the error log for each imported object as the script runs)

The max_execution_time of the server is set to 30, but in the script, I use set_time_limit(300).

I've gone through all the log files, but none of them give any indication as to what is happening.

Does anyone have any idea?

Thanks in advance !

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Kristian Hole

Tuesday 10 October 2006 3:00:08 pm

Hi Eirik.

Check the apache-logs to see if you have a seg-fault. Then it's most likely the reference bug i PHP 4.3.

Otherwise i would recommend to run the import as a cronjob, since it does not run with a timeout there.

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

Eirik Alfstad Johansen

Tuesday 10 October 2006 10:04:36 pm

Hi Kristian,

As I said, I'm running 3.8.4 and thereby PHP v. 4.4. Does this mean I can rule out the reference bug you are speaking of?

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Claudia Kosny

Wednesday 11 October 2006 12:32:30 am

Hello Eirik

I would also check the memory usage - I once had a script that exceeded the allowed memory limit always at the 91st product. Although this should produce some error message at least...

Most likely unneccessary question: Did you check the php error log as well? Is your error reporting set to 2047?

Greetings from Luxembourg

Claudia

Eirik Alfstad Johansen

Wednesday 11 October 2006 2:29:35 am

Hi Claudia,

Thanks for the tip. I tried increasing the PHP memory limit from 16MB to 32MB, but it doesn't seem to have had any effect.

Also, the only thing outputted to the error log is this:

[error] PHP Notice: Undefined variable: relMemory in /home/user/public_html/ezpublish-3.8.4/lib/ezutils/classes/ezdebug.php on line 1447

However, this does not terminate the script. It continues to run for about 2 minutes after this message is written to the log.

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Xavier Dutoit

Wednesday 11 October 2006 6:11:08 am

Hi Eirik,

I'll second the suggestion to run the import from a cronjob or the cli.

Good luck

X+

http://www.sydesy.com

Eirik Alfstad Johansen

Wednesday 11 October 2006 7:25:58 am

Hi Xavier,

I'm not familiar with running a script as cli. Does it involve refactoring, or do I is there some special shell syntax?

I can't find any documentation regarding it.

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Xavier Dutoit

Wednesday 11 October 2006 9:24:30 am

Hi,

Have a look at the bin/php programs. Basically, you have a few init lines:

include_once( 'lib/ezutils/classes/ezcli.php' );
include_once( 'kernel/classes/ezscript.php' );

$cli =& eZCLI::instance();
$script =& eZScript::instance( array( 'description' => ( "eZ publish Cache Handler\n" .
                                                         "Allows for easy clearing of Cache files\n" .
                                                         "\n" .
                                                         "./bin/ezcache.php --clear-tag=content" ),
                                      'use-session' => false,
                                      'use-modules' => false,
                                      'use-extensions' => true ) );

$script->startup();
...

and the libraries provide various methods to debug, get the params from the cli and so on. Have a look at the existing programs, the opensource the doc is the code ;)

X+

http://www.sydesy.com

Kristian Hole

Wednesday 11 October 2006 10:05:31 am

No, if you are using PHP 4.4, it is probably not caused by the reference bug.

The following error:

[error] PHP Notice: Undefined variable: relMemory

Is given after the code has crashed (from the cleanup-handler in eZ publish), so check if you have errors before this.

I like cronjobs because you do not need all of the startup-code you do in the CLI scripts.

Example of cronjob in extension:

extension/myext/settings/cronjob.ini.append

[CronjobPart-test]
Scripts[]
Scripts[]=test.php

[CronjobSettings]
ExtensionDirectories[]=myext

extension/myext/cronjobs/test.php

<?php
echo "This is my cronjob
?>

Enable the extension.

Then you can run it like this from the ezpublish root dir:

php runcronjobs.php test

http://ez.no/products/ez_publish/documentation/installation/the_cronjob_script

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

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 00:35:50
Script start
Timing: Jan 19 2025 00:35:50
Module start 'layout'
Timing: Jan 19 2025 00:35:50
Module start 'content'
Timing: Jan 19 2025 00:35:51
Module end 'content'
Timing: Jan 19 2025 00:35:51
Script end

Main resources:

Total runtime0.7879 sec
Peak memory usage4,096.0000 KB
Database Queries79

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0054 588.0469152.6406
Module start 'layout' 0.00550.0021 740.687539.4766
Module start 'content' 0.00750.7782 780.1641696.6484
Module end 'content' 0.78570.0021 1,476.812524.1250
Script end 0.7878  1,500.9375 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00310.3894160.0002
Check MTime0.00130.1664160.0001
Mysql Total
Database connection0.00100.127210.0010
Mysqli_queries0.707989.8473790.0090
Looping result0.00070.0865770.0000
Template Total0.758496.320.3792
Template load0.00200.258620.0010
Template processing0.756395.997220.3782
Template load and register function0.00010.013010.0001
states
state_id_array0.00160.197010.0016
state_identifier_array0.00080.106420.0004
Override
Cache load0.00180.2329660.0000
Sytem overhead
Fetch class attribute can translate value0.00060.077740.0002
Fetch class attribute name0.00100.1241120.0001
XML
Image XML parsing0.00150.189440.0004
class_abstraction
Instantiating content class attribute0.00000.0039170.0000
General
dbfile0.00130.1621280.0000
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
8content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
14content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
5content/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: 38
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs