Esteemed Monks,
I have a series of Perl CGI scripts that intermittently are very slow. The same scripts have been in use for a long time on the same system with no problem, but this has started only recently -- and system traffic hasn't increased recently.
In investigating the problem I wrote the following test CGI to figure out which part of the CGI is taking the most time, and found that:
- When the scripts are being slow, the entire lag occurs at the end of the BEGIN block ($time4 - $time3). The lag is between 30-120 seconds
- If, during a slow period, I run a similar script that doesn't have a BEGIN block, it runs very quickly. Complicated scripts without BEGIN blocks also run quickly.
- During a not-slow period, everything runs normally, and all timed sections run in 0-1 seconds each.
- The site isn't receiving unreasonable amounts of traffic during these slow periods, and our performance monitoring tools don't show that the CPU, IO, or memory is maxed-out.
We're using Perl 5.00503 under Apache, without mod_perl.
What I'm looking for is some insight/speculation into why the interpreter might lag so much at the end of a BEGIN block.
BEGIN {
$time1 = time;
[ DO MISCELLANEOUS TASKS ]
$time2 = time;
unshift @INC, "$home/custom/lib";
$time3 = time;
}
$time4 = time;
print "Content-type:text/html\n\n";
print "Begin Block: " . ($time3 - $time1) . "\n";
print " Miscellaneous Tasks: " . ($time2 - $time1) . "\n";
print " unshift inc: " . ($time3 - $time2) . "\n";
print "End begin block/begin main body: " . ($time4 - $time3) . "\n";
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.