Using the code below each image download) file_get_contents() ) takes on average 8-15 seconds.....
If I do not use a context on file_get_contents() then image download is less than a second.
If I change the $opts to, below then i get same performance as file_get_contents() without a context which takes appox 13 seconds to process 2,500 imagesx.
$opts = array(
'http'=>array(
'protocol_version'=>'1.1',
'method'=>'GET',
'header'=>array(
'Connection: close'
),
'user_agent'=>'Image Resizer'
)
);
Reproduce:
$start_time = mktime();
$products = array(
array( 'code'=>'A123', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A124', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A125', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A126', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A127', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A128', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A134', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A135', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A146', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' ),
array( 'code'=>'A165', 'image_url'=>'http://www.google.com/intl/en_ALL/images/srpr/logo1w.png' )
);
if ( count( $products ) > 0 ) {
$opts = array(
'http'=>array(
'protocol_version'=>'1.1',
'method'=>'GET',
'user_agent'=>'Image Resizer'
)
);
$context = stream_context_create($opts);
$def_width = 100;
$max_width = $def_width;
foreach( $products as $product ) {
$code = $product['code'];
$folder = substr( $code, 0, 3 );
echo( 'Looking at: ' .$product['code'] ."<br />" );
$file = '/tmp/' .$folder .'/' .$code .'_' .$def_width .'.jpg';
$filemtime = @filemtime($file);
$gen_file = true;
if ( $filemtime !== false ) {
$file_age = (time() - $filemtime);
if ( $file_age <= 300 ) {
$gen_file = false;
}
}
echo( ' File not cached or cached file has expired<br />' );
if ( $gen_file ) {
echo( ' Getting File...');
$imgStr = file_get_contents( $product['image_url'], false, $context );
$img = @imagecreatefromstring($imgStr);
if ( is_resource( $img ) ) {
echo( 'DONE' .'<br />' );
$image_x = imagesx($img);
$image_y = imagesy($img);
if ( $def_width >= $image_x ) {
$def_width = $image_x;
}
echo( ' Calculating Scale<br />' );
$ts = min( $max_width/$image_x,$max_width/$image_y);
$thumbhght = $ts * $image_y;
$thumbwth = $ts * $image_x;
$thumb_image_resized = imagecreatetruecolor( $thumbwth, $thumbhght);
imagecopyresampled($thumb_image_resized, $img, 0, 0, 0, 0, $thumbwth, $thumbhght, $image_x, $image_y );
echo( ' Checking For Directory<br />' );
if ( !is_dir( '/tmp/' .$folder ) ) {
mkdir( '/tmp/' .$folder );
}
echo( ' Writing File<br />' );
$new_file = '/tmp/' .$folder .'/' .$code .'_' .$def_width .'.jpg';
imagejpeg( $thumb_image_resized, $new_file, 100);
echo( ' DONE<br />' );
imagedestroy($img);
imagedestroy($thumb_image_resized);
} else {
echo( 'Problem Getting Image<br />' );
die();
}
} else {
echo( ' Already Exists<br />' );
}
}
}
$end_time = mktime();
echo( 'Completed In...' .($end_time - $start_time ) .' seconds(s)<br />' );
HTTP 1.1 requests are pipelined by default. If you don't "Connection: Close", it assumes "Connection: Keep-Alive", and then you have to wait for the connection to time out (since you never explicitly closed it) before the next loop will start.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With